动态写Animation,注:Animation并不会真正移动控件,需要调用onAnimationEnd

http://blog.163.com/zhuowh2006@126/blog/static/101823724201272034121383/

源地址,感觉自己以后会遇到类似问题,先MARK,方便以后查阅、。

 

android不用xml文件,

 

android不用xml文件,动态写Animation

// 移动animation
 public static void Translate(View view, float fromX, float toX, float fromY,
   float toY, long durationMillis) {
  as = new AnimationSet(true);
  TranslateAnimation ta = new TranslateAnimation(fromX, toX, fromY,
    toY);
  ta.setFillAfter(true);
  ta.setFillBefore(false);
  ta.setDuration(durationMillis);
  as.addAnimation(ta);
  as.setFillAfter(true);
  as.setFillBefore(false);
  view.startAnimation(as);
 }

 

今天在使用TranslateAnimation位移一个LinearLayout时,发现动画完成后又会自动回到初始的状态,设置了fillAfter也不太管用。

在网上搜了一圈,发现:

这种现象很正常,因为TranslateAnimation只负责实现位移动画效果,并不会真正的改变LinearLayout的位置,所以需要加一个AnimationListener ,在动画结束(onAnimationEnd() )后,通过设置LayoutParam里相关属性来改变LinearLayout位置才行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值