【Android】图形处理特效 Matrix 的set 、 pre、post方法的区别和使用
2018-01-18 23:34
801 查看
Matrix包含一个3 X 3的矩阵,专门用于图像变换匹配。
Matrix提供了四种操作:
translate(平移)
rotate(旋转)
scale(缩放)
skew(错切)pre是在队列最前面插入,post是在队列最后面追加,而set先清空队列在添加。
下面通过一些例子具体说明:
一、matrix.preScale(2f,1f);
matrix.preTranslate(5f, 0f);
matrix.postScale(0.2f, 1f);
matrix.postTranslate(0.5f, 0f);
执行顺序:translate(5, 0) -> scale(2f, 1f) -> scale(0.2f, 1f) -> translate(0.5f, 0f)
二、
matrix.postTranslate(2f, 0f);
matrix.preScale(0.2f, 1f);
matrix.setScale(1f, 1f);
matrix.postScale(5f, 1f);
matrix.preTranslate(0.5f, 0f);
执行顺序:translate(0.5f, 0f) -> scale(1f, 1f) -> scale(5f, 1) 执行了setScale后,前面两句设置的矩阵变化就不起作用了。
(matrix.postTranslate(2f, 0f); matrix.preScale(0.2f, 1f); 不起作用)
三、[html] view plain copymatrix.preScale(2,2);
matrix.postTranslate(200, 200);
效果图(图中画了四条线作为参考,200、400线)
解释:放大是pre,移动是post。先放大,然后移动到(200,200)。
四、[html] view plain copymatrix.postScale(2,2);
matrix.preTranslate(200, 200);
效果图:
解释:pre 先执行,再执行post 。所以是先平移到(200,200),再放大一倍。 明明跟样例三,一个是先放大,一个是先移动。为啥差距这么大。可以这么理解。先平移到了(200,200)。’然后进行放大一倍。但是这个放大。是将整个画布,或者是坐标系都放大了,所以到达了(400,400)坐标处。
五、[html] view plain copymatrix.setScale(-1, 1);
matrix.postTranslate(bmp.getWidth(),0);
这是一种特殊的缩放变换。X为负数,则表示以X轴翻转后,再进行缩放。注意: 没有Translate,只有matrix.setScale(-1,1)。 图像会翻转到X轴返方向。会看不到图像。Translate 最好用 postTranslate 。 如果用了setScale 和 preTranslate ,是不会看到图像的。理解:因为是preTranslate,会将图像先平移,距离X轴一段距离。然后再将图像沿X轴翻转。然后再放大(整体放大,包括刚才的平移的距离。)导致图像离X的负半轴更远。
[html] view plain copymatrix.setScale(1, -1);
matrix.postTranslate(0, bmp.getHeight());
沿Y轴翻转
Matrix提供了四种操作:
translate(平移)
rotate(旋转)
scale(缩放)
skew(错切)pre是在队列最前面插入,post是在队列最后面追加,而set先清空队列在添加。
下面通过一些例子具体说明:
一、matrix.preScale(2f,1f);
matrix.preTranslate(5f, 0f);
matrix.postScale(0.2f, 1f);
matrix.postTranslate(0.5f, 0f);
执行顺序:translate(5, 0) -> scale(2f, 1f) -> scale(0.2f, 1f) -> translate(0.5f, 0f)
二、
matrix.postTranslate(2f, 0f);
matrix.preScale(0.2f, 1f);
matrix.setScale(1f, 1f);
matrix.postScale(5f, 1f);
matrix.preTranslate(0.5f, 0f);
执行顺序:translate(0.5f, 0f) -> scale(1f, 1f) -> scale(5f, 1) 执行了setScale后,前面两句设置的矩阵变化就不起作用了。
(matrix.postTranslate(2f, 0f); matrix.preScale(0.2f, 1f); 不起作用)
三、[html] view plain copymatrix.preScale(2,2);
matrix.postTranslate(200, 200);
效果图(图中画了四条线作为参考,200、400线)
解释:放大是pre,移动是post。先放大,然后移动到(200,200)。
四、[html] view plain copymatrix.postScale(2,2);
matrix.preTranslate(200, 200);
效果图:
解释:pre 先执行,再执行post 。所以是先平移到(200,200),再放大一倍。 明明跟样例三,一个是先放大,一个是先移动。为啥差距这么大。可以这么理解。先平移到了(200,200)。’然后进行放大一倍。但是这个放大。是将整个画布,或者是坐标系都放大了,所以到达了(400,400)坐标处。
五、[html] view plain copymatrix.setScale(-1, 1);
matrix.postTranslate(bmp.getWidth(),0);
这是一种特殊的缩放变换。X为负数,则表示以X轴翻转后,再进行缩放。注意: 没有Translate,只有matrix.setScale(-1,1)。 图像会翻转到X轴返方向。会看不到图像。Translate 最好用 postTranslate 。 如果用了setScale 和 preTranslate ,是不会看到图像的。理解:因为是preTranslate,会将图像先平移,距离X轴一段距离。然后再将图像沿X轴翻转。然后再放大(整体放大,包括刚才的平移的距离。)导致图像离X的负半轴更远。
[html] view plain copymatrix.setScale(1, -1);
matrix.postTranslate(0, bmp.getHeight());
沿Y轴翻转
相关文章推荐
- Android 图形处理特效 Matrix 的set 、 pre、post方法的区别和使用
- Android中Matrix的set、pre、post的区别
- Android中Matrix的set、pre、post的区别
- Android中Matrix的pre post set方法理解
- Matrix 中的post 和pre 和set 方法的区别 以及Canvas中的方法
- Matrix 中的post 和pre 和set 方法的区别 以及Canvas中的方法
- 详谈Android中Matrix的set、pre、post的区别
- Android中Matrix的pre post set方法理解
- Android中Matrix的pre post set方法理解
- Android中Matrix的pre post set方法理解
- Android Matrix的 pre post set方法的理解(zz)
- Android中Matrix的pre post set方法理解(转载来源:Linux社区 作者:zjmdp)
- Android中Matrix的pre post set方法理解
- Android中的Matrix,以及set,pre和post的区别
- Matrix 中的post 和pre 和set 方法的区别 以及Canvas中的方法
- Android中Matrix的pre post set方法理解(转载来源:Linux社区 作者:zjmdp)
- android Matrix.setRotate 和 postRotate的区别
- Android中使用Matrix控制图形变换和制作倒影效果的方法
- android图形处理之 Matrix方法
- 浅谈android中图片处理之图形变换特效Matrix(四)