Node类的setPosition,getPosition函数如果是一个Node的Child则获取的坐标就是该Node的本地坐标
另一个关键问题就是在cocos2d-x里就是各种对象的大小问题。因为在cocos2d-x里Node对象有缩放的方法setScaleX和setScaleY。所以在获取对象大小的时候必须根据情况明确指定获取对象原始大小,还是缩放后的大小。当然cocos2d-x里提供了对应函数来完成这些操作:
@H_502_10@
getContentSize函数来获得节点原始的大小。只是逻辑尺寸,不是像素。返回CGSize类型。
@H_502_10@
boundingBox函数来获得经过缩放和旋转之后的外框盒大小,返回CGRect类型。
@H_502_10@
getContentSizeInPixels获得的是像素点大小
@H_502_10@
像素点和逻辑点关系:逻辑点大小 = 像素大小/contentScaleFactor.
@H_502_10@
@H_502_10@
有个问题最近才遇到,父精灵进行缩放处理,会对子精灵进行标记(boolean值),在实际绘制过程中会影响子精灵显示大小,但并不改变子精灵的getBoundingBox所获得的值,也就是只有直接setscale才会影响getBoundingBox数值。
@H_502_10@
@H_502_10@
@H_502_10@
Sprite中有个方法:
getTextureRect返回精灵纹理大小,返回CGRect类型,并且是原始纹理大小,无关缩放。在一般情况下和getContentSize作用一样,但如果用TP处理过,还回值是实际纹理大小,留白部分会去除。这个在碰撞检测过程中经常用到。
cocos2d中还有两个方法用于坐标转换:
convertToWindowSpace,将节点坐标转换为屏幕坐标,注意的是转换后为UI坐标系。
convertToNodeSpace将屏幕坐标转换为节点坐标,转换后为GL坐标系。
@H_502_10@
getVisibleSize:默示获得视口(可视区域)的大小,若是DesignResolutionSize跟屏幕尺寸一样大,则getVisibleSize便是getWinSize。
getVisibleOrigin:默示可视区域的出发点坐标,这在处理惩罚相对地位的时辰很是有效,确保节点在不合辨别率下的地位一致。 @H_502_10@
getVisibleOrigin:默示可视区域的出发点坐标,这在处理惩罚相对地位的时辰很是有效,确保节点在不合辨别率下的地位一致。 @H_502_10@
坐标转换:
@H_502_10@
@H_502_10@
@H_502_10@
GL坐标系,cocos2d-x默认坐标系:
@H_502_10@
@H_502_10@
@H_502_10@
Point Director::convertToGL(const Point& uiPoint)
@H_502_10@
{
@H_502_10@
Size s = m_obWinSizeInPoints;
@H_502_10@
float newY = s.height - uiPoint.y;
@H_502_10@
}
@H_502_10@
屏幕坐标系: 默认原点在左上角
@H_502_10@
Point Director::convertToUI(const Point& glPoint)
@H_502_10@
{
@H_502_10@
Size winSize = m_obWinSizeInPoints;
@H_502_10@
float oppositeY = winSize.height - glPoint.y;
@H_502_10@