Android 对View执行上移下移动动画 android位移动画

1.补间动画 View Animation(Tween Animation)

1.1位移动画
<translate xmlns:android="http://schemas.android.com/apk/res/android"  
    android:fromXDelta="0"
    android:toXDelta="300"  
    android:fromYDelta="100%p"  
    android:toYDelta="0"  
    android:duration="200"/>   
<!--   
 fromXDelta  动画起始位置的横坐标  
 toXDelta    动画起结束位置的横坐标  
 fromYDelta  动画起始位置的纵坐标  
 toYDelta    动画结束位置的纵坐标  
 duration    动画的持续时间  
 100%p 表示自身的长度的位置
 -->

代码实现:

Animation  animation = new TranslateAnimation(0,50,0,50);
参数1:x轴的起始位置
参数2:x轴的终止位置
参数3: y轴的起始位置
参数4:y轴的终止位置
相对于原图位置的原点(图片的右上角为0,0),如果不想用这个点作为参照点,可以使用其他构造
TranslateAnimation(fromXType, fromXValue, toXType, toXValue, fromYType, fromYValue, toYType, toYValue)
参数1,参数3,参数5,参数7就是设置参照点的方式
imageView.startAnimation(animation);
1.2旋转动画

xml定义

<rotate xmlns:android="http://schemas.android.com/apk/res/android"  
    android:fromDegrees="0"  
    android:toDegrees="360"  
    android:duration="200"  />  
<!--   
 fromDegrees:表示旋转的起始角度  
 toDegrees:表示旋转的结束角度  
 duration    动画的持续时间  
 from<to:顺时针旋转
 from>to:逆时针旋转
 -->

代码实现:

Animation animation  = new RotateAnimation(360,0,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f); 
参数1:旋转的起始角度
参数2:旋转的终止角度
参数3:旋转中心的x轴取值参照方式
参数4:中心点x轴的取值
参数5:旋转中心的y轴取值参照方式
参数6:中心点y轴的取值
imageView.startAnimation(animation);
1.3透明度动画

xml定义:

<alpha xmlns:android="http://schemas.android.com/apk/res/android" 
    android:fromAlpha="1.0"  
    android:toAlpha="0.1"  
    android:duration="200"/>  
<!--   
 fromAlpha :起始透明度  
 toAlpha:结束透明度  
 1.0表示完全不透明  
 0.0表示完全透明  
 -->

代码实现

Animation animation = new AlphaAnimation(1f,0.1f);
参数1: 起始透明度;
参数2: 目标透明度;
1.4缩放动画

xml定义

<scale xmlns:android="http://schemas.android.com/apk/res/android"  
    android:fromXScale="0.5"  
    android:toXScale="1.0"  
    android:fromYScale="0.5"  
    android:toYScale="1.0"  
    android:pivotX="50%"  
    android:pivotY="50%"  
    android:duration="200"/>  
<!--   
 fromXScale:表示沿着x轴缩放的起始比例  
 toXScale:表示沿着x轴缩放的结束比例  
 fromYScale:表示沿着y轴缩放的起始比例  
 toYScale:表示沿着y轴缩放的结束比例  
 1.0表示原来的大小
 50%表示图片中心点
 -->

代码实现:

Animation   animation = new ScaleAnimation(1f,0.2f,1f,0.2f,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f); 
参数1:x方向起始大小(1f表示原图大小)
参数2:x方向终止大小(0.2f表示原图的0.2倍)
参数3:y方向起始大小(1f表示原图大小)
参数4:y方向终止大小(0.2f表示原图的0.2倍)
参数5:缩放中心点x轴取值的参照方式
参数6:中心点x轴的取值(0.5f表示相对与原图的0.5倍)
参数7:缩放中心点y轴取值参照方式
参数8:中心点y轴的取值(0.5f表示相对与原图的0.5倍)
(注:参照方式:Animation.RELATIVE_TO_SELF:自身   Animation.RELATIVE_TO_PARENT:父控件   Animation.ABSOLUTE:绝对)
imageView.startAnimation(animation);
1.5 共有属性
 
android:duration(播放时间)
android:repeatCount: 重复的次数  默认值是0 代表旋转1次,值为-1或者infinite时,表示动画永不停止  
android:repeatMode:  设置重复的模式。默认是restart。(当repeatCount的值大于0或者为infinite时才有效) 
                     设成reverse,表示偶数次显示动画时会做与动画文件定义的方向相反的方向动行。  
对应代码方法:
Animation.setDuration(long durationMillis)
Animation.setRepeatCount(int repeatCount)
Animation.setRepeatMode(int repeatMode)

android:interpolator(动画的渲染器)
  accelerate_interpolator(动画加速器) 使动画在开始的时候 最慢,然后逐渐加速 
  decelerate_interpolator(动画减速器) 使动画在开始的时候 最快,然后逐渐减速 
  accelerate_decelerate_interpolator(动画加速减速器)慢到快(中间位置最快)到慢
  anticipate_interpolator(动画前反向器) 先往动画移动的反方向移动一点然后在沿着设定的动画移动
  overshoot_interpolator(动画后反向器) 最后超出目的值然后缓慢改变到目的值
  anticipate_overshoot_interpolator (动画双反向器) 先往动画的反方向移动一点,然后沿着设定的方向移动到终点之后继续移动一点然后在回弹到最终设定的位置
  bounce_interpolator(动画弹跳器) 快到目的值时值会跳跃
  cycle_interpolator(动画循环器) 动画循环一定次数
  linear_interpolator(动画匀速器) 线性均匀改变
  overshoot_interpolator(动画减速器) 快速到达终点并超出一小步最后回到终点
 使用:android:interpolator="@android:anim/accelerate_interpolator"

对应代码方法:

Animation.setInterpolator(Context context, int resID) //R.anim.accelerate_interpolator
Animation.setInterpolator(Interpolator i) 
  TimeInterpolator          一个接口,允许你自定义interpolator,以下几个都是实现了这个接口
  AccelerateInterpolator        加速,开始时慢中间加速
  DecelerateInterpolator        减速,开始时快然后减速
  AccelerateDecelerateInterolator   先加速后减速,开始结束时慢,中间加速
  AnticipateInterpolator       反向 ,先向相反方向改变一段再加速播放
  AnticipateOvershootInterpolator   反向加超越,先向相反方向改变,再加速播放,会超出目的值然后缓慢移动至目的值
  BounceInterpolator          跳跃,快到目的值时值会跳跃,如目的值100,后面的值可能依次为85,77,70,80,90,100
  CycleInterpolator          循环,动画循环一定次数,值的改变为一正弦函数:Math.sin(2 * mCycles * Math.PI * input)
  LinearInterpolator         线性,线性均匀改变
 OvershootInterpolator       超越,最后超出目的值然后缓慢改变到目的值
2.组合动画

xml定义:

<set xmlns:android="http://schemas.android.com/apk/res/android"  
    android:interpolator="@android:anim/accelerate_decelerate_interpolator"  
    android:shareInterpolator="true" >  
    <scale  ... />  
    <rotate ...  />  
    <translate ...  />  
    <alpha ...  />  
<!--   
 shareInterpolator:里面动画效果是否共享一个Interpolator
 不共享设置android:shareInterpolator="false",每一个动画效果自己添加interpolator。
 -->
</set>

代码实现:

AlphaAnimation alpha=new AlphaAnimation(0, 1);  
alpha.setDuration(1000); 
alpha.setStartOffset(1000); //延时一秒后播放
AnimationSet animSet = new AnimationSet(false);
animSet.addAnimation(alpha);
animSet.cancel();//取消动画
animSet.reset();//释放资源

2.2 LayoutAnimation(GridLayoutAnimationController)

xml定义:

<?xml version="1.0" encoding="utf-8"?>  
<layoutAnimation  
    xmlns:android="http://schemas.android.com/apk/res/android"  
    android:delay="0.5"  
    android:animationOrder="normal"  
    android:animation="@anim/alpha"  
    />  
<!--   
 delay:延迟多少开始播放
 -->

代码实现:

AlphaAnimation alpha=new AlphaAnimation(0, 1);  
alpha.setDuration(1000);  
LayoutAnimationController lac=new LayoutAnimationController(alpha);  
lac.setOrder(LayoutAnimationController.ORDER_NORMAL);  
ListView.setLayoutAnimation(lac); 
LayoutAnimationController.ORDER_NORMAL;    //顺序显示
LayoutAnimationController.ORDER_REVERSE;   //反显示
LayoutAnimationController.ORDER_RANDOM     //随机显示

使用:

<ListView  
        android:id="@+id/listView1"  
        android:layout_width="fill_parent"  
        android:layout_height="wrap_content"         
    android:layoutAnimation="@anim/layoutanimation"/>

2.逐帧动画 Drawable Animation(Frame Animation)
xml定义:

<animation-list xmlns:android="http://schemas.android.com/apk/res/android"  
    android:oneshot="true">  
    <item android:drawable="@drawable/girl1" android:duration="100" />  
    <item android:drawable="@drawable/girl2" android:duration="100" />  
    <item android:drawable="@drawable/girl3" android:duration="100" />  
<!--   
 oneshot:如果为true,表示动画只播放一次停止在最后一帧上,如果设置为false表示动画循环播放
 -->
</animation-list>

代码实现:

AnimationDrawable anim = new AnimationDrawable();  
for (int i = 1; i <= 3; i++) {  
    int id = getResources().getIdentifier("girl" + i, "drawable", getPackageName());  
    Drawable drawable = getResources().getDrawable(id);  
    anim.addFrame(drawable, 100);  
}

播放

View.setBackgroundResource(R.anim.frame);  // 可以在xml里直接@drawble/
AnimationDrawable anim = (AnimationDrawable) image.getBackground();  
anim.start();  
注:想activity一开始就播放请放在onWindowFocusChanged方法里
View.setBackgroundResource(R.anim.frame);  // 可以在xml里直接@drawble/
AnimationDrawable anim = (AnimationDrawable) image.getBackground();  
anim.start();  
注:想activity一开始就播放请放在onWindowFocusChanged方法里

动画恢复到第一帧动画: anim.selectDrawable(0); //选择当前动画的第一帧,然后停止 anim.stop();

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容