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

作者:ludi 时间:2022-06-01 06:59:40 

 最近项目上要实现语音搜索功能,界面样式要模仿一下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();
 }
}

在res/values 下建一个attrs文件 代码:


<resources>
 <declare-styleable name="CustomCircleView">
   <attr name="bigCircleColor" format="color" />
   <attr name="floatCircleColor" format="color" />
   <attr name="icon" format="reference" />
 </declare-styleable>
</resources>

在布局中的使用:


<com.example.administrator.mycustomcircleview.CustomCircleView
 android:id="@+id/customView"
 android:layout_width="200dp"
 android:layout_height="200dp"
 android:layout_gravity="center"
 app:icon="@mipmap/voice_icon"
 app:floatCircleColor="@color/colorAccent"
 app:bigCircleColor="@color/colorPrimaryDark"
 />

高度宽度一定要给精确值,切记啊!!!颜色值可以不设定,默认就是我上面图的效果。
然后根据音量大小直接传入数值就可以了,很简单的使用方法,这里我用随机数代替了。


customView = ((CustomCircleView) findViewById(R.id.customView));
 button = ((Button) findViewById(R.id.button));
 button.setOnClickListener(this);
}

@Override
public void onClick(View v) {
 Random random=new Random();
 customView.setStrokeWidth(random.nextInt(100));
}
标签:Android,语音,搜索
0
投稿

猜你喜欢

  • JDBC连接MySQL并实现模糊查询

    2021-07-06 01:42:28
  • C# 如何调用SAP RFC

    2023-07-02 18:11:42
  • 在IDEA中配置tomcat并创建tomcat项目的图文教程

    2023-08-11 11:33:59
  • springboot 整合 sa-token简介及入门教程

    2023-03-24 01:10:45
  • Android编程实现点击EditText之外的控件隐藏软键盘功能

    2022-08-07 02:06:08
  • Java编程用栈来求解汉诺塔问题的代码实例(非递归)

    2023-01-13 21:41:25
  • Android实现点汇聚成字的动态效果详解

    2023-10-08 08:50:26
  • Java扩展库RxJava的基本结构与适用场景小结

    2022-12-27 10:03:15
  • Java内存模型详解

    2023-06-21 21:04:29
  • C#影院售票系统毕业设计(3)

    2023-04-24 04:08:57
  • 详解Android使用@hide的API的方法

    2023-02-16 07:10:31
  • c#使用多线程的几种方式示例详解

    2022-04-07 07:45:33
  • C# CultureInfo类案例详解

    2023-04-20 05:00:45
  • Java程序常见异常及处理汇总

    2021-08-12 04:20:44
  • 详解通过JDBC进行简单的增删改查(以MySQL为例)

    2023-08-14 20:16:40
  • SpringBoot整合Security安全框架实现控制权限

    2022-10-03 14:37:15
  • MapStruct处理Java中实体与模型间不匹配属性转换的方法

    2023-08-02 22:31:28
  • 详解Java高级特性之反射

    2021-06-09 14:01:06
  • fastjson生成json时Null属性不显示的解决方法

    2022-08-17 15:56:59
  • 使用javaMail实现发送邮件

    2023-01-20 21:22:26
  • asp之家 软件编程 m.aspxhome.com