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

 更新时间:2017年12月29日 10:18:01   作者:郑海波  
这篇文章主要为大家详细介绍了android使用FlipAnimation实现3D垂直翻转动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

需求

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

解决

各种Animator的组合

第一步动画:

动画代码文件1,card_flip_left_out.xml

 <?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

<?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代码啦,在第一个动画结束的时候,换图。

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();
 }

}


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

相关文章

  • Android自定义view渐变圆形动画

    Android自定义view渐变圆形动画

    这篇文章主要为大家详细介绍了Android自定义view渐变圆形动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • Android简单实现计算器功能

    Android简单实现计算器功能

    这篇文章主要为大家详细介绍了Android简单实现计算器功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • 详解Android的网络数据存储

    详解Android的网络数据存储

    LeanCloud是一种简单高效的数据和文件存储服务,本文主要介绍了利用LeanCloud来进行网络数据的存储的实现方法。具有很好的参考价值,需要的朋友一起来看下吧
    2016-12-12
  • Android图片性能优化详解

    Android图片性能优化详解

    这篇文章给大家分享了关于Android性能优化之图片优化的相关知识点内容,有兴趣的朋友参考下。
    2018-07-07
  • 浅析安卓(Android)的性能优化

    浅析安卓(Android)的性能优化

    性能优化是一个大的范畴,如果有人问你在Android中如何做性能优化的,也许都不知道从哪开始说起。那么这篇文章我们从布局优化和内存优化两个方面来展开说如何进行Android的性能优化。
    2016-08-08
  • sqlite查询结果在listview中展示的实现

    sqlite查询结果在listview中展示的实现

    下面小编就为大家带来一篇sqlite查询结果在listview中展示的实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Android工具栏顶出转场动画的实现方法实例

    Android工具栏顶出转场动画的实现方法实例

    这篇文章主要给大家介绍了关于Android工具栏顶出转场动画的实现方法,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-09-09
  • Android辅助功能实现自动抢红包(附源码)

    Android辅助功能实现自动抢红包(附源码)

    本篇文章主要介绍了Android辅助功能实现自动抢红包(附源码),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • 基于Android的服务器端程序实例

    基于Android的服务器端程序实例

    这篇文章主要介绍了基于Android的服务器端程序实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Android SearchView搜索控件使用方法详解

    Android SearchView搜索控件使用方法详解

    这篇文章主要为大家详细介绍了Android SearchView搜索控件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04

最新评论