`

2011.10.13(2)——— android Matrix学习03

阅读更多
2011.10.13(2)———  android Matrix学习03

参考:http://www.moandroid.com/?p=1805

这节主要说一下图像的复合变化

我们知道rotate(旋转),scale(缩放)和skew(倾斜)这三种操作都可以指定中心点

第一:::说一下旋转

比如说:
_matrix.postRotate(30, 100, 250);

这个意思是说围绕着(100,250)旋转30°  

这种相当于先将坐标系平移到该点,再进行旋转,然后将旋转后的图像平移回到原来的坐标原点。
我们需要3步:
平移——将坐标系平移到点P(a,b);
旋转——以原点为中心旋转图像;
平移——将旋转后的图像平移回到原来的坐标原点;

1、一个概念

这种需要多种图像的几何变化就叫做图像的复合变化。

2、一个定律

设对给定的图像依次进行了基本变化F1、F2、F3…..、Fn,它们的变化矩阵分别为T1、T2、T3…..、Tn,图像复合变化的矩阵T可以表示为:T = TnTn-1…T1。

注意:最后乘的时候 是倒着乘的


//例子05 围绕某个点旋转的复合运算
	private void init5() {
		_bitmap = ((BitmapDrawable) getResources().getDrawable(R.drawable.a)).getBitmap();
		
		//Matrix{[1.0, 0.0, -100.0][0.0, 1.0, -250.0][0.0, 0.0, 1.0]}
		//Matrix{[0.8660254, -0.5, 38.39746][0.5, 0.8660254, -266.50635][0.0, 0.0, 1.0]}
		//Matrix{[0.8660254, -0.5, 138.39746][0.5, 0.8660254, -16.506348][0.0, 0.0, 1.0]}
		_matrix.postTranslate(-100, -250);
		Log.i(TAG, _matrix.toString());
		_matrix.postRotate(30);
		Log.i(TAG, _matrix.toString());
		_matrix.postTranslate(100, 250);
		
		//Matrix{[0.8660254, -0.5, 138.39746][0.5, 0.8660254, -16.506348][0.0, 0.0, 1.0]}
//		_matrix.postRotate(30, 100, 250);
		
		
		//可以看出来_matrix.postRotate(30, 100, 250);
		//和上面的复合运算的结果是一样的 
		//所以说   如果图像围绕着某个点P(a,b)旋转,
		//则先要将坐标系平移到该点,
		//再进行旋转,
		//然后将旋转后的图像平移回到原来的坐标原点。
		//我们需要3步:
		//1、平移——将坐标系平移到点P(a,b);
		//2、旋转——以原点为中心旋转图像;
		//3、平移——将旋转后的图像平移回到原来的坐标原点;
		//一个概念:::
		//这种需要多种图像的几何变化就叫做图像的复合变化。
		//一个定律:::
		//设对给定的图像依次进行了基本变化F1、F2、F3…..、Fn,
		//它们的变化矩阵分别为T1、T2、T3…..、Tn,
		//图像复合变化的矩阵T可以表示为:T = TnTn-1…T1。
		//注意::最后乘的时候 是倒着乘的
		
	}



通过上面的 我们证明了
_matrix.postRotate(30, 100, 250);


_matrix.postTranslate(-100, -250);
_matrix.postRotate(30);
_matrix.postTranslate(100, 250);

是一样的

首先 我们根据定律 来算一下:





注意:第一步平移到(100,250)得到的矩阵的a3,b3是负数 -100,-250,我想可能是把坐标(100,250)平移到原点吧 这个得注意

另外 我们可以按照我们上一节的结论 可以算出:

平移 
[1.0, 0.0, -100.0][0.0, 1.0, -250.0][0.0, 0.0, 1.0]
旋转
a3 = a1*dx + a2*dy
b3 = b1*dx + b2*dy
[0.8660254, -0.5, 38.39746][0.5, 0.8660254, -266.50635][0.0, 0.0, 1.0]
平移 直接加即可
[0.8660254, -0.5, 38.39746+100][0.5, 0.8660254, -266.50635+250][0.0, 0.0, 1.0]
即:
[0.8660254, -0.5, 138.39746][0.5, 0.8660254, -16.506348][0.0, 0.0, 1.0]


第二:::缩放

//例子06 围绕某个点缩放的复合运算
	private void init6() {
		_bitmap = ((BitmapDrawable) getResources().getDrawable(R.drawable.a)).getBitmap();
		//围绕100,250缩放到原来的一半
		//Matrix{[0.5, 0.0, 50.0][0.0, 0.5, 125.0][0.0, 0.0, 1.0]}
//		_matrix.postScale(0.5f, 0.5f, 100, 250);
		
		//Matrix{[1.0, 0.0, -100.0][0.0, 1.0, -250.0][0.0, 0.0, 1.0]}
		//Matrix{[0.5, 0.0, -50.0][0.0, 0.5, -125.0][0.0, 0.0, 1.0]}
		//Matrix{[0.5, 0.0, 50.0][0.0, 0.5, 125.0][0.0, 0.0, 1.0]}
		_matrix.postTranslate(-100, -250);
		Log.i(TAG, _matrix.toString());
		_matrix.postScale(0.6f, 0.5f);
		Log.i(TAG, _matrix.toString());
		_matrix.postTranslate(100, 250);
		
		//这个和上面的_matrix.postScale(0.5f, 0.5f, 100, 250);效果是一样的
		//根据
		//a1 = a1*sx  a2 = a2*sx a3 = a3*sx 
		//b1 = b1*sy  b2 = b2*sy b3 = b3*sy 
		//可以算出来的
	}


和上面一样 先平移 在缩放 在平移
用这个
a1 = a1*sx  a2 = a2*sx a3 = a3*sx
b1 = b1*sy  b2 = b2*sy b3 = b3*sy
就可以算出来
不再分析了 和上面一样的

最后 结论:

旋转
相对点P(a,b)旋转Ø
_matrix.postRotate(Ø, a, b);
矩阵:




缩放
相对点P(a,b)缩放(sx,sy)
_matrix.postScale(sx,sy, a, b);
矩阵:






  • 大小: 3.5 KB
分享到:
评论

相关推荐

    从一条电线到建立一个网络视频.zip

    03 D03 网络基础——时钟同步与曼彻斯特编码.mp4 04 D04 网络基础——实际网络中0和1是如何传输的.mp4 05 D05 网络基础——0和1如何变成网络中的帧.mp4 06 D06 网路基础——网络帧中到底包含什么东西?.mp4 07 D07 ...

    Android经典项目——AndroidStudio版本.zip

    Android经典项目——AndroidStudio版本.zip。 经典项目——AndroidStudio版本.zip经典项目——AndroidStudio版本.zip Android 经典项目 源码

    城市规划毕业设计——国际酒店景观设计(毕业论文+答辩PPT).zip

    城市规划毕业设计——国际酒店景观设计(毕业论文+答辩PPT).zip 城市规划毕业设计——国际酒店景观设计(毕业论文+答辩PPT).zip 城市规划毕业设计——国际酒店景观设计(毕业论文+答辩PPT).zip 城市规划毕业设计...

    JDK_1.7,amd64_ubuntu,安装包,直接下载安装即可完成1.7版本的SDK包。原生安装,不用配置环境变量,

    2,jdk-170.tar.gz ——————————JDK1.7deb包 3,switch_java.sh -------------------------java其它版本切换 4,check_java.sh———————————版本核对 注意:使用命令接口切换时,需要将自己配置的...

    python项目——Word助手.zip

    python项目——Word助手.zip python项目——Word助手.zip python项目——Word助手.zip python项目——Word助手.zip python项目——Word助手.zip python项目——Word助手.zip python项目——Word助手.zip python项目...

    嵌入式成品项目-无线接收时钟.zip

    嵌入式成品项目——无线接收时钟.zip嵌入式成品项目——无线接收时钟.zip嵌入式成品项目——无线接收时钟.zip嵌入式成品项目——无线接收时钟.zip嵌入式成品项目——无线接收时钟.zip嵌入式成品项目——无线接收时钟...

    wavecom 模块常用AT指令手册.pdf

    AT+CPIN2** —— 输入PIN2。与AT+CPIN类似,但针对特定功能的二次安全验证。 **3. AT+CPINCPIN的剩余的尝试号码。** —— 显示剩余PIN输入次数,避免因多次错误尝试而锁定SIM卡。 **4. AT+CLCK** —— 设备锁。...

    C语言项目——MP3音乐播放器.zip

    C语言项目——MP3音乐播放器.zip C语言项目——MP3音乐播放器.zip C语言项目——MP3音乐播放器.zip C语言项目——MP3音乐播放器.zip C语言项目——MP3音乐播放器.zip C语言项目——MP3音乐播放器.zip C语言项目——...

    python项目——DIY字符画.zip

    python项目——DIY字符画.zip python项目——DIY字符画.zip python项目——DIY字符画.zip python项目——DIY字符画.zip python项目——DIY字符画.zip python项目——DIY字符画.zip python项目——DIY字符画.zip ...

    微信小程序——人脸检测(截图+源码).zip

    微信小程序——人脸检测(截图+源码).zip 微信小程序——人脸检测(截图+源码).zip 微信小程序——人脸检测(截图+源码).zip 微信小程序——人脸检测(截图+源码).zip 微信小程序——人脸检测(截图+源码).zip ...

    microsoftrootcertificateauthority2011.cer

    microsoftrootcertificateauthority2011.cer - 教程详情https://blog.csdn.net/Dream_Weave/article/details/125408661

    C语言项目——企业员工管理系统.zip

    C语言项目——企业员工管理系统.zip C语言项目——企业员工管理系统.zip C语言项目——企业员工管理系统.zip C语言项目——企业员工管理系统.zip C语言项目——企业员工管理系统.zip C语言项目——企业员工管理系统....

    城市规划毕业设计——尚上人家景观设计(毕业论文+答辩PPT+CAD图+设计图+效果图).zip

    城市规划毕业设计——尚上人家景观设计(毕业论文+答辩PPT+CAD图+设计图+效果图).zip 城市规划毕业设计——尚上人家景观设计(毕业论文+答辩PPT+CAD图+设计图+效果图).zip 城市规划毕业设计——尚上人家景观设计...

    微信小程序——移动端商城(截图+源码).zip

    微信小程序——移动端商城(截图+源码).zip 微信小程序——移动端商城(截图+源码).zip 微信小程序——移动端商城(截图+源码).zip 微信小程序——移动端商城(截图+源码).zip 微信小程序——移动端商城(截图+...

    微信小程序——图书管理系统(截图+源码).zip

    微信小程序——图书管理系统(截图+源码).zip 微信小程序——图书管理系统(截图+源码).zip 微信小程序——图书管理系统(截图+源码).zip 微信小程序——图书管理系统(截图+源码).zip 微信小程序——图书管理...

    微信小程序——手势解锁(截图+源码).zip

    微信小程序——手势解锁(截图+源码).zip 微信小程序——手势解锁(截图+源码).zip 微信小程序——手势解锁(截图+源码).zip 微信小程序——手势解锁(截图+源码).zip 微信小程序——手势解锁(截图+源码).zip ...

    小学语文一年级下册反义及量词练习大全.pdf

    这篇小学语文一年级下册的反义词及量词练习主要涵盖了语言学习的基础概念,旨在帮助学生掌握汉语中的基本词汇关系和量词的正确使用。 反义词是汉语词汇中非常重要的一部分,它指的是意思相反或相对的词语。在给出的...

    微信小程序——全屏动画滚动(截图+源码).zip

    微信小程序——全屏动画滚动(截图+源码).zip 微信小程序——全屏动画滚动(截图+源码).zip 微信小程序——全屏动画滚动(截图+源码).zip 微信小程序——全屏动画滚动(截图+源码).zip 微信小程序——全屏动画...

    14本安卓开发书籍

    Android SDK 中文开发文档.pdf Android 开发环境搭建步骤详细图解.pdf Android2.3用户手册.pdf Android应用程序开发36技.pdf Android开发从入门到精通.doc ...深入浅出Android——Android开发经典教材.pdf

Global site tag (gtag.js) - Google Analytics