博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Wheel ProgressBar 实现之三——模拟进度过程
阅读量:6463 次
发布时间:2019-06-23

本文共 2360 字,大约阅读时间需要 7 分钟。

1. 效果展示:
知道如何画圆弧,如何精确画出进度文本之后,我们将进入 Wheel ProgressBar 实现的最后一个过程:模拟其动态呈现过程。如下图所示,初始时显示进度为 0 (上图),点击进度条后,将自动减速加载(下图),每次点击之后都将重新从 0 加载到 100。 
2. 实现原理:
通过以下几个步骤来实现进度的动态加载:
1、画一个灰色圆环;
2、通过当前的进度(百分数)计算得到当前应该画的弧度(蓝色);
3、画出当前进度弧;
4、画出进度文本。
3. 具体实现:
如何画弧和进度文本不再赘述:
1、画一个灰色圆环,可以通过两种方法实现:
第一种是直接画出一个圆环,采用 Canvas.drawCircle() 接口,设置圆心、半径和画笔:
canvas.drawCircle(this.getWidth() / 2,                this.getHeight() / 2,                (mRectBounds.width() - mArcWidth)/2,                mRimPaint);
第二种是画一个 360 度的圆弧:
canvas.drawArc(mArcBounds, 360, 360, false, mRimPaint);
以上两种方法都在 View 重写的 onAttachedToWindow() 方法中实现。
2、通过当前的进度(百分数)计算得到当前应该画的弧度(蓝色):
mDegree = Math.round( ((float)mProgress / 100) * 360 );
mProgress 为当前的进度,mDegree 为计算得到的当前弧度
3、画出当前弧度:
通过在主线程中调用 View.invalidate() 方法触发 View 的重绘操作,具体是调用 onDraw(), 所以当前弧度在 onDraw() 中绘制:
canvas.drawArc(mArcBounds, -90, mDegree, false, mArcPaint);
mDegree 即为上一步计算得到的弧度。
4、Activity 中的实现:
这里我们开启了一个工作线程,减速实现进度的刷新,并实现进度点击后的重新加载。注意 mProgress.setProgress() 方法,在这个方法中我们实现的就是通过进度计算弧度的操作,并通过 invalidate 重绘。
protected void onCreate(Bundle savedInstanceState) {          super.onCreate(savedInstanceState);          setContentView(R.layout.activity_main);                   mProgress = (CustomArc) findViewById(R.id.progress);                   final Runnable r = new Runnable() {               public void run() {                    running = true;                    while(progress<101) {                         mProgress.setProgress(progress);                         progress++;                         try {                              Thread.sleep(10 + progress);                         } catch (InterruptedException e) {                              // TODO Auto-generated catch block                              e.printStackTrace();                         }                    }                    running = false;               }        };               mProgress.setOnClickListener(new View.OnClickListener() {                             @Override               public void onClick(View v) {                    // TODO Auto-generated method stub                    if(!running) {                         progress = 0;                         mProgress.resetCount();                         mThread = new Thread(r);                         mThread.start();                    }               }          });     }
5、完整的工程请下载:

 

你可能感兴趣的文章
阿里宣布开源Weex ,亿级应用匠心打造跨平台移动开发工具
查看>>
Android项目——实现时间线程源码
查看>>
招商银行信用卡重要通知:消费提醒服务调整,300元以下消费不再逐笔发送短信...
查看>>
python全栈_002_Python3基础语法
查看>>
C#_delegate - 调用列表
查看>>
交换机二层接口access、trunk、hybird三种模式对VLAN的处理过程
查看>>
jQuery.extend 函数详解
查看>>
[转]Windows的批处理脚本
查看>>
lnmp高人笔记
查看>>
[转载] OpenCV2.4.3 CheatSheet学习(三)
查看>>
C#中跨窗体操作(2)--消息机制
查看>>
子程序框架
查看>>
多维数组元素的地址
查看>>
数据库运维体系_SZMSD
查看>>
aspose 模板输出
查看>>
福大软工1816 · 第三次作业 - 结对项目1
查看>>
selenium多个窗口切换
查看>>
《单页面应用》所获知识点
查看>>
静态库 调试版本 和发布版本
查看>>
DB2 错误码解析
查看>>