Android属性动画简单实现图片的伸缩
2017-10-25 09:33
441 查看
![这里写图片描述](http://img.blog.csdn.net/20171025154711043?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMzk2OTgxNTI=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast) 代码如下 private int a=0; private ObjectAnimator animator; private ObjectAnimator fanimator; private ObjectAnimator animator1; private ObjectAnimator fanimator1; private ObjectAnimator animator2; private ObjectAnimator fanimator2; private ObjectAnimator animator3; private ObjectAnimator fanimator3; //-----伸出时的动画 animator = ObjectAnimator.ofFloat(icon, "rotation", 0f, 180f); animator1 = ObjectAnimator.ofFloat(gt, "translationX", 0f,-80f); animator2 = ObjectAnimator.ofFloat(copy, "translationX", 0f,-160f); animator3 = ObjectAnimator.ofFloat(xg, "translationX", 0f,-240f); //----缩回时的动画 fanimator = ObjectAnimator.ofFloat(icon, "rotation", 0f, -180f); fanimator1 = ObjectAnimator.ofFloat(gt, "translationX", -80f,0f); fanimator2 = ObjectAnimator.ofFloat(copy, "translationX", -160f,0f); fanimator3 = ObjectAnimator.ofFloat(xg, "translationX", -240f,0f); //------- 这里的icon gt copy xg.是我的图片id icon = (ImageView) findViewById(R.id.icon); gt = (ImageView) findViewById(R.id.gt); copy = (ImageView) findViewById(R.id.copy); xg = (ImageView) findViewById(R.id.xg); 注意一下图片是要重合在一起,一个压一个 -//// //给伸出动画设置监听 animator.addListener(new Animator.AnimatorListener() { @Override public void onAnimationStart(Animator animator) { } @Override public void onAnimationEnd(Animator animator) { icon.setImageResource(R.drawable.icon_packup);//动画结束改变图片 } @Override public void onAnimationCancel(Animator animator) { } @Override public void onAnimationRepeat(Animator animator) { } }); //给缩回动画设置监听 fanimator.addListener(new Animator.AnimatorListener() { @Override public void onAnimationStart(Animator animator) { } @Override public void onAnimationEnd(Animator animator) { icon.setImageResource(R.drawable.icon_open);//改变图片 } @Override public void onAnimationCancel(Animator animator) { } @Override public void onAnimationRepeat(Animator animator) { } }); icon.setOnClickListener(new View.OnClickListener() {//图片的点击事件 @Override public void onClick(View view) { a++; if(a%2==1){//第一次点击是实现伸出效果 AnimatorSet animSet = new AnimatorSet();//动画集合 animSet.play(animator).with(animator1).with(animator2).with(animator3); animSet.setDuration(1000); animSet.start(); }else{//再点击一次实现缩回效果 AnimatorSet animSet1 = new AnimatorSet();//动画集合 animSet1.play(fanimator).with(fanimator1).with(fanimator2).with(fanimator3); animSet1.setDuration(1000); animSet1.start(); } } });
相关文章推荐
- Android属性动画简单实现图片的伸缩
- Android 仿QQ菜单背景图片的左右上下移动属性动画实现
- Android简单用属性动画实现两个控件重叠
- Android用两张图片实现简单动画效果
- Android逐帧动画、属性动画的简单实现
- Android开发中 简单实现属性动画
- android,侧滑栏SlidingLayout、ViewPager实现画廊、简单用viewpager实现画廊、圆形图片、简单的跑马灯动画效果、可拖拽的弹簧式水泡动画集合
- android 简单图片动画播放实现
- Android 属性动画实现一个简单的PopupWindow
- Android中一个视图弹出动画的简单实现
- 【Android游戏开发十六】Android Gesture之【触摸屏手势识别】操作!利用触摸屏手势实现一个简单切换图片的功能!
- android 简单实现获取网络图片
- 实现Android简单动画旋转案例
- Android Graphics 学习(1)----播放gif动画简单的实现
- Android Tween动画之RotateAnimation实现图片不停旋转
- 实现Android简单动画旋转案例
- Android Tween动画之RotateAnimation实现图片不停旋转
- (android控件)巧用background属性,实现图片可选择效果
- 【Android游戏开发十六】Android Gesture之【触摸屏手势识别】操作!利用触摸屏手势实现一个简单切换图片的功能!
- Android Tween动画之RotateAnimation实现图片不停旋转