Android自定义横向的ProgressBar

其实很简单,上代码!

在res下创建drawable文件夹,新建文件drawable/progressbar_color.xml

<? xml  version = "1.0"  encoding = "utf-8" ?>
< layer-list  xmlns:android = "http://schemas.android.com/apk/res/android"  >
 
     <!-- 背景  gradient是渐变,corners定义的是圆角 -->
     < item  android:id = "@android:id/background" >
         < shape >
             < corners  android:radius = "10dp"  />
 
             < solid  android:color = "#ffffff"  />
         </ shape >
     </ item >
     <!-- 第二条进度条颜色 -->
     < item  android:id = "@android:id/secondaryProgress" >
         < clip >
             < shape >
                 < corners  android:radius = "10dip"  />
 
                 < gradient
                     android:angle = "90.0"
                     android:centerColor = "#ac6079"
                     android:centerY = "0.45"
                     android:endColor = "#6c213a"
                     android:startColor = "#e71a5e"  />
             </ shape >
         </ clip >
     </ item >
     <!-- 进度条 -->
     < item  android:id = "@android:id/progress" >
         < clip >
             < shape >
                 < corners  android:radius = "10dip"  />
 
                 < solid  android:color = "#FF8080"  />
             </ shape >
         </ clip >
     </ item >
 
</ layer-list >
然后在布局中引用就可以了。

< ProgressBar 
         android:id = "@+id/my_progress"
         android:layout_width = "match_parent"
         android:layout_height = "12dp"
         android:max = "100"
         android:progress = "40"
         android:secondaryProgress = "70"
         style = "?android:attr/progressBarStyleHorizontal"
         android:progressDrawable = "@drawable/progressbar_color" />


还有一种是进度条样式加载图片:

  1. <?xml version="1.0" encoding="UTF-8"?>                
  2. <layer-list xmlns:android="http://schemas.android.com/apk/res/android" >                 
  3. <!--  设置背景色图像资源  -->                   
  4. <item                  
  5.     android:id="@android:id/background"                
  6.     android:drawable="@drawable/prgs_bg" />     
  7.                                        
  8. <!--  设置进度条颜色图像资源  -->                   
  9. <item                  
  10.     android:id="@android:id/progress"                
  11.     android:drawable="@drawable/prgs_progress" />  
  12.                 
  13. </layer-list>



Android自定义ProgressBar可以通过继承View或者ViewGroup来实现。下面是一种常见的自定义ProgressBar的实现方式: 1. 创建一个新的Java类,继承自View或者ViewGroup,例如CustomProgressBar。 2. 在CustomProgressBar类中,重写onDraw方法来绘制ProgressBar的外观。可以使用Canvas和Paint来绘制矩形、圆角矩形、圆形等形状,并使用不同的颜色表示进度。 ```java @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); // 绘制背景 canvas.drawRect(0, 0, getWidth(), getHeight(), backgroundPaint); // 绘制进度 float progressWidth = getWidth() * progress / maxProgress; canvas.drawRect(0, 0, progressWidth, getHeight(), progressPaint); } ``` 3. 在CustomProgressBar类中,添加一些自定义属性,例如进度条的颜色、背景色等。可以使用TypedArray来获取这些属性的值。 ```java TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.CustomProgressBar); int progressColor = typedArray.getColor(R.styleable.CustomProgressBar_progressColor, defaultProgressColor); int backgroundColor = typedArray.getColor(R.styleable.CustomProgressBar_backgroundColor, defaultBackgroundColor); typedArray.recycle(); ``` 4. 在CustomProgressBar类中,添加一些公共方法来设置和获取进度值。 ```java public void setProgress(int progress) { this.progress = progress; invalidate(); // 通知View重绘 } public int getProgress() { return progress; } ``` 5. 在布局文件中使用自定义ProgressBar。 ```xml <com.example.CustomProgressBar android:layout_width="match_parent" android:layout_height="wrap_content" app:progressColor="#FF0000" app:backgroundColor="#CCCCCC" /> ``` 以上是一种简单的自定义ProgressBar的实现方式,你可以根据自己的需求进行扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值