Android自定义加载loading view动画组件_Android

在github上找的一个有点酷炫的loading动画https://github.com/Fichardu/CircleProgress 

我写写使用步骤 

自定义view(CircleProgress )的代码 

package com.hysmarthotel.view;

import com.hysmarthotel.roomcontrol.R;
import com.hysmarthotel.util.EaseInOutCubicInterpolator;

import android.animation.TimeInterpolator;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Point;
import android.util.AttributeSet;
import android.view.View;
import android.view.animation.AnimationUtils;

public class CircleProgress extends View {

 private static final int RED = 0xFFE5282C;
 private static final int YELLOW = 0xFF1F909A;
 private static final int BLUE = 0xFFFC9E12;
 private static final int COLOR_NUM = 3;
 private int[] COLORS;
 private TimeInterpolator mInterpolator = new EaseInOutCubicInterpolator();

 private final double DEGREE = Math.PI / 180;
 private Paint mPaint;
 private int mViewSize;
 private int mPointRadius;
 private long mStartTime;
 private long mPlayTime;
 private boolean mStartAnim = false;
 private Point mCenter = new Point();

 private ArcPoint[] mArcPoint;
 private static final int POINT_NUM = 15;
 private static final int DELTA_ANGLE = 360 / POINT_NUM;
 private long mDuration = 3600;

 public CircleProgress(Context context) {
  super(context);
  init(null, 0);
 }

 public CircleProgress(Context context, AttributeSet attrs) {
  super(context, attrs);
  init(attrs, 0);
 }

 public CircleProgress(Context context, AttributeSet attrs, int defStyle) {
  super(context, attrs, defStyle);
  init(attrs, defStyle);
 }

 private void init(AttributeSet attrs, int defStyle) {
  mArcPoint = new ArcPoint[POINT_NUM];

  mPaint = new Paint();
  mPaint.setAntiAlias(true);
  mPaint.setStyle(Paint.Style.FILL);

  TypedArray a = getContext().obtainStyledAttributes(attrs, R.styleable.CircleProgress, defStyle, 0);
  int color1 = a.getColor(R.styleable.CircleProgress_color1, RED);
  int color2 = a.getColor(R.styleable.CircleProgress_color2, YELLOW);
  int color3 = a.getColor(R.styleable.CircleProgress_color3, BLUE);
  a.recycle();

  COLORS = new int[]{color1, color2, color3};
 }

 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  int defaultSize = getResources().getDimensionPixelSize(R.dimen.default_circle_view_size);
  int width = getDefaultSize(defaultSize, widthMeasureSpec);
  int height = getDefaultSize(defaultSize, heightMeasureSpec);
  mViewSize = Math.min(width, height);
  setMeasuredDimension(mViewSize, mViewSize);
  mCenter.set(mViewSize / 2, mViewSize / 2);

  calPoints(1.0f);
 }

 @Override
 protected void onDraw(Canvas canvas) {
  canvas.save();
  canvas.translate(mCenter.x, mCenter.y);

  float factor = getFactor();
  canvas.rotate(36 * factor);
  float x, y;
  for (int i = 0; i < POINT_NUM; ++i) {
   mPaint.setColor(mArcPoint[i].color);
   float itemFactor = getItemFactor(i, factor);
   x = mArcPoint[i].x - 2 * mArcPoint[i].x * itemFactor;
   y = mArcPoint[i].y - 2 * mArcPoint[i].y * itemFactor;
   canvas.drawCircle(x, y, mPointRadius, mPaint);
  }

  canvas.restore();

  if (mStartAnim) {
   postInvalidate();
  }
 }

 private void calPoints(float factor) {
  int radius = (int) (mViewSize / 3 * factor);
  mPointRadius = radius / 12;

  for (int i = 0; i < POINT_NUM; ++i) {
   float x = radius * -(float) Math.sin(DEGREE * DELTA_ANGLE * i);
   float y = radius * -(float) Math.cos(DEGREE * DELTA_ANGLE * i);

   ArcPoint point = new ArcPoint(x, y, COLORS[i % COLOR_NUM]);
   mArcPoint[i] = point;
  }
 }

 private float getFactor() {
  if (mStartAnim) {
   mPlayTime = AnimationUtils.currentAnimationTimeMillis() - mStartTime;
  }
  float factor = mPlayTime / (float) mDuration;
  return factor % 1f;
 }

 private float getItemFactor(int index, float factor) {
  float itemFactor = (factor - 0.66f / POINT_NUM * index) * 3;
  if (itemFactor < 0f) {
   itemFactor = 0f;
  } else if (itemFactor > 1f) {
   itemFactor = 1f;
  }
  return mInterpolator.getInterpolation(itemFactor);
 }

 public void startAnim() {
  mPlayTime = mPlayTime % mDuration;
  mStartTime = AnimationUtils.currentAnimationTimeMillis() - mPlayTime;
  mStartAnim = true;
  postInvalidate();
 }

 public void reset() {
  stopAnim();
  mPlayTime = 0;
  postInvalidate();

 }

 public void stopAnim() {
  mStartAnim = false;
 }

 public void setInterpolator(TimeInterpolator interpolator) {
  mInterpolator = interpolator;
 }

 public void setDuration(long duration) {
  mDuration = duration;
 }

 public void setRadius(float factor) {
  stopAnim();
  calPoints(factor);
  startAnim();
 }

 static class ArcPoint {
  float x;
  float y;
  int color;

  ArcPoint(float x, float y, int color) {
   this.x = x;
   this.y = y;
   this.color = color;
  }
 }

}

EaseInOutCubicInterpolator是自定义view(CircleProgress )中要是用的一个工具 

package com.hysmarthotel.util;

import android.animation.TimeInterpolator;

public class EaseInOutCubicInterpolator implements TimeInterpolator {

 @Override
 public float getInterpolation(float input) {
  if ((input *= 2) < 1.0f) {
   return 0.5f * input * input * input;
  }
  input -= 2;
  return 0.5f * input * input * input + 1;
 }

}

在activity中的调用(还有一些其他用法可以自己看看github上的源代码) 

mProgressView = (CircleProgress)findViewById(R.id.progress_vie);
mProgressView.startAnim(); //开始
mProgressView.stopAnim(); //结束
mProgressView.setRadius(factor); //半径
mProgressView.reset(); //复原

在xml文件中的布局 

<?xml version="1.0" encoding="utf-8"?>
<AbsoluteLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:circleprogress="http://schemas.android.com/apk/res/com.hysmarthotel.roomcontrol"  //这个地方记得要加 //包名
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="@drawable/bg1" >

 <com.hysmarthotel.view.CircleProgress                   //类名
  android:id="@+id/progress_vie"
  android:layout_x="350.5px"
  android:layout_y="150.0px"
  android:layout_width="1140.0px"
  android:layout_height="700.0px"
  circleprogress:color1="@android:color/holo_red_light"   //这些参数就是通过xmlns:circleprogress,和attrs文件相关联的     circleprogress:color2="@android:color/holo_green_light"     circleprogress:color3="@android:color/holo_blue_light" />

自己在values目录中新建的attrs文件,这是与自定义view中自定义参数相关的

 <declare-styleable name="CircleProgress">
  <attr name="color1" format="reference|color"/>
  <attr name="color2" format="reference|color"/>
  <attr name="color3" format="reference|color"/>
 </declare-styleable>

自己在values目录中新建的dimens文件,这个只是几个颜色参数

 <?xml version="1.0" encoding="utf-8"?>
<resources>
 <dimen name="activity_horizontal_margin">16dp</dimen>
 <dimen name="activity_vertical_margin">16dp</dimen>
 <dimen name="default_circle_view_size">200dp</dimen>
</resources>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索android
, Android加载动画
loading加载动画
自定义view加载布局、自定义view加载xml、ios 加载自定义view、自定义view加载layout、xib加载自定义view,以便于您获取更多的相关知识。

时间: 2024-11-15 21:38:51

Android自定义加载loading view动画组件_Android的相关文章

Android自定义加载loading view动画组件

在github上找的一个有点酷炫的loading动画https://github.com/Fichardu/CircleProgress 我写写使用步骤 自定义view(CircleProgress )的代码 package com.hysmarthotel.view; import com.hysmarthotel.roomcontrol.R; import com.hysmarthotel.util.EaseInOutCubicInterpolator; import android.ani

Android自定义加载控件实现数据加载动画_Android

本文实例为大家分享了Android自定义加载控件,第一次小人跑动的加载效果眼前一亮,相比传统的PrograssBar高大上不止一点,于是走起,自定义了控件LoadingView去实现动态效果,可直接在xml中使用,具体实现如下 package com.*****.*****.widget; import android.content.Context; import android.graphics.drawable.AnimationDrawable; import android.util.

一款超酷的Android自定义加载控件_Android

在设计应用的时候,我们应该热爱极简主义,简单就是好的,对于很多用户来说,复杂的东西并不受欢迎. 我要实现的是根据不同的情况去显示不同的加载效果,随用随调,效果是借鉴于某一项目的效果,我认为有必要提取出来改善封装一下,供以后使用.情况大致分为:加载中.无网络.无数据.加载失败等,这些仅仅就需要一个View 就可以搞定啦! 预览下效果图: 我们怎么实现这种效果呢 view_loading.xml的布局如下: <?xml version="1.0" encoding="utf

一款超酷的Android自定义加载控件

在设计应用的时候,我们应该热爱极简主义,简单就是好的,对于很多用户来说,复杂的东西并不受欢迎. 我要实现的是根据不同的情况去显示不同的加载效果,随用随调,效果是借鉴于某一项目的效果,我认为有必要提取出来改善封装一下,供以后使用.情况大致分为:加载中.无网络.无数据.加载失败等,这些仅仅就需要一个View 就可以搞定啦! 预览下效果图: 我们怎么实现这种效果呢 view_loading.xml的布局如下: <?xml version="1.0" encoding="utf

Android动态加载Activity原理详解_Android

activity的启动流程 加载一个Activity肯定不会像加载一般的类那样,因为activity作为系统的组件有自己的生命周期,有系统的很多回调控制,所以自定义一个DexClassLoader类加载器来加载插件中的Activity肯定是不可以的. 首先不得不了解一下activity的启动流程,当然只是简单的看一下,太详细的话很难研究清楚. 通过startActivity启动后,最终通过AMS进行跨进程回调到ApplicationThread的scheduleLaunchActivity,这时

Android RecyclerView加载不同布局简单实现_Android

前言 关于RecyclerView的使用这里就不在赘述了,相信网上一搜一大把(本人之前的文章也有简单的使用介绍),这次我们讲的是RecyclerView在使用的过程中,有时候会根据不同的位置加载不同的布局的简单实现,这里只是起到抛砖引玉的作用 效果图 设计思想  •重写RecyclerView.Adapter的getItemViewType(int position), 在此方法中根据不同的position,设置不同的ViewType  •编写具体的RecyclerView.ViewHolder

Android 异步加载图片的实例代码_Android

异步加载图片的主要流程是进行判断缓存中是否存在图片,如果存在则直接返回,如果不存在则进行下载并进行缓存. 以下是建立一个异步下载类: 复制代码 代码如下: /** * User: Tom * Date: 13-5-13 * Time: 下午8:07 */public class AsnycImageLoader {     //定义一个HashMap进行存放缓存的Image key为String Value为一个弱引用的一个资源文件    // 图片 为了方便JAVA的回收    private

Android自定义listview布局实现上拉加载下拉刷新功能_Android

listview实现上拉加载以及下拉刷新的方式有很多.下面是我写的一种自定义的布局,复用性也比较的强.首先就是继承的listview的自定义view.      AutoListView.Java: package com.example.mic.testdemo.view; import android.annotation.TargetApi; import android.content.Context; import android.os.Build; import android.os

Android中自定义加载样式图片的具体实现

先让大家看看效果图吧,相信很多Android初学者都想知道这中效果是怎么实现的,来上图: 想实现上面这张图中的自定义加载样式,其实很简单,首先我们需要的布局组件有ProcessBar和TextView,下面是布局文件的代码(只是加载的页面的布局): 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.an