Android 自定义View (四) 视频音量调控
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24529807
今天没事逛eoe,看见有人求助要做一个下面的效果,我看下面一哥们说要用12张图片,这尼玛逆天的麻烦,仔细看了一下感觉自定义控件木有问题,就花点时间写了一个。
好了,进入正题,继续我们的自定义View四部曲。
1、先分许需要的属性,两个小块的颜色、一张中间的图片、间隙大小、一个多少个块块。分析完毕,开始写attr.xml
- <?xml version="1.0" encoding="utf-8"?>
 - <resources>
 - <attr name="firstColor" format="color" />
 - <attr name="secondColor" format="color" />
 - <attr name="circleWidth" format="dimension" />
 - <attr name="dotCount" format="integer" />
 - <attr name="splitSize" format="integer" />
 - <attr name="bg" format="reference"></attr>
 - <declare-styleable name="CustomVolumControlBar">
 - <attr name="firstColor" />
 - <attr name="secondColor" />
 - <attr name="circleWidth" />
 - <attr name="dotCount" />
 - <attr name="splitSize" />
 - <attr name="bg" />
 - </declare-styleable>
 - </resources>
 
2、在构造中获取这些属性:
- /**
 - * 第一圈的颜色
 - */
 - private int mFirstColor;
 - /**
 - * 第二圈的颜色
 - */
 - private int mSecondColor;
 - /**
 - * 圈的宽度
 - */
 - private int mCircleWidth;
 - /**
 - * 画笔
 - */
 - private Paint mPaint;
 - /**
 - * 当前进度
 - */
 - private int mCurrentCount = 3;
 - /**
 - * 中间的图片
 - */
 - private Bitmap mImage;
 - /**
 - * 每个块块间的间隙
 - */
 - private int mSplitSize;
 - /**
 - * 个数
 - */
 - private int mCount;
 - private Rect mRect;
 - public CustomVolumControlBar(Context context, AttributeSet attrs)
 - {
 - this(context, attrs, 0);
 - }
 - public CustomVolumControlBar(Context context)
 - {
 - this(context, null);
 - }
 - /**
 - * 必要的初始化,获得一些自定义的值
 - *
 - * @param context
 - * @param attrs
 - * @param defStyle
 - */
 - public CustomVolumControlBar(Context context, AttributeSet attrs, int defStyle)
 - {
 - super(context, attrs, defStyle);
 - TypedArray a = context.getTheme().obtainStyledAttributes(attrs, R.styleable.CustomVolumControlBar, defStyle, 0);
 - int n = a.getIndexCount();
 - for (int i = 0; i < n; i++)
 - {
 - int attr = a.getIndex(i);
 - switch (attr)
 - {
 - case R.styleable.CustomVolumControlBar_firstColor:
 - mFirstColor = a.getColor(attr, Color.GREEN);
 - break;
 - case R.styleable.CustomVolumControlBar_secondColor:
 - mSecondColor = a.getColor(attr, Color.CYAN);
 - break;
 - case R.styleable.CustomVolumControlBar_bg:
 - mImage = BitmapFactory.decodeResource(getResources(), a.getResourceId(attr, 0));
 - break;
 - case R.styleable.CustomVolumControlBar_circleWidth:
 - mCircleWidth = a.getDimensionPixelSize(attr, (int) TypedValue.applyDimension(
 - TypedValue.COMPLEX_UNIT_PX, 20, getResources().getDisplayMetrics()));
 - break;
 - case R.styleable.CustomVolumControlBar_dotCount:
 - mCount = a.getInt(attr, 20);// 默认20
 - break;
 - case R.styleable.CustomVolumControlBar_splitSize:
 - mSplitSize = a.getInt(attr, 20);
 - break;
 - }
 - }
 - a.recycle();
 - mPaint = new Paint();
 - mRect = new Rect();
 - }
 
3、重写onDraw
- @Override
 - protected void onDraw(Canvas canvas)
 - {
 - mPaint.setAntiAlias(true); // 消除锯齿
 - mPaint.setStrokeWidth(mCircleWidth); // 设置圆环的宽度
 - mPaint.setStrokeCap(Paint.Cap.ROUND); // 定义线段断电形状为圆头
 - mPaint.setAntiAlias(true); // 消除锯齿
 - mPaint.setStyle(Paint.Style.STROKE); // 设置空心
 - int centre = getWidth() / 2; // 获取圆心的x坐标
 - int radius = centre - mCircleWidth / 2;// 半径
 - /**
 - * 画块块去
 - */
 - drawOval(canvas, centre, radius);
 - /**
 - * 计算内切正方形的位置
 - */
 - int relRadius = radius - mCircleWidth / 2;// 获得内圆的半径
 - /**
 - * 内切正方形的距离顶部 = mCircleWidth + relRadius - √2 / 2
 - */
 - mRect.left = (int) (relRadius - Math.sqrt(2) * 1.0f / 2 * relRadius) + mCircleWidth;
 - /**
 - * 内切正方形的距离左边 = mCircleWidth + relRadius - √2 / 2
 - */
 - mRect.top = (int) (relRadius - Math.sqrt(2) * 1.0f / 2 * relRadius) + mCircleWidth;
 - mRect.bottom = (int) (mRect.left + Math.sqrt(2) * relRadius);
 - mRect.right = (int) (mRect.left + Math.sqrt(2) * relRadius);
 - /**
 - * 如果图片比较小,那么根据图片的尺寸放置到正中心
 - */
 - if (mImage.getWidth() < Math.sqrt(2) * relRadius)
 - {
 - mRect.left = (int) (mRect.left + Math.sqrt(2) * relRadius * 1.0f / 2 - mImage.getWidth() * 1.0f / 2);
 - mRect.top = (int) (mRect.top + Math.sqrt(2) * relRadius * 1.0f / 2 - mImage.getHeight() * 1.0f / 2);
 - mRect.right = (int) (mRect.left + mImage.getWidth());
 - mRect.bottom = (int) (mRect.top + mImage.getHeight());
 - }
 - // 绘图
 - canvas.drawBitmap(mImage, null, mRect, mPaint);
 - }
 - /**
 - * 根据参数画出每个小块
 - *
 - * @param canvas
 - * @param centre
 - * @param radius
 - */
 - private void drawOval(Canvas canvas, int centre, int radius)
 - {
 - /**
 - * 根据需要画的个数以及间隙计算每个块块所占的比例*360
 - */
 - float itemSize = (360 * 1.0f - mCount * mSplitSize) / mCount;
 - RectF oval = new RectF(centre - radius, centre - radius, centre + radius, centre + radius); // 用于定义的圆弧的形状和大小的界限
 - mPaint.setColor(mFirstColor); // 设置圆环的颜色
 - for (int i = 0; i < mCount; i++)
 - {
 - canvas.drawArc(oval, i * (itemSize + mSplitSize), itemSize, false, mPaint); // 根据进度画圆弧
 - }
 - mPaint.setColor(mSecondColor); // 设置圆环的颜色
 - for (int i = 0; i < mCurrentCount; i++)
 - {
 - canvas.drawArc(oval, i * (itemSize + mSplitSize), itemSize, false, mPaint); // 根据进度画圆弧
 - }
 - }
 
这里需要注意下:
画块:首先根据块数量和间隙计算,每个块所占的比例。
画图:当图比较大时,直接使用该环内切正方形大小进行约束,当图片比较小时,在正中心的位置绘制。有些数学运算过程,楼主在草稿上画了一会,不复杂,大家自己画画,我就不贴草稿了。
4、添加触摸监听:
- /**
 - * 当前数量+1
 - */
 - public void up()
 - {
 - mCurrentCount++;
 - postInvalidate();
 - }
 - /**
 - * 当前数量-1
 - */
 - public void down()
 - {
 - mCurrentCount--;
 - postInvalidate();
 - }
 - private int xDown, xUp;
 - @Override
 - public boolean onTouchEvent(MotionEvent event)
 - {
 - switch (event.getAction())
 - {
 - case MotionEvent.ACTION_DOWN:
 - xDown = (int) event.getY();
 - break;
 - case MotionEvent.ACTION_UP:
 - xUp = (int) event.getY();
 - if (xUp > xDown)// 下滑
 - {
 - down();
 - } else
 - {
 - up();
 - }
 - break;
 - }
 - return true;
 - }
 
触摸监听也得很简单哈,基本能实现,大家也可以加个最小距离加速度什么的,都行。
最后,效果图:
可惜楼主尼玛是找不到那个音量的图,不要叫我去抠图哈,就随便拿了几张图片来试试。
嘿嘿,留个言,顶一个哈~
Android 自定义View (四) 视频音量调控的更多相关文章
- Android 自己定义View (四) 视频音量调控
		
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24529807 今天没事逛eoe,看见有人求助要做一个以下的效果,我看以下一哥们说 ...
 - Android 自定义View 四个构造函数详解
		
https://blog.csdn.net/zhao123h/article/details/52210732 在开发android开发过程中,很多人都会遇到自定义view,一般都需要继承自View类 ...
 - 【朝花夕拾】Android自定义View篇之(四)自定义View的三种实现方式及自定义属性使用介绍
		
前言 转载请声明,转自[https://www.cnblogs.com/andy-songwei/p/10979161.html],谢谢! 尽管Android系统提供了不少控件,但是有很多酷炫效果仍然 ...
 - Android 自定义 view(四)—— onMeasure 方法理解
		
前言: 前面我们已经学过<Android 自定义 view(三)-- onDraw 方法理解>,那么接下我们还需要继续去理解自定义view里面的onMeasure 方法 推荐文章: htt ...
 - Android自定义View学习(四)
		
硬件加速 参考:HenCoder Android 自定义 View 1-8 硬件加速 硬件加速能够让绘制变快,主要有三个原因: 本来由 CPU 自己来做的事,分摊给了 GPU 一部分,自然可以提高效率 ...
 - Android自定义View 画弧形,文字,并增加动画效果
		
一个简单的Android自定义View的demo,画弧形,文字,开启一个多线程更新ui界面,在子线程更新ui是不允许的,但是View提供了方法,让我们来了解下吧. 1.封装一个抽象的View类 B ...
 - Android 自定义View (五)——实践
		
前言: 前面已经介绍了<Android 自定义 view(四)-- onMeasure 方法理解>,那么这次我们就来小实践下吧 任务: 公司现有两个任务需要我完成 (1)监测液化天然气液压 ...
 - Android 自定义 view(三)—— onDraw 方法理解
		
前言: 上一篇已经介绍了用自己定义的属性怎么简单定义一个view<Android 自定义view(二) -- attr 使用>,那么接下来我们继续深究自定义view,下一步将要去简单理解自 ...
 - Android 自定义View及其在布局文件中的使用示例(三):结合Android 4.4.2_r1源码分析onMeasure过程
		
转载请注明出处 http://www.cnblogs.com/crashmaker/p/3549365.html From crash_coder linguowu linguowu0622@gami ...
 
随机推荐
- Python sys.path.append
			
python sys.path.append 对于模块和自己写的程序不在同一个目录下,可以把模块的路径通过sys.path.append(路径)添加到程序中. 在程序开头加上: import syss ...
 - Java简介(2)-基本概念
			
1.抽象类:规定一个或多个抽象方法的类别本身必须定义为abstract,抽象类只是用来派生子类,而不能用它来创建对象 2.final类:又称“最终类”,它只能用来创建对象,而不能被继承,与抽象类刚好相 ...
 - linux常用svn命令(转载)
			
原地址:http://www.rjgc.net/control/content/content.php?nid=4418 1.将文件checkout到本地目录svn checkout p ...
 - XmlHttp对象
			
我是这样理解XmlHttp对象的:xml是一种文档类型Http可以把它看做是浏览器XmlHttp:可以解释为把xml的内容读到浏览器上(网页上),把这句话封装一下,见下XmlHttp是浏览器对象,起的 ...
 - thinkphp 文件下载实例 实现以及注意事项
			
#下载 function download() { $id=$_GET['id']; $file_name ...
 - HTML CSS简介与图片映射
			
1. CSS 入门 内联样式:在 HTML 元素中使用 “style” 属性,需要将表现与内容混在一起: 内部样式表:在 HTML 文档头部 <head> 区域使用 <style&g ...
 - MFC枚举USB设备碰到的一个疑难,还没解决
			
代码如下: 打开USB Hub设备之后,返回句柄hHubDevice,然后使用EnumerateHubPorts来枚举Hub的端 口.疑问在代码的中文注释中. bool CUsbEnumHub::En ...
 - 转:FIFO的定义与作用
			
一.先入先出队列(First Input First Output,FIFO)这是一种传统的按序执行方法,先进入的指令先完成并引退,跟着才执行第二条指令. 1.什么是FIFO? FIFO是英文Firs ...
 - Mahout
			
http://blog.csdn.net/yueyedeai/article/details/26567379
 - poj2352  Stars
			
http://poj.org/problem?id=2352 #include <cstdio> #include <cstring> #define maxn 400000 ...