原来PATH的菜单效果如此简单。布局+TranslateAnimation搞定

本文介绍了如何使用TranslateAnimation实现视图的移动动画,并详细解析了Interpolator的作用及多种类型,如OvershootInterpolator和BounceInterpolator等,以实现不同的动画效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.png

                      (效果图)

原理:
点击红色加号触发事件:

public static void startAnimationsIn(ViewGroup viewgroup,int durationMillis) {
  for (int i = 0; i < viewgroup.getChildCount(); i++) {
    ImageButton inoutimagebutton = (ImageButton) viewgroup
      .getChildAt(i);
    inoutimagebutton.setVisibility(0);
    MarginLayoutParams mlp = (MarginLayoutParams) inoutimagebutton.getLayoutParams();
    Animation animation = new TranslateAnimation(mlp.rightMargin-xOffset,0F,yOffset + mlp.bottomMargin, 0F);
//这个地方就是相对和绝对位置的区别,其实还有4个参数没有显示出来,但是她会根据单位自动识别。原句应该是:
//new TranslateAnimation(Animation.ABSOLUTE,mlp.rightMargin - xOffset, Animation.RELATIVE_TO_SELF,0F,Animation.ABSOLUTE, yOffset + mlp.bottomMargin, Animation.RELATIVE_TO_SELF,0F);
   
    animation.setFillAfter(true);animation.setDuration(durationMillis);
    animation.setStartOffset((i * 100)
      / (-1 + viewgroup.getChildCount()));
    animation.setInterpolator(new OvershootInterpolator(2F));
    inoutimagebutton.startAnimation(animation);
   
  }
}
 
发生移动动画出现。隐藏即为
Animation animation = new TranslateAnimation(0F,mlp.rightMargin-xOffset, 0F,yOffset + mlp.bottomMargin);



值得一提的是 interpolator的使用,PATH中使用了OvershootInterpolator以及AnticipateInterpolator。
    interpolator 被用来修饰动画效果,定义动画的变化率,可以使存在的动画效果可以 accelerated(加速),decelerated(减速),repeated(重复),bounced(弹跳)等。
AccelerateDecelerateInterpolator 在动画开始与介绍的地方速率改变比较慢,在中间的时候加速
AccelerateInterpolator  在动画开始的地方速率改变比较慢,然后开始加速
AnticipateInterpolator 开始的时候向后然后向前甩
AnticipateOvershootInterpolator 开始的时候向后然后向前甩一定值后返回最后的值
BounceInterpolator   动画结束的时候弹起
CycleInterpolator 动画循环播放特定的次数,速率改变沿着正弦曲线
DecelerateInterpolator 在动画开始的地方快然后慢
LinearInterpolator   以常量速率改变
OvershootInterpolator    向前甩一定值后再回到原来位置


下面是主要动画类的链接http://code.google.com/p/liyoroopensource/source/browse/trunk/Rotate3D/src/cy/test/rotate3d/MyAnimations.java?r=135


下面上一下源码http://download.csdn.net/detail/shenyongjun1209/5352786



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值