原创 2015年05月12日 13:15:29
  • 24733

Android开发中,经常会接触到自定义View,而与View绘制相关的一组组方法很容易让人混淆……

现在个人简单整理,希望能够让大家有个清晰的认识

1、移动View内容的相关变量和方法 (注意:是移动View所包含的内容,而非View本身)

View相关成员变量

[java] view plain copy

 
  1. //View的内容相对于View在水平方向上的偏移量,以像素为单位
  2. //当mScrollX为正数时,内容相对于View从右向左移动,反之则向从左向右移动
  3. protected int mScrollX;
  4. //View的内容相对于View在垂直方向上的偏移量,以像素为单位
  5. //当mScrollY为负数时,内容相对于View从下向上移动,反之则向从上向下移动
  6. protected int mScrollY;

View相关成员方法

[java] view plain copy

 
  1. //获取内容偏移量mScrollX的值
  2. int android.view.View.getScrollX()
  3. //获取内容偏移量mScrollY的值
  4. int android.view.View.getScrollY()
  5. //设置内容偏移量mScrollX的值,此方法引发View重新调整内容的位置并重绘
  6. //相当于调用scrollTo(value,mScrollY)
  7. void android.view.View.setScrollX(int value)
  8. //设置内容偏移量mScrollY的值,此方法引发View重新调整内容的位置并重绘
  9. //相当于调用scrollTo(mScrollX,value)
  10. void android.view.View.setScrollY(int value)
  11. //将View的内容移动到参数所指定的位置中,此时mScrollX=x,mScrollY=y。
  12. //此方法引发View重新调整内容的位置并重绘
  13. void android.view.View.scrollTo(int x, int y)
  14. //设置View内容移动的增量,相当于调用scrollTo(mScroll+x, mScroll+y);
  15. //此方法引发View重新调整内容的位置并重绘
  16. void android.view.View.scrollBy(int x, int y)

关于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相关成员变量

[java] view plain copy

 
  1. //此成员变量包含了View的平移、缩放、旋转、锚点等属性
  2. //平移相关的是mTransformationInfo.mTranslationX和mTransformationInfo.mTranslationY
  3. TransformationInfo mTransformationInfo;

View相关成员方法

[java] view plain copy

 
  1. //此方法用于获取View在水平方向的偏移量,以像素为单位
  2. public float android.view.View.getTranslationX()
  3. //此方法用于获取View在垂直方向的偏移量,以像素为单位
  4. public float android.view.View.getTranslationY()
  5. //此方法用于设置View在水平方向的偏移量,以像素为单位。会引发View重绘
  6. //偏移量为正数时,表示View从左向右平移。反之则从右向左平移
  7. public void android.view.View.setTranslationX(float translationX)
  8. //此方法用于设置View在水平方向的偏移量,以像素为单位。会引发View重绘
  9. //偏移量为正数时,表示View从上向下平移。反之则从下向上平移
  10. public void android.view.View.setTranslationY(float translationY)

View的平移、缩放、旋转、锚点信息都存放在View的成员变量mTransformationInfo中,

而mTransformationInfo还包含了一个矩阵变量mMatrix(可以通过View.getMatrix()获取),

这个矩阵作用很大,因为平移、绽放、旋转操作,都可以转化为对矩阵的数学运算……

不熟悉的话,可以参考这篇文章(http://blog.csdn.net/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相关成员变量

[java] view plain copy

 
  1. //此成员变量包含了View的平移、缩放、旋转、锚点等属性
  2. //缩放相关的是mTransformationInfo.mScaleX和mTransformationInfo.mScaleY
  3. TransformationInfo mTransformationInfo;

View相关成员方法

[java] view plain copy

 
  1. //此方法用于获取View在水平方向的缩放比例。
  2. public float android.view.View.getScaleX()
  3. //此方法用于获取View在垂直方向的缩放比例。
  4. public float android.view.View.getScaleY()
  5. //设置View在水平方向的缩放比例
  6. //scaleX=1,表示是原来的大小
  7. //scaleX<1,表示缩小,如scale=0.5f,表示宽度是原来的0.5倍
  8. //scaleX>1,表示放大,如scale=2.0f,表示宽度是原来的2.0倍
  9. public void android.view.View.setScaleX(float scaleX)
  10. //设置View在垂直方向的缩放比例
  11. //scaleY=1,表示是原来的大小
  12. //scaleY<1,表示缩小,如scale=0.5f,表示高度是原来的0.5倍
  13. //scaleY>1,表示放大,如scale=2.0f,表示高度是原来的2.0倍
  14. public void android.view.View.setScaleY(float scaleY)
  15. //设置锚点的X坐标值,以像素为单位。默认是View的中心。
  16. public void android.view.View.setPivotX(float pivotX)
  17. //设置锚点的Y坐标值,以像素为单位。默认是View的中心。
  18. public void android.view.View.setPivotX(float pivotX)

通过调用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相关成员变量

[java] view plain copy

 
  1. //此成员变量包含了View的平移、缩放、旋转、锚点等属性
  2. //缩放相关是mTransformationInfo的mRotation、mRotationX、mRotationY
  3. TransformationInfo mTransformationInfo;

View相关成员方法

 
[java] view plain copy

 
  1. //此方法用于获取View在Z轴上的旋转角度
  2. public float android.view.View.getRotation()
  3. //此方法用于获取View在X轴上的旋转角度
  4. public float android.view.View.getRotationX()
  5. //此方法用于获取View在Y轴上的旋转角度
  6. public float android.view.View.getRotationY()
  7. //设置View在Z轴上的旋转角度
  8. public void android.view.View.setRotation(float rotation)
  9. //设置View在X轴上的旋转角度
  10. public void android.view.View.setRotationX(float rotationX)
  11. //设置View在Y轴上的旋转角度
  12. public void android.view.View.setRotationY(float rotationY)
  13. //设置View旋转中心点的X坐标。
  14. public void android.view.View.setPivotX(float pivotX)
  15. //设置View旋转中心点的Y坐标。
  16. public void android.view.View.setPivotX(float pivotX)
  17. //设置摄像机的与旋转目标在Z轴上距离
  18. void android.view.View.setCameraDistance(float distance)

旋转包括了三种方式,分别是围绕着X、Y、Z轴进行旋转,旋转角度以度数为单位,当该值为正数表示顺时针旋转,当该值为负数时表示逆时针旋转,
比如setRotation(90)表示围绕Z轴顺时针旋转90度。
 
这里的坐标系,与数学上的空间坐标系有点区别,如下图所示 :
 
X轴、Y轴的方向与我们平时编程所接触的方向一致,而Z轴方向是由屏幕内与屏幕外延伸。
 
所谓顺时针旋转与逆时针旋转,与坐标轴的方向相关,
一般是从正方向往负方向看。
 
 
下图是围绕Z轴顺时针旋转90度的的效果
 
 
下图是围绕X轴顺时针旋转45度的效果
 
下图是围绕Y轴顺时针旋转45度的效果
 
 
 
这些方法可以连在一起使用,如下图所示,猜猜用如何实现这种效果
 
 
 
上图是setRotation(90)和setRotationX的综合效果。
 
 
 
在以上的旋转操作,默认都是View的中心坐标为旋转中心的,可能通过setPivotX()和setPivotY()来修改该旋转中心的坐标。这里就不再举例了。
 
 
另外,上面还提到一个方法是setCameraDistance(float),该方法用于设置摄像机与View的距离,用于改善3D旋转的效果,
该方法只能用于setRotationX和setRoationY,对setRotation无影响。
 
getCameraDistance()方法用于获取当前摄像机到View的距离。
 
这两个方法是Android3.1才提供的,用得比较少,不再详述。

View的平移、缩放、旋转以及位置、坐标系的更多相关文章

  1. WPF/Silverlight中图形的平移,缩放,旋转,倾斜变换演示

    原文:WPF/Silverlight中图形的平移,缩放,旋转,倾斜变换演示 为方便描述, 这里仅以正方形来做演示, 其他图形从略. 运行时效果图:XAML代码:// Transform.XAML< ...

  2. Graphics平移缩放旋转(转载)+点睛

    点睛:可以进行多次旋转和平移,也就是平移以后再平移,旋转以后再旋转,有时候一次达不到要求,如果你想一次调整完美的话很麻烦,所以最好多次,上代码 private void btnTranslate_Cl ...

  3. 图片在 canvas 中的 选中/平移/缩放/旋转,包含了所有canvas的2D变化,让你认识到数学的重要性

    1.介绍 canvas 已经出来好久了,相信大家多少都有接触. 如果你是前端页面开发/移动开发,那么你肯定会有做过图片上传处理,图片优化,以及图片合成,这些都是可以用 canvas 实现的. 如果你是 ...

  4. 二维坐标的平移,旋转,缩放及matlab实现

    本文结合matlab 软件解释二维坐标系下的平移,旋转,缩放 首先确定点在二维坐标系下的表达方法,使用一个1*3矩阵: Pt = [x,y,1] 其中x,y 分别为点的X,Y坐标,1为对二维坐标的三维 ...

  5. threeJS创建mesh,创建平面,设置mesh的平移,旋转、缩放、自传、透明度、拉伸

    这个小案例是当初我在学习的时候,小的一个小案例,代码还需要进一步优化:还请谅解~~:主要用到了threeJS创建mesh,创建平面,设置mesh的平移,旋转.缩放.自传.透明度.拉伸等这些小功能: 采 ...

  6. 【转载】Unity中矩阵的平移、旋转、缩放

    By:克森 简介 在这篇文章中,我们将会学到几个概念:平移矩阵.旋转矩阵.缩放矩阵.在学这几个基本概念的同时,我们会用到 Mesh(网格).数学运算.4x4矩阵的一些简单的操作.但由于克森也是新手,文 ...

  7. OpenGL中旋转平移缩放等变换的顺序对模型的影响

    l 前提: 0x01. 假设绘制顶点的语句为Draw Array,变换的语句(旋转.平移.缩放)为M,而 M0; M1; M2; Draw Array; 则称对Array先进行M2再进行M1.M0 0 ...

  8. Matlab 图像平移、旋转、缩放、镜像

    今天学习了用Matlab实现对图像的基本操作.在Matlab中,图像是按照二维矩阵的形式表示的.所以对图像的操作就是对矩阵的操作. 对图像进行缩放.平移.旋转,都可以转化为矩阵的运算. 关于变换矩阵的 ...

  9. 【OpenGL(SharpGL)】支持任意相机可平移缩放的轨迹球实现

    [OpenGL(SharpGL)]支持任意相机可平移缩放的轨迹球 (本文PDF版在这里.) 在3D程序中,轨迹球(ArcBall)可以让你只用鼠标来控制模型(旋转),便于观察.在这里(http://w ...

随机推荐

  1. python实现HOG+SVM对CIFAR-10数据集分类(上)

    本博客只用于学习,如果有错误的地方,恳请指正,如需转载请注明出处. 看机器学习也是有一段时间了,这两天终于勇敢地踏出了第一步,实现了HOG+SVM对图片分类,具体代码可以在github上下载,http ...

  2. 撸一撸Spring Cloud Ribbon的原理

    说起负载均衡一般都会想到服务端的负载均衡,常用产品包括LBS硬件或云服务.Nginx等,都是耳熟能详的产品. 而Spring Cloud提供了让服务调用端具备负载均衡能力的Ribbon,通过和Eure ...

  3. ACE_TEST1.obj : error LNK2019: 无法解析的外部符号

    ACE_TEST1.obj : error LNK2019: 无法解析的外部符号 "int __cdecl ace_main_i(int,char * * const)" (?ac ...

  4. 关于js 全选 反选

    prop 对于HTML元素本身就带有的固有属性,在处理时,使用prop方法. attr  对于HTML元素我们自己自定义的DOM属性,在处理时,使用attr方法. $("#selectAll ...

  5. Windows 定时任务对数据库进行操作

    定时对数据库进行操作可以用mysql的event事件来完成,但是只有mysql5.1后的才支持,所以有一定的局限性,也可以通过其他的mysql管理软件实现,而我发现Windows本身就有个定时任务的功 ...

  6. “茴”字有四种写法,this也是一样

    说到这个地方又想起以前高中还是初中学的<孔乙己>这个梗,但是这里的this显然实用性比那个要大很多,哈哈. 简单来说,this有四种应用场景,分别是在构造函数上.对象属性中.普通函数中.c ...

  7. 原码,反码,补码 与(&) 或(|) 非(~) 异或(^) 左移 << 右移 >> 无符号右移 >>>

    原码 数字在计算机中以二进制表示,8位的字长,最高位是符号位, 正数为0,负数为1.比如,3为0000 0011: -3为1000 0011. 注意,Java中int为32位.3的16进制表示为3,- ...

  8. Virtualbox以及VWare在Win10下的不兼容

    异常处理汇总-开发工具  http://www.cnblogs.com/dunitian/p/4522988.html Hyper原因导致的,关闭即可 禁用 hyper-vbcdedit /set h ...

  9. qemu-trustzone编译&运行(包含linux内核的编译方法)

    由于之前都是用的mtk6797开发板,回到实验室之后想要做实验的话需要弄一个支持trustzone的qemu,在这里记录一下我的编译和调试过程.本来最近一直忙着看论文和写论文,但是忽然发现自己在实验部 ...

  10. FFMpeg首次使用

    FFMpeg在Windows上的使用.去FFMpeg官网上去下载文件. 把下载好的文件放如下图所示的位置. cmd,调出系统的命令行工具.首先进入d盘. 进入到ffmpeg所在的文件夹. 运行 ffm ...