全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android自定义view绘制圆环占比动画

本文实例为大家分享了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 


相关文章: 公司网站设计制作厂家,怎么创建自己的一个网站?  济南专业网站制作公司,济南信息工程学校怎么样?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  香港网站服务器数量如何影响SEO优化效果?  建站之星在线版空间:自助建站+智能模板一键生成方案  如何选择高效便捷的WAP商城建站系统?  建站之星上传入口如何快速找到?  制作表格网站有哪些,线上表格怎么弄?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  网站制作的步骤包括,正确网址格式怎么写?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  专业公司网站制作公司,用什么语言做企业网站比较好?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  建站主机如何选?高性价比方案全解析  制作网站公司那家好,网络公司是做什么的?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  南平网站制作公司,2025年南平市事业单位报名时间?  建站之星免费版是否永久可用?  网站制作网站,深圳做网站哪家比较好?  西安专业网站制作公司有哪些,陕西省建行官方网站?  建站主机选择指南:服务器配置与SEO优化实战技巧  如何快速搭建高效简练网站?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  家庭建站与云服务器建站,如何选择更优?  免费ppt制作网站,有没有值得推荐的免费PPT网站?  黑客入侵网站服务器的常见手法有哪些?  网页设计与网站制作内容,怎样注册网站?  建站之星3.0如何解决常见操作问题?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  建站主机无法访问?如何排查域名与服务器问题  ,柠檬视频怎样兑换vip?  建站之星后台密码遗忘如何找回?  移民网站制作流程,怎么看加拿大移民官网?  存储型VPS适合搭建中小型网站吗?  如何制作网站标识牌,动态网站如何制作(教程)?  如何用y主机助手快速搭建网站?  如何在景安云服务器上绑定域名并配置虚拟主机?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  如何选择适合PHP云建站的开源框架?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  网站企业制作流程,用什么语言做企业网站比较好?  高防服务器租用首荐平台,企业级优惠套餐快速部署  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  制作网站的模板软件,网站怎么建设?  如何通过FTP空间快速搭建安全高效网站?  临沂网站制作企业,临沂第三中学官方网站?  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  如何在建站之星网店版论坛获取技术支持? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。