动画:关于matrix 的函数调用顺序的一些记录

在matrix 中的一些函数 preScale,postScale,preTranslate,postTranslate 等的记录。

matrix.preScale(0.5f, 1);  
matrix.preTranslate(10, 0); 
matrix.postScale(0.7f, 1);  
matrix.postTranslate(15, 0); 

我们在代码中实际调用的过程是

preSacle--->preTranslate--->postScale--->postTranslate
但是系统实际调用的过程是:
preTranslate--->preSacle--->postScale--->postTranslate
其实,无论你调用的顺序是什么样,最终的执行结果都是 preTranslate--->preSacle--->postScale--->postTranslate 这的顺序。

所以,preTranslate是指在setScale前平移,postTranslate是指在setScale后平移(和调用的顺序无关)。


要注意的是:
matrix 的setXXX方法会对之前调用preXXX和postXXX进行清空操作,之前的设置将会无效,之后才会有效。
比如:

matrix.preScale(0.5f, 1);  
matrix.postTranslate(10, 0); 
matrix.setScale(1, 0.6f); 
matrix.postScale(0.7f, 1); 
matrix.preTranslate(15, 0); 


实际执行的效果是:
preTranslate--->setScale--->postScale。因为setScale会清空matrx之前的设置。


同时, Canvas里scale, translate, rotate, concat方法都是pre方法,如果要进行更多的变换可以先从Canvas获得matrix, 变换后再设置回Canvas.,已达到我们想要的效果。


希望能对朋友们也有些帮助。




你可能感兴趣的:(动画:关于matrix 的函数调用顺序的一些记录)