本文实例为大家分享了Android自定义view绘制圆环占比动画的具体代码,供大家参考,具体内容如下

一、实现效果图
二、核心代码
1.自定义MyProgressView.java
package com.czhappy.effectdemo.view;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Paint.FontMetrics;
import android.graphics.Rect;
import android.graphics.RectF;
import android.os.Handler;
import android.os.Message;
import android.text.TextUtils;
import android.util.AttributeSet;
import android.view.View;
import com.czhappy.effectdemo.R;
import com.czhappy.effectdemo.utils.ScreenUtil;
public class MyProgressView extends View {
// 画实心圆的画笔
private Paint mCirclePaint;
// 画圆环的画笔
private Paint mRingDefaultPaint;
// 已用环的画笔
private Paint mUsePaint;
// 画圆环的画笔
private Paint mRingPaint;
// 画白线的画笔
private Paint mLinePaint;
// 画字体的画笔
private Paint mTextPaint;
// 圆形颜色
private int mCircleColor;
// 圆环颜色
private int mRingColor;
// 半径
private float mRadius;
// 圆环半径
private float mRingRadius;
// 圆环宽度
private float mStrokeWidth;
// 圆心x坐标
private int mXCenter;
// 圆心y坐标
private int mYCenter;
// 字的长度
private float mTxtWidth;
// 字的高度
private float mTxtHeight;
// 总进度
private int mTotalProgress = 100;
// 当前进度
private int mProgress;
// 实际展示总进度
private int mShowProgress;
// 已用流量
private String usedFlow;
private Context mContext;
private Handler circleHandler = new Handler(){
public void handleMessage(Message msg) {
super.handleMessage(msg);
if(msg.what == 1){
int temp = (Integer)msg.obj;
setProgress(temp);
}
};
};
public MyProgressView(Context context, AttributeSet attrs) {
super(context, attrs);
mContext = context;
// 获取自定义的属性
initAttrs(context, attrs);
initVariable();
}
private void initAttrs(Context context, AttributeSet attrs) {
TypedArray typeArray = context.getTheme().obtainStyledAttributes(attrs,
R.styleable.TasksCompletedView, 0, 0);
mRadius = typeArray.getDimension(R.styleable.TasksCompletedView_radius, 80);
mStrokeWidth = typeArray.getDimension(R.styleable.TasksCompletedView_strokeWidth, 10);
mCircleColor = typeArray.getColor(R.styleable.TasksCompletedView_circleColor, 0xFFFFFFFF);
mRingColor = typeArray.getColor(R.styleable.TasksCompletedView_ringColor, 0xFFFFFFFF);
mRingRadius = mRadius + mStrokeWidth / 2;
}
private void initVariable() {
//画圆画笔设置
mCirclePaint = new Paint();
mCirclePaint.setAntiAlias(true);//防锯齿
mCirclePaint.setColor(mCircleColor);
mCirclePaint.setStyle(Paint.Style.FILL);
//“使用”字画笔设置
mUsePaint = new Paint();
mUsePaint.setAntiAlias(true);
mUsePaint.setStyle(Paint.Style.FILL);
mUsePaint.setColor(getResources().getColor(R.color.ticket_color));
mUsePaint.setTextSize(ScreenUtil.sp2px(mContext, 10));
//圆环画笔设置
mRingDefaultPaint = new Paint();
mRingDefaultPaint.setAntiAlias(true);
mRingDefaultPaint.setColor(getResources().getColor(R.color.default_ring_color));
mRingDefaultPaint.setStyle(Paint.Style.STROKE);
mRingDefaultPaint.setStrokeWidth(mStrokeWidth);
//已使用多少圆环画笔设置
mRingPaint = new Paint();
mRingPaint.setAntiAlias(true);
mRingPaint.setColor(mRingColor);
mRingPaint.setStyle(Paint.Style.STROKE);
mRingPaint.setStrokeWidth(mStrokeWidth);
mTextPaint = new Paint();
mTextPaint.setAntiAlias(true);
mTextPaint.setStyle(Paint.Style.FILL);
mTextPaint.setColor(Color.BLACK);
mTextPaint.setTextSize(ScreenUtil.sp2px(mContext, 22));
mLinePaint = new Paint();
mLinePaint.setColor(Color.WHITE);
//获取字体高度
FontMetrics fm = mTextPaint.getFontMetrics();
mTxtHeight = (int) Math.ceil(fm.descent - fm.ascent);
}
@Override
protected void onDraw(Canvas canvas) {
mXCenter = getWidth() / 2;
mYCenter = getHeight() / 2;
//画圆
canvas.drawCircle(mXCenter, mYCenter, mRadius, mCirclePaint);
RectF oval = new RectF();
oval.left = (mXCenter - mRingRadius);
oval.top = (mYCenter - mRingRadius);
oval.right = mRingRadius * 2 + (mXCenter - mRingRadius);
oval.bottom = mRingRadius * 2 + (mYCenter - mRingRadius);
//画整圆弧
canvas.drawArc(oval, -90, 360, false, mRingDefaultPaint);
//已使用多少圆弧
canvas.drawArc(oval, -90, ((float) mProgress / mTotalProgress) * 360, false, mRingPaint);
//文字绘制
String txt = mProgress + "%";
//文字的长度
mTxtWidth = mTextPaint.measureText(txt, 0, txt.length());
canvas.drawText(txt, mXCenter - mTxtWidth / 2, mYCenter + mTxtHeight / 9, mTextPaint);
Rect _pb = new Rect();
String sup = "已用";
mUsePaint.getTextBounds(sup, 0, sup.length(), _pb);
int perX = mXCenter - _pb.width() / 2;
canvas.drawText(sup, perX, mYCenter / 2, mUsePaint);
if (!TextUtils.isEmpty(usedFlow)) {
mUsePaint.getTextBounds(usedFlow, 0, usedFlow.length(), _pb);
perX = mXCenter - _pb.width() / 2;
canvas.drawText(usedFlow, perX, (float) (mYCenter + mYCenter / 1.7), mUsePaint);
}
//画横线图片
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.mipmap.circle_bottom_bg);
perX = mXCenter - bitmap.getWidth() / 2;
canvas.drawBitmap(bitmap, perX, (float) (mYCenter + mYCenter / 5), mLinePaint);
}
/**
* 设置当前进度
* @param progress
*/
public void setProgress(int progress) {
mProgress = progress;
postInvalidate();
}
/**
* 实际展示总进度
* @param progress
*/
public void setmShowProgress(int progress) {
mShowProgress = progress;
new Thread(new CircleThread()).start();
}
public void setUsedFlow(String usedFlow) {
this.usedFlow = usedFlow;
}
private class CircleThread implements Runnable{
int m=0;
int i=0;
@Override
public void run() {
// TODO Auto-generated method stub
while(!Thread.currentThread().isInterrupted()){
try {
Thread.sleep(50);
m++;
Message msg = new Message();
msg.what = 1;
if(i < mShowProgress){
i += m;
}else{
i = mShowProgress;
return;
}
msg.obj = i;
circleHandler.sendMessage(msg);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
}
2.FlowActivity.java
package com.czhappy.effectdemo.activity;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import com.czhappy.effectdemo.R;
import com.czhappy.effectdemo.view.MyProgressView;
/**
* Description:
* User: chenzheng
* Date: 2017/1/21 0021
* Time: 17:17
*/
public class FlowActivity extends AppCompatActivity {
private MyProgressView mTasksView;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_flow);
initView();
}
private void initView() {
mTasksView = (MyProgressView) findViewById(R.id.flow_prgress_view);
}
public void beginAnim(View view){
mTasksView.setUsedFlow("200.0M");
mTasksView.setmShowProgress(60);
}
}
3.activity_flow.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tc="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="10dp" android:background="#fff" android:gravity="center_horizontal" android:orientation="vertical"> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:onClick="beginAnim" android:text="开始动画"/> <com.czhappy.effectdemo.view.MyProgressView android:id="@+id/flow_prgress_view" android:layout_width="100dp" android:layout_height="100dp" tc:circleColor="@color/circle_color" tc:radius="44dp" tc:ringColor="@color/ring_color" tc:strokeWidth="6dp" android:layout_marginTop="10dp"/> </LinearLayout>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Android
# view
# 圆环占比
# Android实现长按圆环动画View效果的思路代码
# Android自定义View实现圆环进度条
# Android自定义View实现圆环带数字百分比进度条
# Android自定义view实现圆环效果实例代码
# android自定义View实现圆环颜色选择器
# Android自定义View实现圆环交替效果
# Android中自定义View实现圆环等待及相关的音量调节效果
# Android自定义View之酷炫数字圆环
# Android开发笔记之:在ImageView上绘制圆环的实现方法
# Android自定义view实现半圆环效果
# 自定义
# 已用
# 大家分享
# 具体内容
# 大家多多
# 白线
# context
# attrs
# setProgress
# temp
# Integer
# obj
# initAttrs
# styleable
# TasksCompletedView
# getDimension
# obtainStyledAttributes
# initVariable
# typeArray
# getTheme
相关文章:
高性价比服务器租赁——企业级配置与24小时运维服务
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
重庆市网站制作公司,重庆招聘网站哪个好?
免费网站制作appp,免费制作app哪个平台好?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
如何撰写建站申请书?关键要点有哪些?
建站主机与虚拟主机有何区别?如何选择最优方案?
如何正确下载安装西数主机建站助手?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
如何通过二级域名建站提升品牌影响力?
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
网站制作壁纸教程视频,电脑壁纸网站?
,巨量百应是干嘛的?
建站之星安装步骤有哪些常见问题?
制作电商网页,电商供应链怎么做?
PHP正则匹配日期和时间(时间戳转换)的实例代码
武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?
如何高效完成自助建站业务培训?
如何自定义建站之星网站的导航菜单样式?
浅谈Javascript中的Label语句
如何在宝塔面板中修改默认建站目录?
建站之星伪静态规则如何设置?
如何安全更换建站之星模板并保留数据?
郑州企业网站制作公司,郑州招聘网站有哪些?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
长沙做网站要多少钱,长沙国安网络怎么样?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
家庭建站与云服务器建站,如何选择更优?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
建站之星如何通过成品分离优化网站效率?
常州自助建站费用包含哪些项目?
成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?
定制建站如何定义?其核心优势是什么?
大型企业网站制作流程,做网站需要注册公司吗?
动图在线制作网站有哪些,滑动动图图集怎么做?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
建站之星图片链接生成指南:自助建站与智能设计教程
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
建站之星伪静态规则如何正确配置?
成都响应式网站开发,dw怎么把手机适应页面变成网页?
如何解决VPS建站LNMP环境配置常见问题?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
,交易猫的商品怎么发布到网站上去?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
如何做网站制作流程,*游戏网站怎么搭建?
建站主机选购指南与交易推荐:核心配置解析
如何在Golang中处理模块冲突_解决依赖版本不兼容问题
宝塔建站助手安装配置与建站模板使用全流程解析
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
*请认真填写需求信息,我们会在24小时内与您取得联系。