文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android自定义控件实现UC浏览器语音搜索效果

2023-05-31 05:15

关注

 最近项目上要实现语音搜索功能,界面样式要模仿一下UC浏览器的样式,UC浏览器中有一个控件,会随着声音大小浮动,然后寻思偷个懒,百度一下,结果也没有找到类似的,只能自己动手了。

先上图看我实现的效果:

Android自定义控件实现UC浏览器语音搜索效果

这是自定义控件的代码,里面注释也很明白,就不费话了

public class CustomCircleView extends View{  private Paint mPaint;  private int strokeWidth = 0;   //圆环的宽度  private Bitmap bitmap = null;  // 图片位图  private int nBitmapWidth = 0;  // 图片的宽度  private int nBitmapHeight = 0; // 图片的高度  private int width;     //view的宽度  private int height ;    //view的高度  private int bigCircleColor =0;    //view的高度  private int floatCircleColor =0;    //view的高度  public CustomCircleView(Context context) {    this(context, null);  }  public CustomCircleView(Context context, AttributeSet attrs) {    this(context, attrs, 0);  }  public CustomCircleView(Context context, AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);    TypedArray a = context.getTheme().obtainStyledAttributes(attrs, R.styleable.CustomCircleView, defStyleAttr, 0);    int n = a.getIndexCount();    for (int i = 0; i < n; i++)    {      int attr = a.getIndex(i);      switch (attr)      {        case R.styleable.CustomCircleView_icon:          bitmap = BitmapFactory.decodeResource(getResources(), a.getResourceId(attr, 0));          break;        case R.styleable.CustomCircleView_bigCircleColor:          bigCircleColor = a.getColor(attr, Color.GRAY);          break;        case R.styleable.CustomCircleView_floatCircleColor:          floatCircleColor = a.getColor(attr,Color.GREEN);          break;      }    }    a.recycle();    mPaint = new Paint();    //如果布局中没有设置bigCircleColor和floatCircleColor的时候给他一个默认值    if (bigCircleColor==0){      bigCircleColor=Color.parseColor("#FFEEF0F1");    }    if (floatCircleColor==0){      floatCircleColor=Color.parseColor("#25c1f5");    }    // 获取图片高度和宽度    nBitmapWidth = bitmap.getWidth();    nBitmapHeight = bitmap.getHeight();  }  @Override  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {    int widthMode = MeasureSpec.getMode(widthMeasureSpec);    int widthSize = MeasureSpec.getSize(widthMeasureSpec);    int heightMode = MeasureSpec.getMode(heightMeasureSpec);    int heightSize = MeasureSpec.getSize(heightMeasureSpec);    //获取view的高度和宽度 这个view必须给精确值!!!!!!!!    if (widthMode == MeasureSpec.EXACTLY) {      width = widthSize;    }    if (heightMode == MeasureSpec.EXACTLY)    {      height = heightSize;    }    setMeasuredDimension(width, height);  }  @Override  protected void onDraw(Canvas canvas) {    super.onDraw(canvas);    mPaint.setAntiAlias(true); // 消除锯齿    //绘制最外层灰色大圆    mPaint.setColor(bigCircleColor);    mPaint.setStyle(Paint.Style.STROKE);    mPaint.setStrokeWidth(height/2-nBitmapHeight/2);    //计算圆的半径稍微麻烦点,但是在图上画一下应该能明白 (height/2-nBitmapHeight/2)/2+nBitmapHeight/2    canvas.drawCircle(width/2, height/2, (height/2-nBitmapHeight/2)/2+nBitmapHeight/2, mPaint);    //绘制浮动的圆    mPaint.setColor(floatCircleColor);    mPaint.setStyle(Paint.Style.STROKE);    mPaint.setStrokeWidth(strokeWidth);    canvas.drawCircle(width/2, height/2, strokeWidth/2+nBitmapHeight/2, mPaint);    //绘制中间图标    canvas.drawBitmap(bitmap, width/2-nBitmapWidth/2, height/2-nBitmapHeight/2, mPaint);  }  //根据传入的宽度重新绘制  public void setStrokeWidth(int with){    this.strokeWidth=with;    invalidate();  }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯