Android移动view动画问题
16lz
2022-06-09
Android写动画效果不是一般的麻烦,网上找了好久,终于解决了动画的问题,总结记录以共勉。 仅以水平方向移动效果做说明,垂直方向类似。
2TranslateAnimationanimation= newTranslateAnimation(p1,p2,0,0);
3animation.setInterpolator( newOvershootInterpolator());
4animation.setDuration(durationMillis);
5animation.setStartOffset(delayMillis);
6animation.setAnimationListener( newAnimation.AnimationListener(){
7@Override
8 public voidonAnimationStart(Animationanimation){
9}
10
11@Override
12 public voidonAnimationRepeat(Animationanimation){
13}
14
15@Override
16 public voidonAnimationEnd(Animationanimation){
17 intleft=view.getLeft()+( int)(p2-p1);
18 inttop=view.getTop();
19 intwidth=view.getWidth();
20 intheight=view.getHeight();
21view.clearAnimation();
22view.layout(left,top,left+width,top+height);
23}
24});
25view.startAnimation(animation);
26} 调用示例: 移动到目标位置 slideview(0, distance); 从目标位置移回原位
2animation.setInterpolator( newOvershootInterpolator());
3animation.setDuration(durationMillis);
4animation.setStartOffset(delayMillis);
5view.startAnimation(animation);
2@Override
3 public voidonAnimationStart(Animationanimation){
4}
5
6@Override
7 public voidonAnimationRepeat(Animationanimation){
8}
9
10@Override
11 public voidonAnimationEnd(Animationanimation){
12 intleft=view.getLeft()+( int)(p2-p1);
13 inttop=view.getTop();
14 intwidth=view.getWidth();
15 intheight=view.getHeight();
16view.clearAnimation();
17view.layout(left,top,left+width,top+height);
18}
19});
完整动画函数代码:
1 public voidslideview( final floatp1, final floatp2){2TranslateAnimationanimation= newTranslateAnimation(p1,p2,0,0);
3animation.setInterpolator( newOvershootInterpolator());
4animation.setDuration(durationMillis);
5animation.setStartOffset(delayMillis);
6animation.setAnimationListener( newAnimation.AnimationListener(){
7@Override
8 public voidonAnimationStart(Animationanimation){
9}
10
11@Override
12 public voidonAnimationRepeat(Animationanimation){
13}
14
15@Override
16 public voidonAnimationEnd(Animationanimation){
17 intleft=view.getLeft()+( int)(p2-p1);
18 inttop=view.getTop();
19 intwidth=view.getWidth();
20 intheight=view.getHeight();
21view.clearAnimation();
22view.layout(left,top,left+width,top+height);
23}
24});
25view.startAnimation(animation);
26} 调用示例: 移动到目标位置 slideview(0, distance); 从目标位置移回原位
slideview(0, -distance);
过程中遇到的问题:
1、动画执行完成后,view回到原位
1TranslateAnimationanimation= newTranslateAnimation(p1,p2,0,0);2animation.setInterpolator( newOvershootInterpolator());
3animation.setDuration(durationMillis);
4animation.setStartOffset(delayMillis);
5view.startAnimation(animation);
开始时动画效果只写了这么多,发现动画执行完,view会回到原位。
经过查资料尝试使用animation.setFillAfter(true); view不再返回原位,但又出现了第2个问题
2、点击按钮时,view在初始位置会先闪一下,再执行动画
经过查资料得知,animation.setFillAfter(true); 只是将view移动到了目标位置,但是view绑定的点击事件还在原来位置,导致点击时会先闪一下
又查资料找到解决办法: 不加setFillAfter, 通过设置view位置实现效果,增加如下代码 1animation.setAnimationListener( newAnimation.AnimationListener(){2@Override
3 public voidonAnimationStart(Animationanimation){
4}
5
6@Override
7 public voidonAnimationRepeat(Animationanimation){
8}
9
10@Override
11 public voidonAnimationEnd(Animationanimation){
12 intleft=view.getLeft()+( int)(p2-p1);
13 inttop=view.getTop();
14 intwidth=view.getWidth();
15 intheight=view.getHeight();
16view.clearAnimation();
17view.layout(left,top,left+width,top+height);
18}
19});
在动画执行完毕后(onAnimationEnd)设置view的位置,同时要clearAnimation()
注:clearAnimation() 必须在 layout(l,t,r,b) 前执行,否则会出错~ 至此大功告成~更多相关文章
- android基础之RelativeLayout布局
- android布局动画实现方法
- android四种动画
- Android(安卓)开发笔记 动画效果 --Animation
- Android(安卓)动画显示文字与bitmap的BadgeView
- Android视图绘画与属性动画
- Android(安卓)动画框架(一)转
- Android(安卓)开机震动的调用位置以及打开关闭方法
- Android启动画面实现