Android圆形进度条颜色的设置

时间:2011年03月30日 10:28:25 来源: 中国移动开发者社区 作者:xyz_lmn

               xml布局文件需加入如下的进度条构件: 

Java代码:

 

 

  1. <ProgressBar 
     
  2. android:id="@+id/loadProgressBar" 
     
  3. android:indeterminateDrawable="@drawable/progressbar" 
     
  4. android:layout_width="wrap_content" 
     
  5. android:layout_height="wrap_content" />
复制代码


                 其中的indeterminteDrawable属性就是用来设置进度条颜色等属性的,其内容如下:

Java代码:
 

  1. <?xml version="1.0" encoding="utf-8"?> 
     

  2.  

  3.  
  4. <rotate xmlns:android="http://schemas.android.com/apk/res/android" 
     
  5. android:pivotX="50%" android:pivotY="50%" 
     
  6. android:fromDegrees="0" 
     
  7. android:toDegrees="360"> 
     

  8.  

  9.  
  10. <shape 
     
  11. android:shape="ring"
     
  12. android:innerRadiusRatio="3" 
     
  13. android:thicknessRatio="8" 
     
  14. android:useLevel="false"> 
     

  15.  

  16.  
  17. <gradient android:type="sweep" 
     
  18. android:useLevel="false" 
     
  19. android:startColor="#000000" 
     
  20. android:centerColor="#FFFFFF" 
     
  21. android:centerY="0.50" 
     
  22. android:endColor="#FFFF00" />
     

  23.  
  24. </shape>
     

  25.  
  26. </rotate>
Android 圆形进度条可以通过自定义 View 或者使用第三方库来实现。以下是一种简单的实现方式: 1. 创建一个自定义 View 类,继承自 View 或者 ProgressBar。 2. 在自定义 View 的构造方法中初始化画笔和属性。 3. 重写 onDraw 方法,在该方法中绘制圆形进度条。 4. 使用属性动画或者定时器来更新进度值,并调用 invalidate 方法触发重绘。 下面是一个简单的示例代码: ```java public class CircleProgressBar extends View { private Paint backgroundPaint; private Paint progressPaint; private RectF arcRect; private int progress; private int maxProgress; public CircleProgressBar(Context context) { super(context); init(); } public CircleProgressBar(Context context, AttributeSet attrs) { super(context, attrs); init(); } private void init() { backgroundPaint = new Paint(); backgroundPaint.setColor(Color.GRAY); backgroundPaint.setStyle(Paint.Style.STROKE); backgroundPaint.setStrokeWidth(10); progressPaint = new Paint(); progressPaint.setStyle(Paint.Style.STROKE); progressPaint.setStrokeWidth(10); progressPaint.setStrokeCap(Paint.Cap.ROUND); arcRect = new RectF(); progress = 0; maxProgress = 100; } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); int centerX = getWidth() / 2; int centerY = getHeight() / 2; int radius = Math.min(centerX, centerY) - 10; arcRect.set(centerX - radius, centerY - radius, centerX + radius, centerY + radius); // 绘制背景圆弧 canvas.drawArc(arcRect, 0, 360, false, backgroundPaint); // 绘制进度圆弧 float sweepAngle = 360 * ((float) progress / maxProgress); Shader shader = new SweepGradient(centerX, centerY, Color.RED, Color.BLUE); progressPaint.setShader(shader); canvas.drawArc(arcRect, -90, sweepAngle, false, progressPaint); } public void setProgress(int progress) { this.progress = progress; invalidate(); } public void setMaxProgress(int maxProgress) { this.maxProgress = maxProgress; } } ``` 使用时,可以在布局文件中添加该自定义 View,并通过调用 `setProgress` 方法来更新进度值。 相关问题: 1. 如何创建一个自定义 View? 2. 如何绘制圆形进度条? 3. 如何使用属性动画来更新进度值? 4. 如何使用定时器来更新进度值? 5. 如何使用第三方库来实现圆形进度条
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值