Cocos2d-x 详解坐标系统
前端之家收集整理的这篇文章主要介绍了
Cocos2d-x 详解坐标系统,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
http://blog.csdn.net/Crayondeng/article/details/11936309?utm_source=tuicool
这篇博文将介绍一下在cocos2dx中的一些坐标系统概念:
一、
(1)OpenGL坐标系
Cocos2D-x以OpenGL和OpenGL ES为基础,所以自然支持OpenGL坐标系。该坐标系原点在屏幕左下角,x轴向右,y轴向上。
(2)屏幕坐标系
屏幕坐标系使用的是不同的坐标系统,原点在屏幕左上角,x轴向右,y轴向下。iOS的屏幕触摸事件CCTouch传入的位置信息使用的是该坐标系。因此在Cocos2D-x中对触摸事件做出响应前,需要首先把触摸点转化到OpenGL坐标系。这一点在后面的触屏信息中会详细介绍,可以使用CCDirector的convertToGL方法来完成这一转化。
在处理触摸事件的回调方法中,我们会经常碰到这两者的坐标系统的转换处理问题。在CCTouch文件中已经为我们封装好了获取触摸点在OpenGL坐标系统和屏幕坐标系统中的坐标位置。
①从触摸点获取到在屏幕坐标系中的坐标
-
- CCPointCCTouch::getLocationInView()const
- {
- returnm_point;
- }
②从触摸点获取到在OpenGL坐标系中的坐标
//returnsthecurrenttouchlocationinOpenGLcoordinates
- CCPointCCTouch::getLocation()returnCCDirector::sharedDirector()->convertToGL(m_point);
- }
二、
(1)世界坐标系统
@H_
502_162@ 世界坐标系也叫作绝对坐标系,是游戏开发中建立的概念,因此,“世界”即是游戏世界。它建立了描述其他坐标系所需要的参考标准。我们能够用世界坐标系来描述其他坐标系的位置。它是Cocos2D-x中一个比较大的概念。
@H_
502_162@ Cocos2D-x中的元素是有父子关系的层级结构。通过CCNode设置位置使用的是相对其父节点的本地坐标系,而非世界坐标系。最后在绘制屏幕的时候,Cocos2D-x会把这些元素的本地节点坐标映射成世界坐标系坐标。世界坐标系和OpenGL坐标系方向一致,原点在屏幕左下角,x轴向右,y轴向上。
(2)节点坐标系统
@H_
502_162@ 节点坐标系是和特定节点相关联的坐标系。每个节点都有独立的坐标系。当节点移动或改变方向时,和该节点关联的坐标系(它的子节点)将随之移动或改变方向。这一切都是相对的,相对于基准的,只有在节点坐标系中才有意义。
@H_
502_162@ CCNode类的设置位置使用的就是父节点的节点坐标系。它和OpenGL坐标系的方向也是一致的,x轴向右,y轴向上,原点在父节点的左下角。
如果父节点是场景树中的顶层节点,那么它使用的节点坐标系就和世界坐标系重合了。
@H_
502_162@ ****
@H_
502_162@ 锚点
@H_
502_162@ 锚点指定了贴图上和所在节点原点(也就是设置位置的点)重合的点的位置,因此只有在CCNode类节点使用贴图的情况下,锚点才有意义。
@H_
502_162@ 锚点的默认值是(0.5,0.5),表示的并不是一个像素点,而是一个乘数因子。(0.5,0.5) 表示锚点位于贴图长度乘0.5和宽度乘0.5的地方,即贴图的中心。
@H_
502_162@ 改变锚点的值虽然可能看起来节点的图像位置发生了变化,但其实并不会改变节点的位置,其实变化的只是贴图相对于你设置的位置的相对位置,相当于你在移动节点里面的贴图,而非节点本身。如果把锚点设置成(0,0),贴图的左下角就会和节点的位置重合,这可能使得元素定位更为方便,但会影响到元素的缩放和旋转等一系列变换。因此并没有一种锚点设置是放之四海而皆准的,要根据你这个对象的使用情况来定义。在Cocos2D-x中锚点为默认值(0.5,0.5),这样的锚点设置要把一个节点放置到贴图的中央。
@H_
502_162@ ****
@H_
502_162@
上面关于世界坐标系和节点坐标系的介绍摘抄自Cocos2dx权威指南一书,下面我简单通俗的讲解一下我的理解:
其实,二者之间是一个绝对和相对的概念,世界坐标系是绝对的,而节点坐标系是相对的。
可以这样理解世界坐标系,所谓绝对,其实它就是和OpenGL坐标系(等同)一致的坐标系统,原点在屏幕左下角,x轴方向向右,y轴方向向上。
而节点坐标系是相对于具体的节点来说的,每一个物体都有一个特定的坐标系统,当节点移动时,那么它本身的坐标系统也就跟着发生变化。但是有一点需要特别注意:节点坐标系的原点默认是其左下角位置。
例如说:我们在一个layer中添加一个sprite,锚点为(0,0),size为(40,40),位置为(50,50),那么此时这个sprite的节点坐标系统是神马呢? ------- 这时它的节点坐标系统就是以(50,50)为坐标系统原点,x轴向右,y轴向上的坐标系。
对上面的例子稍稍变一下:锚点位置改为(0.5,0.5),其他不变,那么这个时候sprite的节点坐标系统又是多少呢?(注意到上面的:节点坐标系的原点默认是其左下角位置) ----- 这个时候它的节点坐标系统就是以(30,30)为坐标系统原点,x轴向右,y轴向上的坐标系。
这样理解是否好一些呢?(如有不对之处,欢迎评论指正!)
关于这两个坐标系统之间的转换,在CCNode中定义了以下四个常用的坐标变换的相关方法。