【Android】Matrix

Android里面使用Matrix来实现图片的旋转,平移,放缩以及图片颜色的改变等等功能。Matrix(矩阵)是数学概念,在Android中,Matrix是由9个float组成的:

这9个float可以实现上面所说的旋转,平移和缩放功能,其中: 

1)sinX 和 cosX:表示旋转角度的 cos 值和 sin 值,注意,旋转角度是按顺时针方向计算的;

2)translateX 和 translateY 表示 x 和 y 的平移量;

3)scale 是缩放的比例, 1 是不变, 2 是表示缩放 1/2;

这几个值是可以通过函数Matrix.geValues()取出来的返回值是一个float [9]数组,具体如下:

public static final int MPERSP_0 Constant Value: 6 (0x00000006)
public static final int MPERSP_1 Constant Value: 7 (0x00000007)
public static final int MPERSP_2 Constant Value: 8 (0x00000008)
public static final int MSCALE_X Constant Value: 0 (0x00000000)
public static final int MSCALE_Y Constant Value: 4 (0x00000004)
public static final int MSKEW_X Constant Value: 1 (0x00000001)
public static final int MSKEW_Y Constant Value: 3 (0x00000003)
public static final int MTRANS_X Constant Value: 2 (0x00000002)
public static final int MTRANS_Y Constant Value: 5 (0x00000005)

我们可以自己设置Matrix的值以便于实现图片的变换操作,但是人的计算能力始终是比不过计算机的,可以自己试试设置Matrix的值看看是否容易达到自己想要的结果。

Android为了方便开发,提供了几个接口以便于我们操作矩阵。他们是translate(平移),rotate(旋转),scale(缩放),skew(倾斜)。每一种变换在Android的API里都提供了set, post和pre三种操作方式,除了translate,其他三种操作都可以指定中心点。

set是直接设置Matrix的值,每次set一次,整个Matrix的数组都会变掉。 
post是后乘,当前的矩阵乘以参数给出的矩阵。可以连续多次使用post,来完成所需的整个变换。例如,要将一个图片旋转30度,然后平移到(100,100)的地方,那么可以这样做:

1 Matrix m = new Matrix();
2 m.postRotate(30);
3 m.postTranslate(100, 100);

再对比一下pre:pre是前乘,参数给出的矩阵乘以当前的矩阵。所以操作是在当前矩阵的最前面发生的。例如上面的例子,如果用pre的话:

1 Matrix m = new Matrix();
2 m.setTranslate(100, 100);
3 m.preRotate(30);

过程是倒过来的,这个可以使用矩阵知识得到解释。

旋转、缩放和倾斜都可以围绕一个中心点来进行,如果不指定,默认情况下,是围绕(0,0)点来进行。

下面给个完整的例子:

 1 package chroya.demo.graphics;
 2 
 3 import android.content.Context;
 4 import android.graphics.Bitmap;
 5 import android.graphics.Canvas;
 6 import android.graphics.Matrix;
 7 import android.graphics.Rect;
 8 import android.graphics.drawable.BitmapDrawable;
 9 import android.util.DisplayMetrics;
10 import android.view.MotionEvent;
11 import android.view.View;
12 
13 public class MyView extends View {
14 
15   private Bitmap mBitmap;
16   private Matrix mMatrix = new Matrix();
17 
18   public MyView(Context context) {
19     super(context);
20     initialize();
21   }
22 
23   private void initialize() {
24 
25     Bitmap bmp = ((BitmapDrawable)getResources().getDrawable(R.drawable.show)).getBitmap();
26     mBitmap = bmp;
27     /*首先,将缩放为100*100。这里scale的参数是比例。有一点要注意,如果直接用100/
28     bmp.getWidth()的话,会得到0,因为是整型相除,所以必须其中有一个是float型的,直接用100f就好。*/
29     mMatrix.setScale(100f/bmp.getWidth(), 100f/bmp.getHeight());
30     //平移到(100,100)处
31     mMatrix.postTranslate(100, 100);
32     //倾斜x和y轴,以(100,100)为中心。
33     mMatrix.postSkew(0.2f, 0.2f, 100, 100);
34     }
35 
36     @Override protected void onDraw(Canvas canvas) {
37     // super.onDraw(canvas); //如果界面上还有其他元素需要绘制,只需要将这句话写上就行了。
38 
39     canvas.drawBitmap(mBitmap, mMatrix, null);
40   }
41 }

That's ALL! 3Q for Android Matrix 介绍.

推荐博客:Android图片处理(Matrix,ColorMatrix)

 

 

 

 

posted @ 2012-09-26 12:11  大脚印  阅读(682)  评论(0编辑  收藏  举报