This commit is contained in:
sloop
2016-07-23 01:01:59 +08:00
committed by GitHub
parent 443bd862e3
commit 2728b4da97

View File

@@ -22,21 +22,17 @@ MPERSP\\_0 & MPERSP\\_1 & MPERSP\\_2
\\right ] \\right ]
$$) $$)
它在我们在之前的很多文章中都提及过但并没有仔细的介绍过从本篇开始终于要正式介绍它了这个在2D和3D绘图中十分重要的角色Matrix(_Android中有两个Matrix分别属于OpenGL 和 graphics 本篇主要讲述的是graphics中的Matrix_) 它在我们在之前的很多文章中都提及过但并没有仔细的介绍过从本篇开始终于要正式介绍它了这个在2D和3D绘图中十分重要的角色Matrix(_本篇讲述的是graphics中的Matrix_)
本篇的重点不在于这些方法的讲解,而是帮助大家理解 Matrix 的一些基本概念。
### Matrix 的翻译过来是矩阵模型。和其释义相同Matrix是一个矩阵其作用则是一个模型一个控制视图状态的模型。 ### Matrix 的翻译过来是矩阵模型。和其释义相同Matrix是一个矩阵其作用则是一个模型一个控制视图状态的模型。
**Matrix 作为一个模型,主要功能就是数值转换,将一个坐标系中的点映射到另一个坐标系中,举个栗子:** Matrix 作为一个模型,主要功能就是数值转换,将一个坐标系中的点映射到另一个坐标系中,举个栗子:
我的的手机屏幕作为物理设备其坐标系肯定是从左上角开始的而且是不会改变的但我们在开发的时候通常不会使用这一坐标系而是使用内容区的坐标系通常情况下我们的内容区和屏幕坐标系还相差一个通知栏加一个标题栏的距离所以两者是不重合的我们在内容区的坐标系中的内容最终绘制的时候肯定要转换为实际的屏幕坐标系来绘制Matrix在此处的作用就是转换这些数值。 我的的手机屏幕作为物理设备其坐标系肯定是从左上角开始的而且是不会改变的但我们在开发的时候通常不会使用这一坐标系而是使用内容区的坐标系通常情况下我们的内容区和屏幕坐标系还相差一个通知栏加一个标题栏的距离所以两者是不重合的我们在内容区的坐标系中的内容最终绘制的时候肯定要转换为实际的屏幕坐标系来绘制Matrix在此处的作用就是转换这些数值。
> >
假设通知栏高度为20像素导航栏高度为40像素,那么我们在内容区的(00)位置绘制一个点,最终就要转化为在实际坐标系中的(060)位置绘制一个点。 假设通知栏高度为20像素导航栏高度为40像素,那么我们在内容区的(00)位置绘制一个点,最终就要转化为在实际坐标系中的(060)位置绘制一个点。
>
我们也知道Android中点视图是可以嵌套的树形结构每一个子View都有自己的坐标系但实际绘制时都应当转换为实际的屏幕坐标系才能正确的绘制所以让每一个子View都有一个Matrix这样每一个View就都拥有了转换坐标的能力可以非常方便的将各自的坐标系中的内容映射到屏幕坐标系中。
![](http://ww4.sinaimg.cn/large/005Xtdi2jw1f624vi3eb6j30rs0goab5.jpg) ![](http://ww4.sinaimg.cn/large/005Xtdi2jw1f624vi3eb6j30rs0goab5.jpg)
@@ -59,11 +55,6 @@ MPERSP\\_0 & MPERSP\\_1 & MPERSP\\_2
$$) $$)
**数值作用的介绍:**
>
根据名称我们就能猜到其大概作用,但有些效果是需要多个参数组合控制的,如下。
序号 | 名称 | 对应单词 | 摘要 序号 | 名称 | 对应单词 | 摘要
-----|----------|-------------|-------------- -----|----------|-------------|--------------
0 | MSCALE_X | scale | 控制X坐标 缩放,旋转 0 | MSCALE_X | scale | 控制X坐标 缩放,旋转