少年郎,是时候打造自己的第一款狂拽酷炫的3D效果了!

移动开发 Android
Android中有两个Camera类。一个是android.hardware.Camera,用于对设备的摄像头进行操作。另一个是android.graphics.Camera,可用于进行3D变换,然后把变换后的矩阵Matrix作用于Canvas等,我们本篇要介绍的就是这个Camera类。

背景介绍

Android中有两个Camera类。一个是android.hardware.Camera,用于对设备的摄像头进行操作。另一个是android.graphics.Camera,可用于进行3D变换,然后把变换后的矩阵Matrix作用于Canvas等,我们本篇要介绍的就是这个Camera类。

玩转Camera

前面我们提到过,Camera是一个能够进行3D变化的类,在进行玩3D变换后,我们能够通过mCamera.getMatrix(Matrix)把变换矩阵Matrix赋值,然后可以用在Canvas上。或者,你可以直接通过mCamera.applyToCanvas(Canvas)直接把变换作用到一个Canvas上。

Android中的三维坐标轴

Android中的三维坐标轴符合左手坐标系。 

 

 

 

Camera默认的位置是在(0, 0, -8)点。

Camera的变换操作 

方法 说明
getMatrix(mMatrix) 给mMatrix赋值。
applyToCanvas(mCanvas) 将变换获得的Matrix直接作用到mCanvas上。
rotate(x,y,z) 旋转。
rotateX、rotateY、rotateZ 旋转。
getLocationX、getLocationY、getLocationZ 获得Camera的位置,默认是在(0,0,-8)点。
setLocation(x,y,z) 设置camera的位置。
translate(x,y,z) 平移Camera。
save() 与Canvas的类似。
restore() 与Canvas类似。

Camera的方法并不多,所以使用起来也是比较简单明了的。

Camera的使用实例

由于使用Camera的核心就是获得一个变换后的Matrix,所以你需要对Matrix具有一定的认识。

演示Demo1 

 

 

 

3D ViewGroup演示 

 

 

 

Camera用于自定义动画

直接上个代码实例,用法和前面的例子没什么本质区别,都是通过Camera变换之后获得Matrix矩阵。

  1. public class Custom3DAnimation extends Animation { 
  2.  
  3.  
  4.     private Camera mCamera; 
  5.  
  6.     private int centerWidth; 
  7.  
  8.     private int centerHeight; 
  9.  
  10.  
  11.     public void setmRotateY(float mRotateY) { 
  12.  
  13.         this.mRotateY = mRotateY; 
  14.  
  15.     } 
  16.  
  17.  
  18.     private float mRotateY; 
  19.  
  20.  
  21.     public Custom3DAnimation() { 
  22.  
  23.         mCamera = new Camera(); 
  24.  
  25.         mRotateY = 90; 
  26.  
  27.     } 
  28.  
  29.  
  30.     @Override 
  31.  
  32.     protected void applyTransformation(float interpolatedTime, Transformation t) { 
  33.  
  34.                 Matrix matrix = t.getMatrix();  //获得Transformation的Matrix 
  35.  
  36.                 mCamera.save();//保存当前镜头状态 
  37.  
  38.         mCamera.rotateY(mRotateY * interpolatedTime); //使相机旋转 
  39.  
  40.         mCamera.getMatrix(matrix); //将旋转变换作用到matrix上 
  41.  
  42.         mCamera.restore(); //合并镜头层 
  43.  
  44.         matrix.preTranslate(centerWidth, centerHeight);//操作前平移 
  45.  
  46.         matrix.postTranslate(-centerWidth, -centerHeight); //操作后平移 
  47.  
  48.  
  49.     } 
  50.  
  51.  
  52.     @Override 
  53.  
  54.     public void initialize(int width, int height, int parentWidth, int parentHeight) { 
  55.  
  56.         super.initialize(width, height, parentWidth, parentHeight); 
  57.  
  58.                 setDuration(5 * 1000); //设置默认持续时间 
  59.  
  60.         setFillAfter(true); //设置动画结束后是否保持状态 
  61.  
  62.         setInterpolator(new LinearInterpolator()); //设置插值器 
  63.  
  64.         centerWidth = width / 2; 
  65.  
  66.                 centerHeight = height / 2; 
  67.  
  68.     } 
  69.  
  70.  

总结

Camera的使用其实并不复杂,只需要记住前面提到的几个方法就行。由于Camera最终是输出一个矩阵,所以还需要对矩阵有一定的掌握。上面我已经给出了矩阵快速使用的指南,大家可以根据情况自行参考。

责任编辑:庞桂玉 来源: 安卓巴士Android开发者门户
相关推荐

2023-09-01 09:30:22

Three.js3D 图形库

2017-07-11 15:00:04

前端CSS3D视角

2021-06-18 05:59:37

Css前端CSS 特效

2013-10-15 10:29:44

天天酷跑手游

2021-06-09 08:30:52

CSS33D旋转视图3D动画

2021-01-05 08:10:00

Css前端3D旋转透视

2023-08-04 09:56:15

2024-03-01 09:12:01

2023-03-29 23:40:24

2015-09-08 10:44:15

MIAOW图形处理器开源

2009-03-24 08:41:45

Dell智能手机移动OS

2012-04-04 12:40:37

HTC

2009-07-14 13:28:56

SketchFlow原型设计工具Expression

2022-02-20 14:45:33

3D动画CSS3前端

2024-02-26 12:02:37

Python数据可视化D3blocks

2015-01-19 17:44:02

Cocos引擎3D特效

2013-03-08 17:28:53

飞鱼星企业级路由器移动互联网

2011-09-16 14:55:47

HTML 5
点赞
收藏

51CTO技术栈公众号