Android如何自定义View实现微信语音界面
发表于:2025-02-09 作者:千家信息网编辑
千家信息网最后更新 2025年02月09日,这篇文章主要为大家展示了"Android如何自定义View实现微信语音界面",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Android如何自定义View实
千家信息网最后更新 2025年02月09日Android如何自定义View实现微信语音界面
这篇文章主要为大家展示了"Android如何自定义View实现微信语音界面",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"Android如何自定义View实现微信语音界面"这篇文章吧。
代码
代码并不复杂,配合注释应该很容易理解。
/** * Author : BlackHao * Time : 2019/4/18 14:03 * Description : 自定义录音按钮布局界面 */public class PressedView extends View implements View.OnTouchListener { private int normalRes; private String normalText = ""; private int pressedRes; private String pressedText = ""; // private Paint paint; private Rect rect; //当前是否是按下状态 private boolean isPressed = false; // private PressCallback callback; //按下的位置y坐标 private int pressedY = 0; //当前是否是outSize private boolean isOutSize = false; //字体dp大小 private static int TEXT_SIZE = 20; //对话框相关 private Dialog soundVolumeDialog = null; //音量图片 private ImageView soundVolumeImg = null; //对话框背景 private RelativeLayout soundVolumeLayout = null; public PressedView(Context context) { super(context); init(); } public PressedView(Context context, @Nullable AttributeSet attrs) { super(context, attrs); init(); } public PressedView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(); } private void init() { // paint = new Paint(); paint.setAntiAlias(true); paint.setTextSize(DensityUtil.dip2px(getContext(), TEXT_SIZE)); paint.setColor(Color.WHITE); rect = new Rect(); // normalRes = R.drawable.blue_btn_bk; normalText = "按住 说话"; pressedRes = R.drawable.red_btn_bk; pressedText = "松开 结束"; // setOnTouchListener(this); // initSoundVolumeDlg(); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); rect.set(0, 0, getWidth(), getHeight()); if (!isPressed) { setBackgroundResource(normalRes); drawTextOnRect(canvas, rect, normalText); } else { setBackgroundResource(pressedRes); drawTextOnRect(canvas, rect, pressedText); } } @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: pressedY = (int) event.getRawY(); isOutSize = false; if (!isPressed) { isPressed = true; postInvalidate(); if (callback != null) { //回调 callback.onStartRecord(); //按下,弹出对话框 soundVolumeImg.setImageResource(R.mipmap.sound_volume_01); soundVolumeImg.setVisibility(View.VISIBLE); soundVolumeLayout.setBackgroundResource(R.mipmap.sound_volume_default_bk); soundVolumeDialog.show(); } } break; case MotionEvent.ACTION_UP: if (isPressed) { isPressed = false; postInvalidate(); if (callback != null) { int upY = (int) event.getRawY(); if (pressedY - upY < getHeight()) { //录音结束 if (soundVolumeDialog.isShowing()) { soundVolumeDialog.dismiss(); } callback.onStopRecord(); } else { //录音取消 if (soundVolumeDialog.isShowing()) { soundVolumeDialog.dismiss(); } callback.onCancelRecord(); } } } break; case MotionEvent.ACTION_MOVE: if (isPressed && callback != null) { int upY = (int) event.getRawY(); if (pressedY - upY < getHeight()) { if (isOutSize) { isOutSize = false; soundVolumeLayout.setBackgroundResource(R.mipmap.sound_volume_default_bk); } } else { if (!isOutSize) { isOutSize = true; soundVolumeLayout.setBackgroundResource(R.mipmap.sound_volume_cancel_bk); } } } break; } return true; } public void setCallback(PressCallback callback) { this.callback = callback; } public interface PressCallback { //开始录音 void onStartRecord(); //停止录音 void onStopRecord(); //取消录音 void onCancelRecord(); } /** * 在指定矩形中间drawText * * @param canvas 画布 * @param targetRect 指定矩形 * @param text 需要绘制的Text */ private void drawTextOnRect(Canvas canvas, Rect targetRect, String text) { Paint.FontMetricsInt fontMetrics = paint.getFontMetricsInt(); // 获取baseLine int baseline = targetRect.top + (targetRect.bottom - targetRect.top - fontMetrics.bottom + fontMetrics.top) / 2 - fontMetrics.top; // 下面这行是实现水平居中,drawText对应改为传入targetRect.centerX() paint.setTextAlign(Paint.Align.CENTER); canvas.drawText(text, targetRect.centerX(), baseline, paint); } /** * 初始化音量信息对话框 */ private void initSoundVolumeDlg() { soundVolumeDialog = new Dialog(getContext(), R.style.SoundVolumeStyle); soundVolumeDialog.requestWindowFeature(Window.FEATURE_NO_TITLE); soundVolumeDialog.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); soundVolumeDialog.setContentView(R.layout.tt_sound_volume_dialog); soundVolumeDialog.setCanceledOnTouchOutside(true); soundVolumeImg = (ImageView) soundVolumeDialog.findViewById(R.id.sound_volume_img); soundVolumeLayout = (RelativeLayout) soundVolumeDialog.findViewById(R.id.sound_volume_bk); } /** * 根据分贝值设置录音时的音量动画 */ public void setVolume(int voiceValue) { if (voiceValue < 200.0) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_01); } else if (voiceValue > 200.0 && voiceValue < 600) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_02); } else if (voiceValue > 600.0 && voiceValue < 1200) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_03); } else if (voiceValue > 1200.0 && voiceValue < 2400) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_04); } else if (voiceValue > 2400.0 && voiceValue < 10000) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_05); } else if (voiceValue > 10000.0 && voiceValue < 28000.0) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_06); } else if (voiceValue > 28000.0) { soundVolumeImg.setImageResource(R.mipmap.sound_volume_07); } }}
以上是"Android如何自定义View实现微信语音界面"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
界面
对话框
对话
语音
内容
篇文章
音量
代码
矩形
学习
帮助
复杂
位置
信息
动画
图片
坐标
大小
字体
布局
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
离子迁移数据库
应用软件开发就业前景
市场人员首先要软件开发价格
江苏网络技术测试题
东光软件开发项目管理
泰州市晟轩网络技术有限公司
抓信息网络安全
360网络安全医疗
网络安全科技展济源站
高二网络技术电子粤教版
网络安全科任职条件及资料
阿克苏网络技术操作
温州java软件开发需要学什么
谈谈看待网络安全的做法
排列五规律软件开发
图形数据库用法
e5 2670服务器
武汉市网络安全协会会员大会
两个服务器同步备份
数据库拆包
网络安全法第1条讲
员工部门数据库设计
vb.net 数据库连接
数据库宽表如何建立
为什么说5g网络安全
对网络安全这门课的认识
网络安全基金一直跌
fm2017最新数据库
网络安全和信息化指导思想
口袋妖怪vs官方服务器