Android自定义View基础开发之图片加载进度条

作者:happy_fsyy 时间:2022-05-01 05:52:14 

学会了Paint,Canvas的基本用法之后,我们就可以动手开始实践了,先写个简单的图片加载进度条看看。

按照惯例,先看效果图,再决定要不要往下看:

Android自定义View基础开发之图片加载进度条

既然看到这里了,应该是想了解这个图片加载进度条了,我们先看具体用法,再看自定义View的实现:


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:custom="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/img"
android:layout_width="200dp"
android:layout_height="200dp"
android:scaleType="centerCrop"
android:layout_centerInParent="true"/>
<com.example.circleprogresstest.CircleProgressView
android:id="@+id/progressView"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_centerInParent="true"
custom:isShowProgress="true" />
</RelativeLayout>

ImageLoader.getInstance().displayImage(url, imageView, options,
new SimpleImageLoadingListener() ,
new ImageLoadingProgressListener() {
@Override
public void onProgressUpdate(String imageUri, View view, int current, int total) {
if(current==total){
progressView.setVisibility(View.GONE);
}else{
progressView.setSweepAngle((int)(360*current*1.0f/total));
progressView.postInvalidate();
}
}
}
);

可以看出,以上的用法,非常简单,在xml中添加我们自定义的View,和添加textview或者button完全相同,只是多了我们自己的自定义属性而已,可以设置圆的颜色,以及文字颜色,大小等等。之后,在MainActivity中使用的方法也是同样简单,只要在图片的进度更新的时候,同时更新我们进度条的进度就行了。

下面我们具体说下我们实现自定义进度条的过程,我们只需要重写onDraw()方法就够了,很明显,我们的进度条包括三部分,内圈圆,外圈圆弧,中间的文字,具体看代码:


protected void onDraw(Canvas canvas) {
mWidth=getMeasuredWidth();
mHeight=getMeasuredHeight();
radius=(float)(Math.min(mWidth,mHeight)*1.0/2)-strokeWidth/2;
//绘制内圈圆
mPaint.setColor(initColor);
mPaint.setStyle(Paint.Style.STROKE);
mPaint.setStrokeWidth(strokeWidth);
canvas.drawCircle(mWidth/2,mHeight/2,radius,mPaint);
//绘制覆盖的圆弧
mPaint.setColor(coverColor);
RectF rectF=new RectF(mWidth/2-radius,mHeight/2-radius,mWidth/2+radius,mHeight/2+radius);
canvas.drawArc(rectF,-90,sweepAngle,false,mPaint);
//绘制中间的文本
if(isShowProgress){
progressText=String.format(getResources().getString(R.string.progress_text),(int)(sweepAngle*100.0/360));
mPaint.setTextSize(textSize);
mPaint.setColor(textColor);
if(mBound==null){
mBound=new Rect();
}
mPaint.getTextBounds(progressText,0,progressText.length(),mBound);
mPaint.setStyle(Paint.Style.FILL);
canvas.drawText(progressText,mWidth/2-mBound.width()/2,mHeight/2+mBound.height()/2,mPaint);
}
}

当然,为了让我们可以自定义进度条的大小颜色,我们还采用了自定义属性,并且在构造器中,也需要加载xml中的各项属性:


<resources>
<declare-styleable name="CircleProgressView">
<attr name="initColor" format="color"/>
<attr name="coverColor" format="color"/>
<attr name="strokeWidth" format="dimension"/>
<attr name="progressTextSize" format="dimension"/>
<attr name="progressTextColor" format="color"/>
<attr name="isShowProgress" format="boolean"/>
</declare-styleable>
</resources>

private void initValues(Context context, AttributeSet attrs, int defStyleAttr){
TypedArray typedArray=context.getTheme().obtainStyledAttributes(attrs,R.styleable.CircleProgressView,defStyleAttr,0);
int num=typedArray.getIndexCount();
for(int i=0;i<num;i++){
int attr=typedArray.getIndex(i);
switch (attr){
case R.styleable.CircleProgressView_initColor:
initColor=typedArray.getColor(attr,Color.GRAY);
break;
case R.styleable.CircleProgressView_coverColor:
coverColor=typedArray.getColor(attr,Color.BLACK);
break;
case R.styleable.CircleProgressView_strokeWidth:
strokeWidth=typedArray.getDimensionPixelOffset(attr,5);
break;
case R.styleable.CircleProgressView_progressTextSize:
textSize=typedArray.getDimensionPixelSize(attr,30);
break;
case R.styleable.CircleProgressView_progressTextColor:
textColor=typedArray.getColor(attr,Color.BLACK);
break;
case R.styleable.CircleProgressView_isShowProgress:
isShowProgress=typedArray.getBoolean(attr,false);
break;
default:
break;
}
}
typedArray.recycle();

mPaint=new Paint();
mPaint.setAntiAlias(true);
}

源码下载

标签:android,图片加载,进度条
0
投稿

猜你喜欢

  • C#实现DataTable映射成Model的方法(附源码)

    2023-03-12 06:10:56
  • Android实现简单的文件下载与上传

    2022-02-25 00:00:14
  • Kotlin超简单实现StepView的方法

    2022-01-21 09:28:27
  • java上乘武功入门--反射

    2021-06-08 21:32:27
  • listview控件实现点击列表头进行listview排序示例分享

    2023-06-06 18:00:39
  • java基础知识之FileInputStream流的使用

    2021-07-05 00:30:24
  • 2021最新Android笔试题总结美团Android岗职能要求

    2023-11-29 15:24:52
  • Android屏幕适配工具类 Android自动生成不同分辨率的值

    2022-03-07 13:45:39
  • 常用json与javabean互转的方法实现

    2023-01-07 14:24:19
  • Unity3D使用UGUI开发原生虚拟摇杆

    2021-10-04 17:28:26
  • Spring Cloud微服务架构的构建:分布式配置中心(加密解密功能)

    2021-10-24 05:49:59
  • IDEA使用GsonFormat完成JSON和JavaBean之间的转换

    2021-06-10 11:30:30
  • Android 数据库打包随APK发布的实例代码

    2022-05-12 11:31:15
  • Spring与Struts整合之让Spring管理控制器操作示例

    2022-08-22 12:53:46
  • java判断list不为空的实现,和限制条数不要在一起写

    2022-01-24 13:14:38
  • Android12 蓝牙适配的实现步骤

    2021-08-25 08:36:34
  • java实现sftp客户端上传文件以及文件夹的功能代码

    2023-02-14 22:07:28
  • Java File类的概述及常用方法使用详解

    2023-11-28 13:06:28
  • SpringBoot的@Value给静态变量注入application.properties属性值

    2023-09-20 11:54:07
  • Java组件commons fileupload实现文件上传功能

    2022-05-03 15:03:07
  • asp之家 软件编程 m.aspxhome.com