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


相关推荐: 如何自定义建站之星模板颜色并下载新样式?  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  JavaScript模板引擎Template.js使用详解  Laravel如何优化应用性能?(缓存和优化命令)  如何在建站之星网店版论坛获取技术支持?  Laravel如何为API生成Swagger或OpenAPI文档  如何彻底卸载建站之星软件?  如何快速使用云服务器搭建个人网站?  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  如何实现建站之星域名转发设置?  phpredis提高消息队列的实时性方法(推荐)  如何为不同团队 ID 动态生成多个非值班状态按钮  零服务器AI建站解决方案:快速部署与云端平台低成本实践  Laravel storage目录权限问题_Laravel文件写入权限设置  浅谈Javascript中的Label语句  昵图网官网入口 昵图网素材平台官方入口  googleplay官方入口在哪里_Google Play官方商店快速入口指南  Laravel如何配置和使用缓存?(Redis代码示例)  html5的keygen标签为什么废弃_替代方案说明【解答】  ,在苏州找工作,上哪个网站比较好?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  javascript中的try catch异常捕获机制用法分析  进行网站优化必须要坚持的四大原则  电商网站制作价格怎么算,网上拍卖流程以及规则?  Python自动化办公教程_ExcelWordPDF批量处理案例  三星、SK海力士获美批准:可向中国出口芯片制造设备  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  网站制作软件免费下载安装,有哪些免费下载的软件网站?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  魔方云NAT建站如何实现端口转发?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  php485函数参数是什么意思_php485各参数详细说明【介绍】  如何用IIS7快速搭建并优化网站站点?  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  香港服务器如何优化才能显著提升网站加载速度?  JavaScript实现Fly Bird小游戏  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  如何有效防御Web建站篡改攻击?  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  如何在阿里云通过域名搭建网站?  如何在万网主机上快速搭建网站?  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  网站建设整体流程解析,建站其实很容易!  利用vue写todolist单页应用