我是靠谱客的博主 震动小松鼠,最近开发中收集的这篇文章主要介绍Android 图形处理特效 Matrix 的set 、 pre、post方法的区别和使用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Android 图形处理特效 Matrix 的set 、 pre、post方法的区别和使用

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); 不起作用



三、


matrix.preScale(2,2);
matrix.postTranslate(200, 200);
效果图(图中画了四条线作为参考,200、400线)

解释:

放大是pre,移动是post。先放大,然后移动到(200,200)。


四、


matrix.postScale(2,2);
matrix.preTranslate(200, 200);
效果图:

解释:pre 先执行,再执行post 。所以是先平移到(200,200),再放大一倍。 明明跟样例三,一个是先放大,一个是先移动。为啥差距这么大。

可以这么理解。先平移到了(200,200)。’然后进行放大一倍。但是这个放大。是将整个画布,或者是坐标系都放大了,所以到达了(400,400)坐标处。


五、

matrix.setScale(-1, 1);
matrix.postTranslate(bmp.getWidth(),0); 


这是一种特殊的缩放变换。X为负数,则表示以X轴翻转后,再进行缩放。

注意: 没有Translate,只有matrix.setScale(-1,1)。 图像会翻转到X轴返方向。会看不到图像。

Translate 最好用 postTranslate 。  如果用了setScale  和  preTranslate ,是不会看到图像的。理解:因为是preTranslate,会将图像先平移,距离X轴一段距离。然后再将图像沿X轴翻转。然后再放大(整体放大,包括刚才的平移的距离。)导致图像离X的负半轴更远。


matrix.setScale(1, -1);
matrix.postTranslate(0, bmp.getHeight());
沿Y轴翻转



最后

以上就是震动小松鼠为你收集整理的Android 图形处理特效 Matrix 的set 、 pre、post方法的区别和使用的全部内容,希望文章能够帮你解决Android 图形处理特效 Matrix 的set 、 pre、post方法的区别和使用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(35)

评论列表共有 0 条评论

立即
投稿
返回
顶部