iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android自定义View基础开发之图片加载进度条
  • 957
分享到

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

view进度条图片Android 2022-06-06 07:06:57 957人浏览 泡泡鱼
摘要

学会了Paint,canvas的基本用法之后,我们就可以动手开始实践了,先写个简单的图片加载进度条看看。 按照惯例,先看效果图,再决定要不要往下看: 既然看到这里了,应该是

学会了Paint,canvas的基本用法之后,我们就可以动手开始实践了,先写个简单的图片加载进度条看看。
按照惯例,先看效果图,再决定要不要往下看:

既然看到这里了,应该是想了解这个图片加载进度条了,我们先看具体用法,再看自定义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);
}

源码下载:http://xiazai.jb51.net/201608/yuanma/circleprogress(jb51.net).rar

您可能感兴趣的文章:Android自定义View实现带数字的进度条实例代码Android 自定义view和属性动画实现充电进度条效果Android自定义view实现水波纹进度球效果Android自定义View仿华为圆形加载进度条Android自定义View之圆形进度条式按钮Android自定义View弧线进度控件Android自定义View实现渐变色进度条Android自定义View实现环形进度条的思路与实例android自定义view制作圆形进度条效果Android自定义View实现简单炫酷的球体进度球实例代码


--结束END--

本文标题: Android自定义View基础开发之图片加载进度条

本文链接: https://www.lsjlt.com/news/24155.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android自定义View实现圆形加载进度条
    本文实例为大家分享了Android自定义View实现圆形加载进度条的具体代码,供大家参考,具体内容如下 效果图 话不多说,咱们直接看代码 首先第一种: 1、创建自定义View类 p...
    99+
    2024-04-02
  • 自定义视图view之环形进度条
    目录 一、普通效果。二、单环在圈外画弧度三、双环效果四、Xml布局五、MainActivity中代码的引用六、自定义属性  一、普通效果。 本章博客有4种不同的效...
    99+
    2023-05-14
    自定义视图 自定义view view环形进度条
  • Android开发基础使用ProgressBar加载进度条示例
    目录前言使用方法总结前言 之前我们用过WebView类,打开网页时就会出现加载网页的情况,为了让我们直观的感受到网页加载到什么程度而不是白白干等着空白页,于是加载进度条就是一个很好...
    99+
    2023-02-05
    Android ProgressBar加载进度条 Android ProgressBar
  • Android自定义View实现圆形进度条
    本文实例为大家分享了Android自定义View实现圆形进度条的具体代码,供大家参考,具体内容如下 原理非常简单,在自定义View的基础上使用Canvas的drawCircle画两个...
    99+
    2024-04-02
  • Android中怎么通过自定义view实现进度条加载效果
    Android中怎么通过自定义view实现进度条加载效果,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。分析图:代码如下:package com.example.d...
    99+
    2023-05-30
    android view
  • Android自定义View实现圆形加载进度条效果的方法
    这篇文章将为大家详细讲解有关Android自定义View实现圆形加载进度条效果的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。View仿华为圆形加载进度条效果图实现思路可以看出该View可分为三个部分...
    99+
    2023-05-30
    android view 进度条
  • android开发中使用view实现自定义一个进度条功能
    今天就跟大家聊聊有关android开发中使用view实现自定义一个进度条功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、自定义属性:<&#63;xml versi...
    99+
    2023-05-31
    android view roi
  • Android怎么自定义View实现圆形进度条
    本文小编为大家详细介绍“Android怎么自定义View实现圆形进度条”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android怎么自定义View实现圆形进度条”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。原...
    99+
    2023-07-02
  • 在Android开发中通过自定义View实现一个圆形进度条
    这期内容当中小编将会给大家带来有关在Android开发中通过自定义View实现一个圆形进度条,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。首先来看看自己定义的Viewpackage cn.easymobi...
    99+
    2023-05-31
    android view roi
  • Android自定义view实现圆环进度条效果
    本文实例为大家分享了Android自定义view实现圆环进度条效果的具体代码,供大家参考,具体内容如下 一、实现效果图 二、核心代码 自定义view的属性 <xml vers...
    99+
    2024-04-02
  • Android自定义view实现圆形进度条效果
    Android中实现进度条有很多种方式,自定义进度条一般是继承progressBar或继承view来实现,本篇中讲解的是第二种方式。 先上效果图: 实现圆形进度条总体来说并不难,还...
    99+
    2024-04-02
  • Java基础之自定义类加载器
    目录一、类加载器关系二、基于本地class文件的自定义类加载器三、遇到的问题四、基于网络(url)class文件的自定义类加载器一、类加载器关系 自定义类加载器 创建一个类继承C...
    99+
    2024-04-02
  • Android开发之自定义加载动画详解
    目录一、demo简介二、分析贪吃动画的尺寸比例三、画圆四、实现张嘴闭嘴动画五、小球移动动画一、demo简介 1.效果展示如下图,我截了三个瞬间,但其实这是一个连续的动画,就是这个大圆...
    99+
    2024-04-02
  • Android自定义View圆形进度条控件的方法
    这篇文章主要讲解了Android自定义View圆形进度条控件的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。继续练习自定义View,这次带来的圆形进度条控件与之前的圆形百分比控件大同小异,这次涉及到了渐变渲...
    99+
    2023-05-31
    android roi %d
  • 自定义视图View绘图基础之Path的使用
    目录使用Path绘制线一、我们这里绘制了7条线来分别介绍上面的几种子类都有什么用二、不难看出其中每条线的属性和样式不一样,我在上面有 了很详细的讲解。三、xxxTo()方法绘制(本章...
    99+
    2023-05-14
    自定义视图 自定义View 自定义视图 Path使用
  • 自定义视图view怎么实现环形进度条
    这篇文章主要介绍“自定义视图view怎么实现环形进度条”,在日常操作中,相信很多人在自定义视图view怎么实现环形进度条问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”自定义视图view怎么实现环形进度条”的疑...
    99+
    2023-07-05
  • 详解Android如何自定义view实现圆形进度条
    Android中实现进度条有很多种方式,自定义进度条一般是继承progressBar或继承view来实现,本篇中讲解的是第二种方式。 先上效果图: 实现圆形进度条总体来说并不难,还...
    99+
    2024-04-02
  • Android中怎么自定义view实现圆环进度条效果
    这篇文章主要讲解了“Android中怎么自定义view实现圆环进度条效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android中怎么自定义view实现圆环进度条效果”吧!核心代码自定义...
    99+
    2023-06-29
  • Android利用Paint自定义View实现进度条控件方法示例
    前言View的三大流程:测量,布局,绘制,自定义View学的是啥?无非就两种:绘制文字和绘制图像。我们在上一篇文章《Android绘图之Paint的使用》中学习了Paint的基本用法,但是具体的应用我们还没有实践过。从标题中可知,本文是带领...
    99+
    2023-05-30
    paint 自定义view 进度条控件
  • Android怎么自定义View实现横向的双水波纹进度条
    这篇文章将为大家详细讲解有关Android怎么自定义View实现横向的双水波纹进度条,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。思路分析整体效果可分为三个,绘制圆角背景和圆角矩形,绘制第一条和第二条水波...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作