Cocos-2d 坐标系及其坐标转换



原作者:jlins  出处:博客园http://www.cnblogs.com/dyllove98/p/3231175.html

 Cocos-2d中,涉及到4种坐标系:

GL坐标系Cocos2DOpenglES为图形库,所以它使用OpenglES坐标系。GL坐标系原点在屏幕左下角x轴向右,y轴向上。

 屏幕坐标系苹果的Quarze2D使用的是不同的坐标系统,原点在屏幕左上角x轴向右,y轴向下。ios的屏幕触摸事件CCTouch传入的位置信息使用的是该坐标系。因此在cocos2d中对触摸事件做出响应前需要首先把触摸点转化到GL坐标系。可以使用CCDirectorconvertToGL来完成这一转化。

世界坐标系也叫做绝对坐标系。世界坐标系和GL坐标系一致,原点在屏幕左下角。

cocos2d中的元素是有父子关系的层级结构,我们通过CCNodeposition设定元素的位置使用的是相对与其父节点的本地坐标系而非世界坐标系。最后在绘制屏幕的时候cocos2d会把这些元素的本地坐标映射成世界坐标系坐标。)

 本地坐标系本地坐标系也叫做物体坐标系,是和特定物体相关联的坐标系。每个物体都有它们独立的坐标系,当物体移动或改变方向时,和该物体关联的坐标系将随之移动或改变方向。比如用cocos2d-x创建了个矩形colorLayer:CCRect(10,10,100,100),这是的本地坐标系为以(10,10)为坐标原点,x轴向右,y轴向上。如果创建了一个CCSprite,锚点为(0.5,0.5),位置为(100,100),size为(40,40),这时的本地坐标系为以(80,80)为坐标原点,x轴向右,y轴向上。

 Cocos-2d中,坐标系转换:

 CCPoint convertToNodeSpace(constCCPoint& worldPoint);
CCPoint convertToWorldSpace(const CCPoint& nodePoint);
CCPoint convertToNodeSpaceAR(const CCPoint& worldPoint);
CCPoint convertToWorldSpaceAR(const CCPoint& nodePoint);

 1.CCPoint convertToNodeSpace(constCCPoint& worldPoint);

 CGPoint nodeSpace =[spriteParentconvertToNodeSpace:orignPosition];

orignPosition转换为相对于spriteParent的本地坐标

 2.CCPointconvertToWorldSpace(const CCPoint& nodePoint);

 CGPoint wordeSpace =[spriteParentconvertToWorldSpace:orignPosition];

orignPosition转换为相对于spriteParent的世界坐标

 3.CCPointconvertToNodeSpaceAR(const CCPoint& worldPoint);

 CGPoint nodeSpaceAR =[spriteParentconvertToWorldSpace:orignPosition];

spriteParent的坐标系原点设置在spriteParent的锚点位置

然后 orignPosition转换为相对于spriteParent的本地坐标

 4.CCPointconvertToWorldSpaceAR(const CCPoint& nodePoint);

 CGPoint wordeSpaceAR =[spriteParentconvertToWorldSpace:orignPosition];

spriteParent的坐标系原点设置在spriteParent的锚点位置

然后 orignPosition转换为相对于spriteParent的世界坐标

  

 

欢迎关注关东升新浪微博@tony_关东升。

关注智捷课堂微信公共平台,了解最新技术文章、图书、教程信息

https://img-blog.csdn.net/20150319185046838

更多精品iOS、Cocos、移动设计课程请关注智捷课堂官方网站:http://www.zhijieketang.com

智捷课堂论坛网站:http://51work6.com/forum.php

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值