转载地址:http://blog.youkuaiyun.com/eieihihi/article/details/45668189
1、移动View内容的相关变量和方法 (注意:是移动View所包含的内容,而非View本身)
View相关成员变量
View相关成员方法
关于ScrollTo方法的使用效果如下图所示:
如上图所示,黄色View(一个LinearLayout)在调用了scrollTo(100,0)方法之后,View里面的按钮全部向左偏移了100像素。而黄色View本身并没有发生位置上的变化。
再看下面图,黄色View调用了scrollTo(0,100)方法之后,View里面的按钮全部向上偏移了100像素,而黄色区域本身没有发生位置上的变化。
从上面的例子中,不管你调用多少次scrollTo(100,0),其最终效果都只是让mScrollX=100,mScrollY=0。也就是说,该方法重复调用,只有一次效果。
而scrollBy(int,int)方法而不同,scrollBy方法被调用一次之后,mScrollX和mScrollY就会增加相应的值,下图是重复调用三次scrollBy(100,0)的效果:
2、移动View的相关变量和方法 (注意:是移动整个View)
View相关成员变量
View相关成员方法
View的平移、缩放、旋转、锚点信息都存放在View的成员变量mTransformationInfo中,
而mTransformationInfo还包含了一个矩阵变量mMatrix(可以通过View.getMatrix()获取),
这个矩阵作用很大,因为平移、绽放、旋转操作,都可以转化为对矩阵的数学运算……
不熟悉的话,可以参考这篇文章(http://blog.youkuaiyun.com/webrobot/article/details/7359626)
上面代码块中的四个方法,都是平移操作相关的方法。
下图是简单的示意图:
上面右边的红色线框表示View的实际大小!
黄色View调用了setTranslationX(100)之后,水平偏移量为100,整个黄色View从左往右移动了100像素。
如果调用的是setTranslationX(-100)的话,整个黄色View就会从右往左移动100像素。
注意:这个移动方向和scrollTo恰恰相反
黄色View调用了translationY(100)之后,效果如下所示:
如上图所示,当垂直偏移量为正数时,黄色View从上往下移动了100像素;反之,当垂直偏移量为负数时,黄色View从下往上移动。
3、缩放View的相关变量和方法 (注意:针对整个View)
View相关成员变量
View相关成员方法
通过调用setScaleX()和setScaleY()方法,可以实现View的缩放,其效果图如下所示
上面还提到了两个方法,分别是setPivotX()和setPivotY(),其他是用来设置缩放操作的锚点坐标的。以像素为单位,它的默认值是View的中心坐标。
如上图,黄色View的大小为width=984、height=1461,
而getPivotX()为492.0 、getPivotY()为730.5,
这正好表明了,View的锚点坐标默认就是View的中心坐标。
锚点的位置,将决定View缩放后所在的位置。
因为默认是中心坐标,所以上面两次绽放操作,其结果都是在水平中心位置或垂直中心位置。
但是,如果锚点的位置变了,那么View缩放后的位置也将发生变化,如下图所示
4、旋转View的相关变量和方法 (注意:针对整个View)
View相关成员变量
View相关成员方法
旋转包括了三种方式,分别是围绕着X、Y、Z轴进行旋转,旋转角度以度数为单位,当该值为正数表示顺时针旋转,当该值为负数时表示逆时针旋转,