关于ValueAnimation以及Interpolator +Drawable实现的自己定义动画效果
ValueAnimation :
Android中的属性动画,他跟objectAnimation是比补间动画拥有更强大的功能,能够操作对象。所以我们能够在自
定义View中通过他们来实现些特别的功能。
Interpolator:
插值器,通过插值器我们能实现比方反弹。重力加速度。等等的效果。
Android本来就自带了插值器。加速减速等等。并且在最新的v4包中还加入了几个新的插值器,能够上网搜下,看看不同的插值器的效果。
Drawable :Drawable这个类是能够用来绘制的类
通过自己定义Drawable 能够实现非常多不通过的功能:
由于不是动态图片。看不到实际效果。能够下载Demo自己执行下看看。
关于自己定义Drawable 的步骤:
1、用一个类继承Drawable
2、创建一个ValueAnimator 对象。设置他的各种属性以及加入AnimatorUpdateListener。然后通过他的监听器能够设置你控件的动画效果
3、创建一个画笔,用来进行绘制你所要绘制的东西
4、绘制的时候按你的需求来计算要绘制的东西(功能不一样计算方式也不一样)
看上图第一个控件的实现方式:
package com.example.modifyprogress; import android.animation.ValueAnimator;
import android.animation.ValueAnimator.AnimatorUpdateListener;
import android.annotation.SuppressLint;
import android.graphics.Canvas;
import android.graphics.ColorFilter;
import android.graphics.Path;
import android.graphics.Rect;
import android.graphics.RectF;
import android.graphics.drawable.Drawable;
import android.view.animation.Animation;
import app.dinus.com.loadingdrawable.MaterInterpolator; @SuppressLint("NewApi")
public class LoadingDrawable extends Drawable{
private Drawable mDrawable;
private Path mPath = new Path();
private float mPercent;
private ValueAnimator mAnimator;
public LoadingDrawable(Drawable drawable) {
this.mDrawable = drawable; mAnimator = ValueAnimator.ofFloat(0.0f,1.0f);
mAnimator.setDuration(5000);
mAnimator.setRepeatCount(Animation.INFINITE);
mAnimator.setRepeatMode(Animation.REVERSE);
mAnimator.setInterpolator(MaterInterpolator.createInterpolator().setDefault_Type(MaterInterpolator.BOUNCE));
mAnimator.addUpdateListener(new AnimatorUpdateListener() { @Override
public void onAnimationUpdate(ValueAnimator animation) { if (mPercent < 1) {
mPercent += (Float)animation.getAnimatedValue()/100;
} else {
mPercent = 0;
}
invalidateSelf();
}
});
mAnimator.start();
}
@Override
public void draw(Canvas canvas) {
mPath.reset();
RectF rect = new RectF(getBounds());
double radius = Math.pow(Math.pow(rect.right, 2) + Math.pow(rect.bottom, 2), 0.5);
mPath.moveTo(rect.right / 2, rect.bottom / 2);
mPath.lineTo(rect.right / 2, 0);
if (mPercent > 0.125f) {
mPath.lineTo(rect.right, 0);
}
if (mPercent > 0.375f) {
mPath.lineTo(rect.right, rect.bottom);
}
if (mPercent > 0.625f) {
mPath.lineTo(0, rect.bottom);
}
if (mPercent > 0.875f) {
mPath.lineTo(0, 0);
}
mPath.lineTo((float) (rect.right / 2 + radius * Math.sin(Math.PI * 2 * mPercent)),
(float) (rect.bottom / 2 - radius * Math.cos(Math.PI * 2 * mPercent)));
mPath.close();
if (mPercent >= 0 && mPercent <= 1) {
canvas.save();
canvas.clipPath(mPath);
mDrawable.draw(canvas);
canvas.restore();
}
} @Override
public void setAlpha(int alpha) {
mDrawable.setAlpha(alpha);
} @Override
public int getAlpha() {
return mDrawable.getAlpha();
} @Override
public void setColorFilter(ColorFilter cf) {
mDrawable.setColorFilter(cf);
} @Override
public int getOpacity() {
// TODO Auto-generated method stub
return mDrawable.getOpacity();
} @Override
protected void onBoundsChange(Rect bounds) {
mDrawable.setBounds(bounds);
} @Override
public int getIntrinsicHeight() {
return mDrawable.getIntrinsicHeight();
} @Override
public int getIntrinsicWidth() {
return mDrawable.getIntrinsicWidth();
} public void setPercent(float percent) {
if (percent > 1) {
percent = 1;
} else if (percent < 0) {
percent = 0;
}
if (percent != mPercent) {
this.mPercent = percent;
invalidateSelf();
}
} }
我自己自己定义了几个插值动画。关于插值动画的測试能够在:http://inloop.github.io/interpolator/
package app.dinus.com.loadingdrawable; import android.view.animation.Interpolator;
/**
*各种插值器效果
* @author chenpengfei_d
*能够去这个网址上看效果: http://inloop.github.io/interpolator/
*/
public class MaterInterpolator implements Interpolator{
private int mDefault_Type = LINEAR;
private float interpolatorValue;
private static MaterInterpolator mInterpolator;
public static MaterInterpolator createInterpolator(){
if (mInterpolator == null) {
mInterpolator = new MaterInterpolator();
}
return mInterpolator;
} @Override
public float getInterpolation(float input) { switch (mDefault_Type) {
case LINEAR: //线性
interpolatorValue = input;
break;
case ACCELERATE: //加速
float factor = 1.0f;
if (factor == 1.0) {
factor = input * input;
}else {
factor = (float)Math.pow(input, factor *2);
}
interpolatorValue = factor;
break;
case ACCELERATEDECELERATE://先加速后减速
interpolatorValue = (float) ((Math.cos((input + 1) * Math.PI) /2.0) + 0.5F);
break;
case ANTICIPATE: float tension = 2.0f;
interpolatorValue = input * input *((tension + 1) * input - tension);
break;
case ANTICIPATEOVERSHOOT:
tension = 2.0f * 1.5f;
if (input < 0.5){
interpolatorValue = (float) (0.5 * (Math.pow(input * 2.0f, 2) * ((tension + 1) * input - tension)));
}else {
interpolatorValue = (float) (0.5 *(Math.pow(((input - 1) * 2.0f), 2) *((tension + 1) *(input - 1) * 2.0f + tension)));
}
break;
case BOUNCE://反弹
if (input < 0.3535) {
interpolatorValue = bounce(input);
}else if(input < 0.7408){
interpolatorValue = bounce(input - 0.54719f) + 0.7f;
}else if (input < 0.9644) {
interpolatorValue = bounce(input - 0.8526f) + 0.9f;
}else {
interpolatorValue = bounce(input - 1.0435f) + 0.95f;
}
break;
case CUBICHERMITE:
interpolatorValue = CubicHermite(input, 0, 1, 4, 4);
break;
case CYCLE:
float cycles = 1.0f;
interpolatorValue = (float)Math.sin(2* cycles *Math.PI *input);
break;
case DECELERATE://减速
float divisor = 1.0f;
if (divisor == 1.0) {
interpolatorValue = (float) (1.0 - (1.0 - input ) * (1.0 - input));
}else {
interpolatorValue = (float) (1.0 - Math.pow((1.0 - input), 2 * divisor));
}
break;
case OVERSHOOT:
tension = 2.0f;
input = input - 1.0f;
interpolatorValue = (float) (input *input *((tension + 1) * input + tension ) +1.0);
break;
case SMOOTHSTEP:
interpolatorValue = input * input * (3 - 2 *input );
break;
case SPRING://弹簧效果
factor = 0.4f;
interpolatorValue = (float) (Math.pow(2, -10 *input) * Math.sin((input - factor /4) *(2 *Math.PI)/factor ) + 1.0);
break;
default:
break;
} return interpolatorValue;
} private float bounce(float input){
return input *input *8;
}
private float CubicHermite(float t, int p0,int p1,int m0,int m1){
float t2 = t* t;
float t3 = t2 * t ;
return (2* t3 - 3 * t2 +1) * p0 + (t3 - 2 * t2 + t) * m0 + (-2 * t3 + 3 * t2) * p1 + (t3 - t2) *m1;
}
public int getDefault_Type() {
return mDefault_Type;
}
public MaterInterpolator setDefault_Type(int default_Type) {
mDefault_Type = default_Type;
return mInterpolator;
}
public static final int LINEAR =0 ;
public static final int SMOOTHSTEP = 1;
public static final int ACCELERATEDECELERATE = 2;
public static final int BOUNCE = 3;
public static final int ACCELERATE = 4;
public static final int ANTICIPATEOVERSHOOT = 5;
public static final int CYCLE = 6;
public static final int ANTICIPATE = 7;
public static final int DECELERATE = 8;
public static final int OVERSHOOT = 9;
public static final int CUBICHERMITE = 10;
public static final int SPRING = 11;
public enum MaterInterPolatorType{
LINEAR,SMOOTHSTEP,SPRING,CUBICHERMITE,OVERSHOOT,DECELERATE,ANTICIPATE,CYCLE,ANTICIPATEOVERSHOOT
,ACCELERATE,BOUNCE,ACCELERATEDECELERATE
}
}
还有其它的效果能够看代码里边。下载执行就好,效果还不错,个人感觉。
关于ValueAnimation以及Interpolator +Drawable实现的自己定义动画效果的更多相关文章
- Android动画主要包含补间动画(Tween)View Animation、帧动画(Frame)Drawable Animation、以及属性动画Property Animation
程序运行效果图: Android动画主要包含补间动画(Tween)View Animation.帧动画(Frame)Drawable Animation.以及属性动画Property Animatio ...
- Android 学习笔记多媒体技术之 Drawable类+Tween(补间动画)+Frame(帧动画)
学习内容: 1.了解Drawable类的作用 2.如何使用Drawable... 3.了解Tween动画... 4.如何创建和使用Tween动画... 1.Drawable类... Drawabl ...
- 动画效果interpolator
Interpolator 被用来修饰动画效果,定义动画的变化率 AccelerateDecelerateInterpolator 在动画开始与结束的地方速率改变比较慢,在中间的时候加速 Accel ...
- Android开发之View动画效果插补器Interpolator
插补器Interpolator 官网描述:An interpolator defines the rate of change of an animation. This allows the bas ...
- 几种常用的Interpolator(插值器)的动画效果
在实现动画的非线性变化的方法中,常用的一种是为动画添加插值器以改变视图的属性值,从而实现理想的动画效果.Interpolator使用相对简单,下面就只给出一些提供的插值器的默认效果. 在代码中:直接调 ...
- 巧用Drawable 实现Android UI 元素间距效果
源文地址: 巧用Drawable 实现Android UI 元素间距效果 在大部分的移动UI或者Web UI都是基于网格概念而设计的.这种网格一般都是有一些对其的方块组成,然后它们组合成为一个块.使用 ...
- Android中的动画机制
1 逐帧动画 逐帧动画 就是一系列的图片按照一定的顺序展示的过程. 逐帧动画很简单, 只需要在drawable中或者anim中定义一个Animation-list 其中包含多个it ...
- 动画_ _ Android应用开发之所有动画使用详解
转载: http://blog.csdn.net/yanbober/article/details/46481171 题外话:有段时间没有更新博客了,这篇文章也是之前写了一半一直放在草稿箱,今天抽空把 ...
- Android 三种动画详解
[工匠若水 http://blog.csdn.net/yanbober 转载请注明出处.点我开始Android技术交流] 1 背景 不能只分析源码呀,分析的同时也要整理归纳基础知识,刚好有人微博私信让 ...
随机推荐
- [读书笔记] Python 数据分析 (十一)经济和金融数据应用
resample: 重采样函数,可以按照时间来提高或者降低采样频率,fill_method可以使用不同的填充方式. pandas.data_range 的freq参数枚举: Alias Descrip ...
- Android开发进度06
1,今日:目标:完成后台账单的增删改查 2,昨天:用户的增删改查 3,收获:熟练了SQLite操作 4,问题:无
- STM32 GPIO重映射(转)
重映射就是将引脚功能重新定义到其他引脚, 例如PA9是USART1-TX默认的 管脚,但是现在PA9用做它用了,那可以将USART1-TX重新映射到PB6,当然这 种映射不是随意的想映射到哪个脚就哪个 ...
- ASP.NET-MVC中Entity和Model之间的关系
Entity 与 Model之间的关系图 ViewModel类是MVC中与浏览器交互的,Entity是后台与数据库交互的,这两者可以在MVC中的model类中转换 MVC基础框架 来自为知笔记(Wiz ...
- angular-基础
AngularJs特点: 1.依赖注入 2.模块化 3.双向绑定 4.语义化标签 当网页加载完毕,AngularJS 自动开启. ng-app 指令告诉 AngularJS,<div> 元 ...
- Android学习之GridView图片布局适配经验
開始解说这篇博客之前,我想问一下,当布局相似GridView这样的多列布局时,我们该怎么布局,才干更好的去适配呢? 扣张图来展示一下 比如这样的需求,三张图片均分屏幕 实现方法: 1.切图固定,比如是 ...
- Coding上部署Ghost博客
Ghost构建于Node.js平台之上.支持0.10.*版本号的Node.js. 在你的本地计算机上执行Ghost事实上非常easy,前提是你已经安装了Node.js. 什么是Node.js? 略过 ...
- python爬虫 分页获取图片并下载
--刚接触python2天,想高速上手,就写了个爬虫,写完之后,成就感暴增,用起来顺手多了. 1.源代码 #coding=utf-8 import urllib import re class Pag ...
- PHP的curl库代码使用
欢迎訪问个人原创地址: http://www.phpthinking.com/archives/468 使用PHP的cURL库能够简单和有效地去抓网页. 你仅仅须要执行一个脚本.然后分析一下你所抓取的 ...
- 屌丝也能开发安卓版2048(App Inventor)
想编写安卓游戏.java太难.来试试App Inventor.尽管有人觉得他是中学生的玩具,可是也能编写2048这种火爆游戏,不须要太复杂的算法. 整个游戏有几个模块: 一.游戏初始化 数列转化为图形 ...