我写写使用步骤

自定义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文件中的布局

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" >

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中自定义参数相关的

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

16dp

16dp

200dp

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

android组件什么时候加载到r文件,Android自定义加载loading view动画组件相关推荐

  1. bootstraptable treeGrid 懒加载_Java类加载机制及自定义加载器

    一:ClassLoader类加载器,主要的作用是将class文件加载到jvm虚拟机中.jvm启动的时候,并不是一次性加载所有的类,而是根据需要动态去加载类,主要分为隐式加载和显示加载. 隐式加载:程序 ...

  2. android jar 无法访问r文件,android项目中gen目录不能自动生成R.java的原因

    php分页代码简单实现 版权声明:本文为博主原创文章,未经博主允许不得转载. 数据库操作类代码:mysqli.func.php <?php // 数据库连接常量 define('DB_HOST' ...

  3. android 真机无法读取tomcat的xml文件,Android为何总是无法正常访问Tomcat服务器

    今天开始写一个MP3播放器,部署好了Tomcat服务器,写好了代码,结果总是无法连接,开始苦逼的搜索各种线索,始终无果,最后看到一篇帖子,由于现在的Tomcat服务器版本更新之后,所有的资源放在Web ...

  4. android 播放wav代码,播放简短的.wav文件 - Android

    Raghav Sood.. 27 该的Soundpool是这个正确的类.以下代码是如何使用它的示例.它也是我在我的几个应用程序中用来管理声音的代码.您可以根据自己的喜好(或内存允许)发出声音. pub ...

  5. 尚硅谷2020最新版宋红康JVM教程-中篇-第4章:再谈类的加载器-02和03-类的加载器分类

    引言 JVM支持两种类型的类加载器,分别为引导类加载器(Bootstrap ClassLoader)和自定义类加载器(User-Defined ClassLoader). 从概念上来讲,自定义类加载器 ...

  6. Android studio R文件位置

    随着Android studio的版本的升级,R文件的位置也改变了,在定位问题的时候,需要查找对应的资源名称,目前高版的Android studio的R文件位置可参考: build-->inte ...

  7. 移动跨平台ReactNative动画组件Animated【14】

    前端江太公 React Native,是一个混合移动应用开发框架,是目前流行的跨平台移动应用开发框架之一.React Native 采用不同的方法进行混合移动应用开发.它不会生成原生 UI 组件,而是 ...

  8. Android Studio(九):引用jar及so文件

    Android Studio相关博客: Android Studio(一):介绍.安装.配置 Android Studio(二):快捷键设置.插件安装 Android Studio(三):设置Andr ...

  9. android组合动画还原,Android - Fragment,View动画,组合动画,属性动画

    转载请注明出处:https://blog.csdn.net/mythmayor/article/details/72876871 1.什么是Fragment 片段,碎片 * 从Android 3.0 ...

最新文章

  1. androidstudio判断手指滑动方向_方向盘的黑科技有多“黑”
  2. Matlab2018a求解一元二次方程
  3. Codeforces
  4. 【考研计算机】AOE关键路径
  5. 大学英语期末考计算机上答卷,英语期末考试质量分析
  6. JAVA继承类初始化顺序
  7. 中国象棋人机对弈搜索算法学习-极大极小值,负极大值,alpha-beta算法
  8. redis指定配置文件启动不生效_redis配置文件不生效
  9. 考个ISTQB证书有用吗
  10. android版本11下载,coloros 11正式版下载
  11. mysql查询区分英文大小写_Mysql查询英文如何严格区分大小写?
  12. 表达式计算器-iExpr
  13. Holding Two
  14. 建造者模式(Builder)---创建型
  15. chatgpt 的强大让你慌了么?趁着还有点理智,跟着我看看怎么玩吧!
  16. Android LruCache和DiskLruCache相结合打造图片加载框架(仿微信图片选择,照片墙)
  17. 任岁月变迁,我心不惊
  18. ForkJoinPool的理解与使用
  19. 产品经理必懂的技术知识
  20. 浙江省宁波温州台州绍兴卫星地图1省4市合一大高清图(2021年)

热门文章

  1. 软件架构自学笔记——非功能特性
  2. BZOJ1597: [Usaco2008 Mar]土地购买(dp 斜率优化)
  3. oracle数据库 export,转:Oracle数据库的备份方法——使用export作为备份
  4. angular初步认识一
  5. Cassandra 1.2 发布,NoSQL 数据库
  6. ActiveRecordBase借助NHibernate的条件获取实体类对象
  7. Ubuntu18.04安装cudnn
  8. pat 食物链(状态压缩求哈密顿回路)
  9. redis服务器索引文件删除,Redis基本命令整理
  10. 微擎 jssdk php文件,微擎register_jssdk分享到朋友功能无法使用的问题及解决办法