仿iphone带进度的进度条
来源:互联网 发布:平板支撑 知乎 编辑:程序博客网 时间:2024/05/19 17:06
Android中有ProgressBar这个控件但是很多时候,我们的设计有自己的想法想自己做一个UI,我们的项目中就遇到了这样的,做了自己的UI
这是一个用Paint画图实现的进度条,仿iphone带进度的进度条,线程安全的View,可直接在线程中更新进度
下面是效果图:
我们现在详解下代码:
public class RoundProgressBar extends View {/** * 画笔对象的引用 */private Paint paint;/** * 圆环的颜色 */private int roundColor;/** * 圆环进度的颜色 */private int roundProgressColor;/** * 中间进度百分比的字符串的颜色 */private int textColor;/** * 中间进度百分比的字符串的字体 */private float textSize;/** * 圆环的宽度 */private float roundWidth;/** * 最大进度 */private int max;/** * 当前进度 */private int progress;/** * 是否显示中间的进度 */private boolean textIsDisplayable;/** * 进度的风格,实心或者空心 */private int style;public static final int STROKE = 0;public static final int FILL = 1;public RoundProgressBar(Context context) {this(context, null);}public RoundProgressBar(Context context, AttributeSet attrs) {this(context, attrs, 0);}//自定义的类型attrs,在attrs中public RoundProgressBar(Context context, AttributeSet attrs, int defStyle) {super(context, attrs, defStyle);paint = new Paint();TypedArray mTypedArray = context.obtainStyledAttributes(attrs,R.styleable.RoundProgressBar);//获取自定义属性和默认值roundColor = mTypedArray.getColor(R.styleable.RoundProgressBar_roundColor, Color.RED);roundProgressColor = mTypedArray.getColor(R.styleable.RoundProgressBar_roundProgressColor, Color.GREEN);textColor = mTypedArray.getColor(R.styleable.RoundProgressBar_textColor, Color.GREEN);textSize = mTypedArray.getDimension(R.styleable.RoundProgressBar_textSize, 15);roundWidth = mTypedArray.getDimension(R.styleable.RoundProgressBar_roundWidth, 5);max = mTypedArray.getInteger(R.styleable.RoundProgressBar_max, 100);textIsDisplayable = mTypedArray.getBoolean(R.styleable.RoundProgressBar_textIsDisplayable, true);style = mTypedArray.getInt(R.styleable.RoundProgressBar_style, 0);mTypedArray.recycle();}
自定义中values文件夹下的attrs中的文件是这样的:
<resources> <declare-styleable name="RoundProgressBar"> <attr name="roundColor" format="color"/> <attr name="roundProgressColor" format="color"/> <attr name="roundWidth" format="dimension"></attr> <attr name="textColor" format="color" /> <attr name="textSize" format="dimension" /> <attr name="max" format="integer"></attr> <attr name="textIsDisplayable" format="boolean"></attr> <attr name="style"> <enum name="STROKE" value="0"></enum> <enum name="FILL" value="1"></enum> </attr> </declare-styleable> </resources>上面是自定义的一些属性什么的,这就是到时候我们用的时候设置尺寸和大小颜色
/** * 画最外层的大圆环 */int centre = getWidth()/2; //获取圆心的x坐标int radius = (int) (centre - roundWidth/2); //圆环的半径paint.setColor(roundColor); //设置圆环的颜色paint.setStyle(Paint.Style.STROKE); //设置空心paint.setStrokeWidth(roundWidth); //设置圆环的宽度paint.setAntiAlias(true); //消除锯齿 canvas.drawCircle(centre, centre, radius, paint); //画出圆环
画中间的百分数
/** * 画进度百分比 */paint.setStrokeWidth(0); paint.setColor(textColor);paint.setTextSize(textSize);paint.setTypeface(Typeface.DEFAULT_BOLD); //设置字体int percent = (int)(((float)progress / (float)max) * 100); //中间的进度百分比,先转换成float在进行除法运算,不然都为0float textWidth = paint.measureText(percent + "%"); //测量字体宽度,我们需要根据字体的宽度设置在圆环中间if(textIsDisplayable && percent != 0 && style == STROKE){canvas.drawText(percent + "%", centre - textWidth / 2, centre + textSize/2, paint); //画出进度百分比}经行判断是画实心的圆还是画空心的圆
/** * 画圆弧 ,画圆环的进度 *///设置进度是实心还是空心paint.setStrokeWidth(roundWidth); //设置圆环的宽度paint.setColor(roundProgressColor); //设置进度的颜色RectF oval = new RectF(centre - radius, centre - radius, centre+ radius, centre + radius); //用于定义的圆弧的形状和大小的界限switch (style) {case STROKE:{paint.setStyle(Paint.Style.STROKE);canvas.drawArc(oval, 0, 360 * progress / max, false, paint); //根据进度画圆弧break;}case FILL:{paint.setStyle(Paint.Style.FILL_AND_STROKE);if(progress !=0)canvas.drawArc(oval, 0, 360 * progress / max, true, paint); //根据进度画圆弧break;}
这是线程的
设置进度,此为线程安全控件,由于考虑多线的问题,需要同步
public synchronized int getMax() {return max;}/** * 设置进度的最大值 * @param max */public synchronized void setMax(int max) {if(max < 0){throw new IllegalArgumentException("max not less than 0");}this.max = max;}/** * 获取进度.需要同步 * @return */public synchronized int getProgress() {return progress;}/** * 设置进度,此为线程安全控件,由于考虑多线的问题,需要同步 * 刷新界面调用postInvalidate()能在非UI线程刷新 * @param progress */public synchronized void setProgress(int progress) {if(progress < 0){throw new IllegalArgumentException("progress not less than 0");}if(progress > max){progress = max;}if(progress <= max){this.progress = progress;postInvalidate();}}
在XML文件中的使用是这样的
<com.example.roundprogressbar.RoundProgressBar android:id="@+id/roundProgressBar4" android_custom:style="FILL" android:layout_width="80dip" android:layout_height="80dip" android_custom:roundWidth="1dip" android_custom:roundProgressColor="#C2C2C2" />
android_custom:style="FILL"这个设置画出的圆是空心还是实心
<pre name="code" class="java"> android_custom:roundWidth="1dip"宽度画出圆的宽度
<pre name="code" class="java"> android_custom:roundProgressColor="#C2C2C2" 画出圆的颜色
Demo下载地址
0 0
- 仿iphone带进度的进度条
- 使用带进度显示的圆形进度条
- 带具体进度的进度条对话框
- 带波形进度的环形进度条实现
- 自定义View(带进度的圆形进度条)
- 仿迅雷下载进度的圆形面积进度条
- 仿迅雷下载进度的圆形面积进度条
- Android开发 自制圆形带进度显示的进度条
- Android开发 自制圆形带进度显示的进度条
- 2种方式实现带进度的圆形进度条
- 自定义View,自定义属性(带进度的圆形进度条)
- Android 自定义带进度显示的半圆形进度条ArcTextProgressBar
- Android 自定义View -带进度的圆形进度条
- Android带圆形数字进度的自定义进度条
- 自定义一个带进度值的圆形进度条
- android 自定义带进度值的圆形进度条
- 自己定义一个带进度的圆形进度条
- 进度条的进度
- big data相关的技术文章
- SCADA系统
- 老码农教你学英语:补充一些英语学习素材
- VMware(安装ghostxp图文教程)
- Socket(Udp)通信客户端
- 仿iphone带进度的进度条
- 序列化类注意的问题
- uva - 11992 (下推法改进版: 1.246 秒)
- maven war包加入SVN版本号信息
- JSP中文乱码解决办法汇总
- Hibernate 常见问题
- Android 中调用隐式意图出现的问题及解决方法
- Objective-C runtime之运行时的基本特点(一)
- Hadoop HDFS (2) HDFS命令行接口