Android编程实现3D滑动旋转效果的方法

所属分类: 软件编程 / Android 阅读数: 1926
收藏 0 赞 0 分享

本文实例讲述了Android编程实现3D滑动旋转效果的方法。分享给大家供大家参考,具体如下:

这里我们通过代码实现一些滑动翻页的动画效果。

Animation实现动画有两个方式:帧动画(frame-by-frame animation)和补间动画(tweened animation)

本示例通过继承Animation自定义Rotate3D,实现3D翻页效果。效果图如下:

1、Rotate3D(Animation)

首先,自定义Animation的3D动画类Rotate3D

public class Rotate3D extends Animation { 
  private float fromDegree;  // 旋转起始角度 
  private float toDegree;   // 旋转终止角度 
  private float mCenterX;   // 旋转中心x 
  private float mCenterY;   // 旋转中心y 
  private Camera mCamera; 
  public Rotate3D(float fromDegree, float toDegree, float centerX, float centerY) { 
    this.fromDegree = fromDegree; 
    this.toDegree = toDegree; 
    this.mCenterX = centerX; 
    this.mCenterY = centerY; 
  } 
  @Override 
  public void initialize(int width, int height, int parentWidth, int parentHeight) { 
    super.initialize(width, height, parentWidth, parentHeight); 
    mCamera = new Camera(); 
  } 
  @Override 
  protected void applyTransformation(float interpolatedTime, Transformation t) { 
    final float FromDegree = fromDegree; 
    float degrees = FromDegree + (toDegree - fromDegree) * interpolatedTime;  // 旋转角度(angle) 
    final float centerX = mCenterX; 
    final float centerY = mCenterY; 
    final Matrix matrix = t.getMatrix(); 
    if (degrees <= -76.0f) { 
      degrees = -90.0f; 
      mCamera.save(); 
      mCamera.rotateY(degrees); // 旋转 
      mCamera.getMatrix(matrix); 
      mCamera.restore(); 
    } else if (degrees >= 76.0f) { 
      degrees = 90.0f; 
      mCamera.save(); 
      mCamera.rotateY(degrees); 
      mCamera.getMatrix(matrix); 
      mCamera.restore(); 
    } else { 
      mCamera.save(); 
      mCamera.translate(0, 0, centerX); // 位移x 
      mCamera.rotateY(degrees); 
      mCamera.translate(0, 0, -centerX); 
      mCamera.getMatrix(matrix); 
      mCamera.restore(); 
    } 
    matrix.preTranslate(-centerX, -centerY); 
    matrix.postTranslate(centerX, centerY); 
  } 
}

然后,实例化Rotate3D的旋转方向

public void initAnimation() { 
  // 获取旋转中心 
  DisplayMetrics dm = new DisplayMetrics(); 
  dm = getResources().getDisplayMetrics(); 
  mCenterX = dm.widthPixels / 2; 
  mCenterY = dm.heightPixels / 2; 
  // 定义旋转方向 
  int duration = 1000; 
  lQuest1Animation = new Rotate3D(0, -90, mCenterX, mCenterY);  // 下一页的【question1】旋转方向(从0度转到-90,参考系为水平方向为0度) 
  lQuest1Animation.setFillAfter(true); 
  lQuest1Animation.setDuration(duration); 
  lQuest2Animation = new Rotate3D(90, 0, mCenterX, mCenterY);   // 下一页的【question2】旋转方向(从90度转到0,参考系为水平方向为0度)(起始第一题) 
  lQuest2Animation.setFillAfter(true); 
  lQuest2Animation.setDuration(duration); 
  rQuest1Animation = new Rotate3D(0, 90, mCenterX, mCenterY);   // 上一页的【question1】旋转方向(从0度转到90,参考系为水平方向为0度) 
  rQuest1Animation.setFillAfter(true); 
  rQuest1Animation.setDuration(duration); 
  rQuest2Animation = new Rotate3D(-90, 0, mCenterX, mCenterY);  // 上一页的【question2】旋转方向(从-90度转到0,参考系为水平方向为0度) 
  rQuest2Animation.setFillAfter(true); 
  rQuest2Animation.setDuration(duration); 
}

2、Activity

首先,定义两个布局文件,用于旋转的画面切换

main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:id="@+id/layout_main" 
  android:layout_width="fill_parent" 
  android:layout_height="wrap_content"       
  android:orientation="vertical"> 
... 
</LinearLayout>

next.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:id="@+id/layout_next" 
  android:layout_width="fill_parent" 
  android:layout_height="wrap_content"       
  android:orientation="vertical"> 
... 
</LinearLayout>

限于篇幅,完整布局文件请详见源码 ^_^

然后,初始化两个旋转的布局文件资源

private void initMain(){ 
    setContentView(R.layout.main); 
  layoutmain = (LinearLayout)findViewById(R.id.layout_main); 
  btn_MainLast = (Button)findViewById(R.id.main_last); 
  btn_MainNext = (Button)findViewById(R.id.main_next); 
  btn_MainLast.setOnClickListener(listener); 
  btn_MainNext.setOnClickListener(listener); 
} 
private void initNext(){ 
    setContentView(R.layout.next); 
  layoutnext = (LinearLayout)findViewById(R.id.layout_next); 
  btn_NextLast = (Button)findViewById(R.id.next_last); 
  btn_NextNext = (Button)findViewById(R.id.next_next); 
  btn_NextLast.setOnClickListener(listener); 
  btn_NextNext.setOnClickListener(listener); 
}

最后,设置布局文件中的按钮监听事件,响应3D旋转动画和方向

private View.OnClickListener listener = new View.OnClickListener() { 
  @Override 
  public void onClick(View v) { 
    switch (v.getId()) { 
    case R.id.main_last:  // 上一页 
      layoutmain.startAnimation(lQuest1Animation);  // 当前页向左旋转(0,-90) 
      initNext(); 
      layoutnext.startAnimation(lQuest2Animation);  // 下一页向左旋转(90, 0) 
      break; 
    case R.id.main_next:  // 下一页 
      layoutmain.startAnimation(rQuest1Animation);  // 当前页向右旋转(0,90) 
      initNext(); 
      layoutnext.startAnimation(rQuest2Animation);  // 下一页向右旋转(-90, 0) 
      break; 
    case R.id.next_last: 
      layoutnext.startAnimation(lQuest1Animation); 
      initMain(); 
      layoutmain.startAnimation(lQuest2Animation); 
      break; 
    case R.id.next_next: 
      layoutnext.startAnimation(rQuest1Animation); 
      initMain(); 
      layoutmain.startAnimation(rQuest2Animation); 
      break; 
    } 
  } 
};

完整实例代码代码点击此处本站下载

希望本文所述对大家Android程序设计有所帮助。

更多精彩内容其他人还在看

老生常谈Android HapticFeedback(震动反馈)

下面小编就为大家带来一篇老生常谈Android HapticFeedback(震动反馈)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

详谈OnTouchListener与OnGestureListener的区别

下面小编就为大家带来一篇详谈OnTouchListener与OnGestureListener的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Android仿知乎悬浮功能按钮FloatingActionButton效果

前段时间在看属性动画,恰巧这个按钮的效果可以用属性动画实现,下面通过本文给大家分享adroid仿知乎悬浮功能按钮FloatingActionButton效果,需要的朋友参考下吧
收藏 0 赞 0 分享

解决Android V7后自定义Toolbar、ActionBar左侧有空白问题

这篇文章主要介绍的Android V7后自定义Toolbar、ActionBar左侧有空白问题的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Android常见控件使用详解

这篇文章主要为大家详细介绍了Android常见控件的使用方法,包括ProgressBar进度条控件、AlertDialog对话框控件等,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android实现简洁的APP更新dialog数字进度条

这篇文章主要为大家详细介绍了Android实现简洁的APP更新dialog数字进度条,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android 判断当前语言环境是否是中文环境

本文主要介绍了Android 判断当前语言环境是否是中文环境的方法。具有很好的参考价值。下面跟着小编一起来看下吧
收藏 0 赞 0 分享

详谈Android中Matrix的set、pre、post的区别

下面小编就为大家带来一篇详谈Android中Matrix的set、pre、post的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Android实现登录界面记住密码的存储

这篇文章主要为大家详细介绍了Android SharedPreferrences实现登录界面记住密码的存储,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android 使用SharedPreferrences储存密码登录界面记住密码功能

Android存储方式有很多种,在这里所用的存储方式是SharedPreferrences, 其采用了Map数据结构来存储数据,以键值的方式存储,可以简单的读取与写入,下面通过实例代码给大家讲解下,需要的朋友参考下吧
收藏 0 赞 0 分享
查看更多