自定义Android下载进度条:实现百分比效果
125 浏览量
更新于2024-08-28
收藏 72KB PDF 举报
"Android实现一个百分比下载进度条的自定义View,通过获取自定义属性、绘制底色和进度条以及显示百分比文字来达到效果。"
在Android开发中,创建一个具有百分比显示的下载进度条可以极大地提升用户体验。为了实现这样一个自定义的进度条,开发者通常会通过自定义View来完成。在这个案例中,我们将探讨如何实现这样的功能。
首先,我们需要在`attrs.xml`文件中定义自定义属性。在这个例子中,我们只有一个属性`dptextsize`,用于设置百分比文字的大小,其格式为尺寸(dimension)。以下是`attrs.xml`文件的内容:
```xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
<declare-styleable name="downloadProgressBar">
<attr name="dptextsize" format="dimension"/>
</declare-styleable>
</resources>
```
接下来,我们创建一个名为`DownLoadProgressbar`的自定义View类。这个类需要继承自`View`,并实现绘制进度条的功能。在类中,我们需要获取自定义属性的值,这可以通过`TypedArray`来完成。此外,还需要重写`onDraw()`方法来绘制进度条的背景(灰色线)、当前进度(橘黄色线)以及百分比文字。以下是一个简化的`DownLoadProgressbar`类的示例:
```java
package com.ywl5320.downloadprogressdemo.downloadview;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.View;
import android.view.ViewTreeObserver.OnGlobalLayoutListener;
import com.ywl5320.downloadprogressdemo.R;
public class DownLoadProgressbar extends View {
private int dpTextSize; // 自定义属性,百分比文字大小
public DownLoadProgressbar(Context context) {
this(context, null);
}
public DownLoadProgressbar(Context context, AttributeSet attrs) {
this(context, attrs, 0);
}
public DownLoadProgressbar(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(attrs);
}
private void init(AttributeSet attrs) {
if (attrs != null) {
TypedArray array = getContext().obtainStyledAttributes(attrs, R.styleable.downloadProgressBar);
dpTextSize = array.getDimensionPixelSize(R.styleable.downloadProgressBar_dptextsize, 16); // 获取dptextsize属性的值
array.recycle();
}
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
// 绘制灰色底色线条
Paint backgroundPaint = new Paint();
backgroundPaint.setColor(getResources().getColor(android.R.color.darker_gray));
canvas.drawRect(0, 0, getWidth(), getHeight(), backgroundPaint);
// 计算并绘制进度条(橘黄色线条)
int progress = ...; // 从实际下载进度获取
Paint progressPaint = new Paint();
progressPaint.setColor(getResources().getColor(android.R.color.holo_orange_light));
float progressWidth = ...; // 根据进度计算宽度
canvas.drawRect(0, 0, progressWidth, getHeight(), progressPaint);
// 绘制百分比文字
String percentageText = String.format("%.0f%%", progress * 100f);
Paint textPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
textPaint.setTextSize(dpTextSize);
textPaint.setColor(getResources().getColor(android.R.color.black));
Rect bounds = new Rect();
textPaint.getTextBounds(percentageText, 0, percentageText.length(), bounds);
int x = (getWidth() - bounds.width()) / 2;
int y = (getHeight() + bounds.height()) / 2;
canvas.drawText(percentageText, x, y, textPaint);
}
}
```
在实际使用时,你需要在布局文件中引用这个自定义View,并设置`dptextsize`属性。例如:
```xml
<com.ywl5320.downloadprogressdemo.downloadview.DownLoadProgressbar
android:id="@+id/progress_bar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:dptextsize="14dp" />
```
最后,你可以在Activity或Fragment中获取这个自定义View,并根据下载进度更新`DownLoadProgressbar`的`progress`值,然后调用`invalidate()`方法触发重绘,以实时显示下载进度。
通过这种方式,你就能在Android应用中实现一个美观且实用的百分比下载进度条,提升用户对下载过程的感知和体验。
828 浏览量
1025 浏览量
2020-09-02 上传
677 浏览量
541 浏览量
413 浏览量
2460 浏览量
646 浏览量
weixin_38586186
- 粉丝: 9
- 资源: 943