软件编程
位置:首页>> 软件编程>> Android编程>> Android 自定义view实现进度条加载效果实例代码

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

作者:zhoushenxian  发布时间:2022-12-21 05:33:48 

标签:android,view,进度条

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

效果如下:

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

分析图:

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

代码如下:


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实现进度条加载效果实例代码

总结

以上所述是小编给大家介绍的Android 自定义view实现进度条加载效果实例代码网站的支持!

来源:http://blog.csdn.net/coderinchina/article/details/77626339

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com