android 动画总结
以下博文讲解比较详细,可查阅:
http://www.360doc.com/content/13/0102/22/6541311_257754535.shtml
几个关键属性:
setRepeatCount(int repeatCount);//设置动画重复执行的次数
setStartOffSet(long startOffSet);//设置动画执行之前的等待时间。
setFillBefore(Boolean fillBefore);//为true则动画执行完成后,回到最初的状态。
setFillAfter(Boolean fillAfter);//为true 动画保持完成状态。
setDuration(long duration);//动画持续时间
以下为自己封装的动画工具类,只是最简单的封装。
package com.create.utilslibrary; import android.content.Context;
import android.view.View;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
import android.view.animation.AnimationSet;
import android.view.animation.DecelerateInterpolator;
import android.view.animation.RotateAnimation;
import android.view.animation.ScaleAnimation;
import android.view.animation.TranslateAnimation; /**
* Created by Administrator on 2016/5/19 0019.
*/
public class AnimatorUtils {
/**
* 条目动画
*
* @param context
* @param view
* @param position
*/
public static void runEnterAnimation(Context context, View view, int position) {
view.setTranslationY(ScreenUtil.getScreenHight(context));
view.animate()
.translationY(0)
.setStartDelay(100 * (position % 15))
.setInterpolator(new DecelerateInterpolator(3.f))
.setDuration(700)
.start();
} /**
* 渐变动画,淡入淡出 动画完成后保持在结束位置
*
* @param fromAlpha 开始的渐变值 0f 表开始时是全透明 1f表开始时是完全显示 值为 0--1f之间
* @param toAlpha 结束的渐变值 0f 表结束时是全透明 1f表结束时是完全显示 值为 0--1f之间
* @param duration 动画持续时间 毫秒
* @return
*/
public static AlphaAnimation getAlpaAnimation(float fromAlpha, float toAlpha, long duration) {
AlphaAnimation alphaAnimation = new AlphaAnimation(fromAlpha, fromAlpha);
alphaAnimation.setDuration(duration);
return alphaAnimation;
} /**
* 平移动画 动画完成后保持在结束位置
* 参考对象是view本身:Animation.RELATIVE_TO_SELF
*
* @param fromXvelue x轴方向 开始的值,相对于view宽度(x轴坐标) 的百分比 0f表示从view的最左侧的坐标点开始动画,1f表示从最右侧开始 值为 0f--1f之间
* @param toXvelue x轴方向 结束的值,相对于view宽度 的百分比 0f表示到view的最左侧坐标点时结束,1f表示到最右侧坐标点结束 值为 0f--1f之间
* @param fromYValue y轴方向 开始的值,相对于view高度(y轴坐标) 的百分比 0f表示从view的最顶部的坐标点开始动画,1f表示从最底部的坐标点开始 值为 0f--1f之间
* @param toYValue y轴方向 结束的值,相对于view高度 的百分比 0f表示到view的最顶部的坐标点时结束,1f表示到底部的坐标点结束 值为 0f--1f之间
* @param duration 动画持续时间
* @return
*/
public static TranslateAnimation getTranslateAnimation(float fromXvelue,
float toXvelue,
float fromYValue,
float toYValue,
long duration
) {
TranslateAnimation translateAnimation = new TranslateAnimation(
Animation.RELATIVE_TO_SELF, fromXvelue, Animation.RELATIVE_TO_SELF, toXvelue,
Animation.RELATIVE_TO_SELF, fromYValue, Animation.RELATIVE_TO_SELF, toYValue
);
translateAnimation.setDuration(duration);
return translateAnimation;
} /**
* 缩放动画 动画完成后保持在结束位置
* @param fromX 开始的x轴大小 相对于自身宽度的比例 0f--1f之间
* @param toX 结束的x轴的大小 相对于自身宽度的比例 0f--1f之间
* @param fromY 开始的y轴大小 相对于自身高度的比例 0f--1f之间
* @param toY 结束的y轴大小 相对于自身高度的比例 0f--1f之间
*
* 以下四个值是确定缩放开始的坐标点。
* @param pivotXType Animation.ABSOLUTE, Animation.RELATIVE_TO_SELF, or Animation.RELATIVE_TO_PARENT.
* @param pivotXValue 0f--1f之间的值
* @param pivotYType 同上
* @param pivotYValue 同上
* @return
*/
public static ScaleAnimation getScaleAnimation(float fromX,
float toX,
float fromY,
float toY,
int pivotXType,
float pivotXValue,
int pivotYType,
float pivotYValue,
long duration
){
ScaleAnimation scaleAnimation = new ScaleAnimation(fromX, toX, fromY, toY,
pivotXType, pivotXValue, pivotYType, pivotYValue);
scaleAnimation.setDuration(duration);
scaleAnimation.setFillAfter(true);
return scaleAnimation;
} /**
* 旋转动画 保持在结束位置
* @param fromDegrees 开始角度
* @param toDegrees 结束角度
* 以下四个参数用户旋转的圆心
* @param pivotXType 确定x轴坐标参照类型 Animation.ABSOLUTE, Animation.RELATIVE_TO_SELF, or Animation.RELATIVE_TO_PARENT.
* @param pivotXValue x轴 的坐标值 0f--1f
* @param pivotYType 确定y轴的坐标参照类型 Animation.ABSOLUTE, Animation.RELATIVE_TO_SELF, or Animation.RELATIVE_TO_PARENT.
* @param pivotYValue y轴 的坐标值 0f--1f
* @return
*/
public static RotateAnimation getRotateAnimation(float fromDegrees,
float toDegrees,
int pivotXType,
float pivotXValue,
int pivotYType,
float pivotYValue,
long duration
){
RotateAnimation rotateAnimation=new RotateAnimation(fromDegrees,toDegrees,
pivotXType,pivotXValue,pivotYType,pivotYValue);
rotateAnimation.setDuration(duration);
rotateAnimation.setFillAfter(true);
return rotateAnimation;
}
/**
* 创建动画集合对象
* @param bool true 所有集合中的动画使用 集合的插值器, false表各个动画使用自己的插值器。
* @return
*/
public static AnimationSet getAnimationSet(Boolean bool) {
AnimationSet animationSet = new AnimationSet(false);
return animationSet;
}
}
android 动画总结的更多相关文章
- Android动画效果之自定义ViewGroup添加布局动画
前言: 前面几篇文章介绍了补间动画.逐帧动画.属性动画,大部分都是针对View来实现的动画,那么该如何为了一个ViewGroup添加动画呢?今天结合自定义ViewGroup来学习一下布局动画.本文将通 ...
- Android动画效果之Property Animation进阶(属性动画)
前言: 前面初步认识了Android的Property Animation(属性动画)Android动画效果之初识Property Animation(属性动画)(三),并且利用属性动画简单了补间动画 ...
- Android动画效果之初识Property Animation(属性动画)
前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ...
- Android动画效果之Frame Animation(逐帧动画)
前言: 上一篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画),今天来总结下Android的另外一种动画Frame ...
- Android动画效果之Tween Animation(补间动画)
前言: 最近公司项目下个版本迭代里面设计了很多动画效果,在以往的项目中开发中也会经常用到动画,所以在公司下个版本迭代开始之前,抽空总结一下Android动画.今天主要总结Tween Animation ...
- Android动画
[浅谈Android动画] 总共四种:Tween Animation变换动画.Frame Animation帧动画 Layout Animation布局动画.Property Animation 属性 ...
- Android动画学习(二)——Tween Animation
前两天写过一篇Android动画学习的概述,大致的划分了下Android Animation的主要分类,没有看过的同学请移步:Android动画学习(一)——Android动画系统框架简介.今天接着来 ...
- Android动画学习(一)——Android动画系统框架简介
2015-11-09补充:Drawable Animation极有可能是Frame Animation 这几天在找工作,面试的时候被问到了Android动画,之前完全没接触过这部分,直接给懵了,当然其 ...
- Android动画的理解
基础知识 在我们开始讲Android动画这个知识点之前,我们了解下相应的基础知识点. Shape篇 一般用Shape定义的XML文件是存放在Drawable目录下,广泛应用于在Button.TextV ...
- Android动画之淡入淡出
为了更好的说明Android动画的淡入淡出效果,这里以一个场景为例: 界面上有两个View 控件,两个View交替显示,当一个View淡入显示,另一个View淡出不可见. 我们把当前要显示的View叫 ...
随机推荐
- H2的MVStore
翻译自http://www.h2database.com/html/mvstore.html 转载请著名出处,及译者信息. 第一次翻译,诸多不妥请谅解,谢谢. 概述 MVStore是一个持久化的.日志 ...
- [转]jquery $(document).ready() 与window.onload的区别
http://blog.csdn.net/xiebaochun/article/details/36375481 Jquery中$(document).ready()的作用类似于传统JavaScrip ...
- R语言putty中直接使用X11(Xming)绘图
1.下载Xming地址 http://pan.baidu.com/s/1o6ilisU,安装,推荐默认安装在C盘,推荐快捷方式放在与putty快捷方式同一个文件夹: 2.打开putty,在SSH的X1 ...
- Swift语言实战晋级-第9章 游戏实战-跑酷熊猫-3 显示一个动态的熊猫
一个静态的熊猫明显不能满足我们的欲望,接下来我们就让熊猫跑起来.序列帧动画的原理就是不停的切换不同的图片.当我们将一张一张的切换Panda类的跑动文理后,熊猫就跑起来了.那么首先我们需要一个数组常量来 ...
- Ways to access Oracle Database in PostgreSQL
Today, organizations stores information(data) in different database systems. Each database system ha ...
- 获取网络IP地址
IPHostEntry iphost = Dns.GetHostEntry(txtDNS.Text);//解析并返回IPHostEntry对象 foreach (IPAddress ip in iph ...
- Python学习总结10:获取shell输出结果
Python中获取shell命令的输出结果的常见方法如下几种: 1. import subprocess output = subprocess.Popen(['ls','-l'],stdout=su ...
- 从一简单程序看C语言内存分配
int main13(){ char buf[20]="aaaa"; char buf2[] = "bbbb"; char *p1 = "111111 ...
- SQL2008无法连接到.\SQLEXPRESS,用户'sa'登录失败(错误18456)图文解决方法
出现问题 :标题: 连接到服务器 ------------------------------ 无法连接到 .\SQLEXPRESS. ------------------------------ ...
- 夺命雷公狗---node下的一聊天室-首发
今晚感觉挺蛋疼,就用了点时间,在node下开发了个聊天室来玩玩,不过之是简单的开发了套而已,并没多做什么考虑,, 但是发现了一个好处就是用node来写聊天室代码居然少得可怜,这个不佩服node都不行, ...