makeAnim 3 渐渐消失效果");// alphaAnimation = new AlphaAnimation(1.0f, 0.2f);// alphaAnimation.setDuration(2000);// imageView.startAnimation(alphaAnimation); animation = AnimationUtils.loadAnimation(this, R.anim.anim_test4); imageView.startAnimation(animation); break; } }}登录后复制 以平移动画为例 先构建TranslateAnimation 对象 TranslateAnimation translateAnimation; 初始化他的一些位置参数translateAnimation = new TranslateAnimation(0, 200, 0, 50); 设置运行时间translateAnimation.setDuration(2000); 让应该动的控件动起来,然后结束之后回到原位“`imageView.startAnimation(translateAnimation); 再来解释下,这些对象的构造函数 TranslateAnimation(Context context, AttributeSet attrs) TranslateAnimation(float fromXDelta, float toXDelta, float fromYDelta, float toYDelta) float fromXDelta:这个参数表示动画开始的点离当前View X坐标上的差值; float toXDelta, 这个参数表示动画结束的点离当前View X坐标上的差值; float fromYDelta, 这个参数表示动画开始的点离当前View Y坐标上的差值; float toYDelta)这个参数表示动画开始的点离当前View Y坐标上的差值; TranslateAnimation(int fromXType, float fromXValue, int toXType, float toXValue, int fromYType, float fromYValue, int toYType, float toYValue) 我们最常用的一个 fromXType:第一个参数是x轴方向的值的参照(Animation.ABSOLUTE,Animation.RELATIVE_TO_SELF,or Animation.RELATIVE_TO_PARENT); fromXValue:第二个参数是第一个参数类型的起始值; toXType,toXValue:第三个参数与第四个参数是x轴方向的终点参照与对应值; 后面四个参数就不用解释了。如果全部选择Animation.ABSOLUTE,其实就是第二个构造函数。 RotateAnimation(Context context, AttributeSet attrs) RotateAnimation(float fromDegrees, float toDegrees) 第一个参数fromDegrees为动画起始时的旋转角度 此角度是当前为0及360,设置其他值则先跳至该角度的位置再由from - to的值: 负则正向转,正则反向转 第二个参数toDegrees为动画旋转到的角度 RotateAnimation(float fromDegrees, float toDegrees, float pivotX, float pivotY) 第三个参数pivotXType为动画在X轴相对于物件位置类型 第四个参数pivotXValue为动画相对于物件的X坐标的开始位置 此值是以本身原始位置为原点,即如设为20%p,则向右移动父控件的20%位移,为负数则向左移 RotateAnimation(float fromDegrees, float toDegrees, int pivotXType, float pivotXValue, int pivotYType, float pivotYValue) 第五个参数pivotXType为动画在Y轴相对于物件位置类型 第六个参数pivotYValue为动画相对于物件的Y坐标的开始位置 此值是以本身原始位置为原点,即如设为20%p,则向下移动父控件的20%位移,为负数则向上移 ScaleAnimation(Context context, AttributeSet attrs) ScaleAnimation(float fromX, float toX, float fromY, float toY) 第一个参数fromX为动画起始时 X坐标上的伸缩尺寸 0.0表示收缩到没有 第二个参数toX为动画结束时 X坐标上的伸缩尺寸 1.0表示正常无伸缩 第三个参数fromY为动画起始时Y坐标上的伸缩尺寸 值小于1.0表示收缩 第四个参数toY为动画结束时Y坐标上的伸缩尺寸 值大于1.0表示放大 ScaleAnimation(float fromX, float toX, float fromY, float toY, float pivotX, float pivotY) 第五个参数pivotXType为动画在X轴相对于物件位置类型 第六个参数pivotXValue为动画相对于物件的X坐标的开始位置 ScaleAnimation(float fromX, float toX, float fromY, float toY, int pivotXType, float pivotXValue, int pivotYType, float pivotYValue) 第七个参数pivotXType为动画在Y轴相对于物件位置类型 第八个参数pivotYValue为动画相对于物件的Y坐标的开始位置 AlphaAnimation(float fromAlpha, float toAlpha) 第一个参数fromAlpha为 动画开始时候透明度 0.0表示完全透明 第二个参数toAlpha为 动画结束时候透明度 1.0表示完全不透 基本上构造函数传完参设置个持续时间然后,start一下就OK了,非常简便。 提一下,这里面的一些坑 我们的缩放动画,一般都是左上角开始的,当然你想改,可以传参状态,有以下三个 Animation.ABSOLUTE(默认值) 相对于控件的0点的坐标值Animation.RELATIVE_TO_SELF相对于自己宽或者高的百分比(1.0表示100%)Animation.RELATIVE_TO_PARENT相对于父控件的宽或者高的百分比.登录后复制 还有旋转也是,以左上角为起始点,如果要更改记得设置 那么再说下用XML的怎么做 首先你要在anim目录下建一个xml,我的例子里是像 anim_test1.xml这样的文件,然后你要把动画预设在XML里配置下即可 登录后复制 命名规则和前面的构造函数完全一致,猜也猜的出来就不多解释了。 然后这一类的xml比java代码多一些xml的标签 android:detachWallpaperandroid:durationandroid:fillAfterandroid:fillBeforeandroid:fillEnabledandroid:interpolatorandroid:repeatCountandroid:repeatMode INFINTE(无限期),RESTART(重新开始,默认值)android:startOffsetandroid:zAdjustment ZORDER_BOTTOM,ZORDER_NORMAL, ZORDER_TOP登录后复制 这部分会在讲Property Animation时再加以解释。 那如何用XML内容来实现动画呢? 拿渐变动画为例 首先构造一个Animation对象 Animation animation 然后给它绑一个anim的XML animation = AnimationUtils.loadAnimation(this, R.anim.anim_test4);登录后复制 然后让我们需要动的部分start一下imageView.startAnimation(animation); 跟java代码实现的也是一模一样。 是不是 SO EASY,这部分基础的只要熟悉一些参数和内容的意思效果就很容易实现。 推荐一些资料: 源码地址:https://github.com/ddwhan0123/BlogSample/blob/master/ViewAnimDemo.zip 记得点个赞哦 09-18 19:35