Android 自定义view实现进度条加载效果实例代码

发布时间 - 2026-01-11 03:00:05    点击率:

  这个其实很简单,思路是这样的,就是拿view的宽度,除以点的点的宽度+二个点 之间的间距,就可以算出大概能画出几个点出来,然后就通过canvas画出点,再然后就是每隔多少时间把上面移动的点不断的去改变它的坐标就可以,

效果如下:

分析图:

代码如下:

package com.example.dotloadview;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.os.Handler;
import android.util.AttributeSet;
import android.view.View;
/**
 * Created by zhouguizhi on 6/18/15.
 */
public class DotLoadProgressView extends View {
  private boolean isStart = false;
  private int dotIndex =0;//点下面的角标
  private int dotNumber = 0;
  private Paint mPaint;
  private int paddingTop = 50;
  private int paddingBottom = 50;
  private int paddingLeft = 30;
  private int paddingRight = 30;
  private Handler mHandler = new Handler();
  private long DELAY_TIME = 300;
  private Bitmap bitmap;
  private int itemDotSpace = 10;//二个点之间的距离
  private Bitmap moveBitmap ;
  private Runnable mRunnable = new Runnable() {
    @Override
    public void run() {
      if (dotNumber != 0){
        dotIndex = (dotIndex + 1) % dotNumber;
      }
      invalidate();
      mHandler.postDelayed(mRunnable, DELAY_TIME);
    }
  };
  public DotLoadProgressView(Context context, AttributeSet attrs) {
    super(context, attrs);
    moveBitmap = BitmapFactory.decodeResource(getResources(),R.drawable.active_dot);
    init();
  }
  private void init() {
    mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
    mPaint.setStyle(Paint.Style.FILL);
    mPaint.setDither(true);
    mPaint.setAntiAlias(true);
  }
  @Override
  protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    for(int i=0;i<dotNumber;i++){
      canvas.drawBitmap(bitmap,paddingLeft+i*itemDotSpace+bitmap.getWidth()*i,paddingTop,mPaint);
    }
    if(isStart){
      canvas.drawBitmap(moveBitmap,paddingLeft+dotIndex*itemDotSpace+moveBitmap.getWidth()*dotIndex,paddingTop,mPaint);
    }
  }
  @Override
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    int parentWidth = MeasureSpec.getSize(widthMeasureSpec);
    bitmap = BitmapFactory.decodeResource(getResources(),R.drawable.inactive_dot);
    setMeasuredDimension(parentWidth,bitmap.getHeight()+paddingTop+paddingBottom);
    int widthWithoutPadding = parentWidth - paddingLeft - paddingRight;
    dotNumber = calculateDotsNumber(widthWithoutPadding);
  }
  private int calculateDotsNumber(int width) {
    int number = (width / (itemDotSpace + bitmap.getWidth()));
    return number;
  }
  public void startProgress() {
    isStart = true;
    dotIndex = -1;
    mHandler.removeCallbacks(mRunnable);
    mHandler.post(mRunnable);
  }
  public void stopProgress() {
    isStart = false;
    mHandler.removeCallbacks(mRunnable);
    invalidate();
  }
  @Override
  protected void onAttachedToWindow() {
    super.onAttachedToWindow();
    startProgress();
  }
  @Override
  protected void onDetachedFromWindow() {
    super.onDetachedFromWindow();
    stopProgress();
  }
}

布局代码:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="wrap_content">
  <com.example.dotloadview.DotLoadProgressView
    android:id="@+id/progress1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    />
</RelativeLayout>

二个点其实是图片,在网上别人项目中拿出来用的,如果感觉那个点图片大了的话,有二个办法,第一叫你们美工切小点,第二就是通过drawable.setBound()去限制他大小了,我在这其实是偷懒,没有那么做,当然这点你也可以通过shade去做,而不用图片的话
最终的效果图还是这样的:

总结

以上所述是小编给大家介绍的Android 自定义view实现进度条加载效果实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# 自定义view  # 进度条  # android  # 自定义进度条  # Android自定义带加载动画效果的环状进度条  # Android开发之ProgressBar字体随着进度条的加载而滚动  # Android自定义View仿华为圆形加载进度条  # Android中WebView加载网页设置进度条  # Android Material加载进度条制作代码  # Android自定义View基础开发之图片加载进度条  # Android Webview添加网页加载进度条实例详解  # Android中实现Webview顶部带进度条的方法  # Android WebView线性进度条实例详解  # Android自定义带进度条WebView仿微信加载过程  # 二个  # 画出  # 小编  # 就可以  # 几个  # 在这  # 在此  # 是这样  # 你也  # 可以通过  # 给大家  # 去做  # 自定义  # 大了  # 每隔  # 所述  # 给我留言  # 感谢大家  # 来用  # 其实很简单 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 黑客如何通过漏洞一步步攻陷网站服务器?  详解jQuery中基本的动画方法  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  北京的网站制作公司有哪些,哪个视频网站最好?  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  用v-html解决Vue.js渲染中html标签不被解析的问题  php结合redis实现高并发下的抢购、秒杀功能的实例  长沙做网站要多少钱,长沙国安网络怎么样?  清除minerd进程的简单方法  BootStrap整体框架之基础布局组件  如何在Ubuntu系统下快速搭建WordPress个人网站?  如何用西部建站助手快速创建专业网站?  Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】  Android仿QQ列表左滑删除操作  如何快速选择适合个人网站的云服务器配置?  ,怎么在广州志愿者网站注册?  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  详解阿里云nginx服务器多站点的配置  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  php485函数参数是什么意思_php485各参数详细说明【介绍】  如何正确选择百度移动适配建站域名?  简单实现Android验证码  手机网站制作与建设方案,手机网站如何建设?  高防服务器租用指南:配置选择与快速部署攻略  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  C++时间戳转换成日期时间的步骤和示例代码  如何在万网主机上快速搭建网站?  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  高端网站建设与定制开发一站式解决方案 中企动力  利用 Google AI 进行 YouTube 视频 SEO 描述优化  Laravel怎么调用外部API_Laravel Http Client客户端使用  javascript读取文本节点方法小结  Laravel如何使用Sanctum进行API认证?(SPA实战)  JavaScript如何实现路由_前端路由原理是什么  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  php json中文编码为null的解决办法  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  如何在企业微信快速生成手机电脑官网?  Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】  Python制作简易注册登录系统  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  如何用免费手机建站系统零基础打造专业网站?  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  黑客入侵网站服务器的常见手法有哪些?  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  phpredis提高消息队列的实时性方法(推荐)