老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

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實現微信語音界面”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!


分享名稱:Android如何自定義View實現微信語音界面
分享路徑:http://www.xueling.net.cn/article/ijhjjg.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 麻豆视频在线观看免费 | 日本三级网 | 4438xx全国最大 | 国产亚洲精品久久久久久牛牛 | 在线视频毛片 | av免费网站在线观看 | 亚洲美女免费视频 | 97久久精品国产 | 日韩处女网站 | 护士扒下内裤让我爽一夜 | 天天操天天操天天操天天操 | 亚洲精品无码国产一区二区 | 成人午夜免费在线视频 | 精品人妻中文av一区二区三区 | 99福利| 久久不见久久见免费影院视频观看 | 久久高潮| 国产高清在线视频观看 | 99视频| 寂寞少妇饥渴难耐自慰 | l8videosex性欧美69 | 91最新在线观看 | 欧日韩无套内射变态 | 无码av中文一区二区三区 | 人妻大胸奶水2 | 免费一区二区视频 | 宝贝好紧好爽再搔一点试视频 | 久久久久久久久久久丰满 | 国产在线播放线播放 | 麻豆视频观看免费视频观看 | 国产久一 | 麻豆果冻传媒2021精品 | 中文字幕人妻在线中字 | 日韩欧美中文字幕一区二区 | 成人亚洲免费视频 | 国产亚洲精品美女在线 | 高清一级淫片a级中文字幕 亚洲欧洲日产国无高清码图片 | 一级特黄爽大片刺激在线 | 久久99久久99精品免观看 | 大伊香蕉精品一区视频在线 | 中文字幕精品乱码中文字乱码 |