前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >android使用FlipAnimation实现3D垂直翻转动画

android使用FlipAnimation实现3D垂直翻转动画

作者头像
砸漏
发布2020-10-29 23:11:53
1.3K0
发布2020-10-29 23:11:53
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本

本文实例为大家分享了android实现3D垂直翻转动画的具体代码,供大家参考,具体内容如下

需求

对ImageView进行类似于翻纸牌的动画

解决

各种Animator的组合

第一步动画:

动画代码文件1,card_flip_left_out.xml

代码语言:javascript
复制
 <?xml version="1.0" encoding="utf-8"? 
 <set xmlns:android="http://schemas.android.com/apk/res/android"  
 <!-- 先缩小 -- 
 <objectAnimator
  android:duration="200"
  android:propertyName="scaleX"
  android:valueFrom="1.0"
  android:valueTo="0.8" / 
 <objectAnimator
  android:duration="200"
  android:propertyName="scaleY"
  android:valueFrom="1.0"
  android:valueTo="0.8" / 
 <!-- 再旋转 -- 
 <objectAnimator
  android:duration="@integer/card_flip_time_full"
  android:interpolator="@android:interpolator/accelerate_decelerate"
  android:propertyName="rotationY"
  android:startOffset="200"
  android:valueFrom="0"
  android:valueTo="90" / 
 <!-- 同时透明度变化 -- 
 <objectAnimator
  android:duration="@integer/card_flip_time_full"
  android:propertyName="alpha"
  android:startOffset="200"
  android:valueFrom="1.0"
  android:valueTo="0.0" / 
 </set 

第二步动画

动画文件2:card_flip_left_out

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"? 
<set xmlns:android="http://schemas.android.com/apk/res/android"  
 <!-- 立即设置为透明 -- 
 <objectAnimator
  android:duration="0"
  android:propertyName="alpha"
  android:valueFrom="1.0"
  android:valueTo="0.0" / 
 <!-- 旋转 -- 
 <objectAnimator
  android:duration="@integer/card_flip_time_full"
  android:interpolator="@android:interpolator/accelerate_decelerate"
  android:propertyName="rotationY"
  android:valueFrom="-90"
  android:valueTo="0" / 
 <!-- 旋转一半的时间,逐渐显示 -- 
 <objectAnimator
  android:duration="1"
  android:propertyName="alpha"
  android:startOffset="@integer/card_flip_time_half"
  android:valueFrom="0.0"
  android:valueTo="1.0" / 
 <!-- 最后放大 -- 
 <objectAnimator
  android:duration="200"
  android:propertyName="scaleX"
  android:startOffset="@integer/card_flip_time_full"
  android:valueFrom="0.8"
  android:valueTo="1.0" / 
 <objectAnimator
  android:duration="200"
  android:propertyName="scaleY"
  android:startOffset="@integer/card_flip_time_full"
  android:valueFrom="0.8"
  android:valueTo="1.0" / 
</set 

下面就是写java代码啦,在第一个动画结束的时候,换图。

代码语言:javascript
复制
package com.example.android.animationsdemo;
import android.animation.Animator;
import android.animation.AnimatorInflater;
import android.animation.AnimatorListenerAdapter;
import android.animation.AnimatorSet;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageView;

/**
 * @date 2015年3月18日 下午2:28:33
 * @author Zheng Haibo
 * @Description: 图片的翻转动画
 */
public class ImageFlipActivity extends Activity {

 private ImageView imageView;
 private int clickCount = 0;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_image_flip);
  imageView = (ImageView) findViewById(R.id.iv_show);

  imageView.setOnClickListener(new OnClickListener() {

   @Override
   public void onClick(View v) {
    playFlipAnimation2();
   }

  });
 }

 private void playFlipAnimation2() {
  clickCount++;
  AnimatorSet animatorSetOut = (AnimatorSet) AnimatorInflater
    .loadAnimator(this, R.animator.card_flip_left_out);

  final AnimatorSet animatorSetIn = (AnimatorSet) AnimatorInflater
    .loadAnimator(this, R.animator.card_flip_left_in);

  animatorSetOut.setTarget(imageView);
  animatorSetIn.setTarget(imageView);

  animatorSetOut.addListener(new AnimatorListenerAdapter() {

   @Override
   public void onAnimationEnd(Animator animation) {// 翻转90度之后,换图
    if (clickCount % 2 == 0) {
     imageView.setImageResource(R.drawable.image1);
    } else {
     imageView.setImageResource(R.drawable.image2);
    }
    animatorSetIn.start();
   }
  });

  animatorSetIn.addListener(new AnimatorListenerAdapter() {

   @Override
   public void onAnimationEnd(Animator animation) {
    // TODO
   }
  });
  animatorSetOut.start();
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com