自定义ProgressBar

<?xml version="1.0" encoding="UTF-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromDegrees="0"
    android:pivotX="50%"
    android:pivotY="50%"
    android:toDegrees="360">
    <shape android:innerRadiusRatio="3"
        android:shape="ring"
        android:thicknessRatio="30"
        android:useLevel="false">
        <gradient
            android:centerColor="#FFFFFF"
            android:centerY="0.01"
            android:endColor="#FFFFFF"
            android:startColor="#000000"
            android:type="sweep"
            android:useLevel="false"/>
    </shape>
</rotate>

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout  
  xmlns:android="http://schemas.android.com/apk/res/android"  
  android:layout_width="wrap_content"  
  android:layout_height="wrap_content"
  android:background="@drawable/base_wait_dialog2"
  android:gravity="center"
  android:padding="8dp"
  android:orientation="vertical">  
  
    <ProgressBar android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:indeterminateDrawable="@drawable/wait_progressbar"
        android:layout_marginTop="6dp"/>
    
    <TextView 
        android:id="@+id/loadingTextView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="#FFFFFF"
        android:textSize="16dp"
        android:layout_marginTop="10dp"
        android:layout_marginLeft="6dp"
        android:layout_marginRight="6dp"
        android:layout_marginBottom="6dp"
        android:gravity="center"
        android:text="正在加载,请稍等.."/>

</LinearLayout>  


这是ProgressBar控件,直接用android:indeterminateDrawable去引用上面的文件就可以了.
<ProgressBar
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:indeterminateDrawable="@drawable/wel_act_loading_pro"
        />


gradient里的属性没什么好介绍的, 这里主要是shape.
下列属性只在android:shape=”ring”时使用:
android:innerRadiux
尺寸值,它用尺寸值或尺寸资源指定圆环内部的半径(指中间的圆孔的半径)。

android:innerRadiusRatio
浮点值,它用圆环宽度的比率来表示内部圆环的半径。例如,如果android:innerRadiusRatio=”5”,那么内部半径就等于圆环的宽度除以5。这个值会被android:innerRadius的值覆盖。默认是9。

android:thickness
尺寸值,它用一个尺寸值或尺寸资源来定义圆环的厚度。

android:thicknessRatio
浮点值。它用圆环宽度的比率来表示圆环的厚度。例如,如果android:thicknessRatio=”2”,那么厚度就等于圆环的宽度除以2。这个值会被android:innerRadius覆盖。默认值是3。也就是说这个值设置的越大圆环就越细了。

android:useLevel
布尔值,如果这个形状要用于LevelListDrawable对象,那么就设置为true。通常应该设置为false或者让形状不可见。








  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android ,可以通过继承 ProgressBar 类来实现自定义 ProgressBar。下面是一个简单的示例: 1. 创建一个自定义 ProgressBar 类 CustomProgressBar,继承自 ProgressBar。 ``` public class CustomProgressBar extends ProgressBar { public CustomProgressBar(Context context) { super(context); } public CustomProgressBar(Context context, AttributeSet attrs) { super(context, attrs); } public CustomProgressBar(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } } ``` 2. 在 CustomProgressBar 类重写 onDraw() 方法,实现自定义绘制。 ``` @Override protected synchronized void onDraw(Canvas canvas) { super.onDraw(canvas); // 绘制背景 Paint paint = new Paint(); paint.setColor(Color.GRAY); paint.setStyle(Paint.Style.FILL); RectF rect = new RectF(0, 0, getWidth(), getHeight()); canvas.drawRoundRect(rect, 10, 10, paint); // 绘制进度 paint.setColor(Color.BLUE); float progress = getProgress() * 1.0f / getMax(); float progressWidth = getWidth() * progress; RectF progressRect = new RectF(0, 0, progressWidth, getHeight()); canvas.drawRoundRect(progressRect, 10, 10, paint); } ``` 在这个例子,我们绘制了一个灰色的背景和蓝色的进度条。可以根据自己的需求进行自定义绘制。 3. 在布局文件使用 CustomProgressBar。 ``` <com.example.myapplication.CustomProgressBar android:id="@+id/custom_progress_bar" android:layout_width="match_parent" android:layout_height="30dp" android:max="100" android:progress="50" /> ``` 在这个例子,我们使用了自定义的 CustomProgressBar,并设置了最大值和当前进度。 以上就是自定义 ProgressBar 的简单示例。可以根据自己的需求进行进一步的自定义
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值