convertToNodeSpace和convertToWorldSpace
2016-03-10 15:40
573 查看
游戏中经常会用到一些变换:
游戏中武器和角色在一个layer上,为了效率,会考虑将bullet, effect和 PhysicsParticle分别放到不用的层上,对应的层上使用batchnode来提高效率
武器和PhysicsParticleLauncher(粒子发射器)绑定,发射的时候,会向PhysicsParticleLayer的武器相同的位置上生成一个物理粒子特效
会经常用到convertToNodeSpace和convertToWorldSpace转换坐标
我们加三个sprite,r0,r1,r2,
r0的父节点是layer, 父节点下坐标(0,0,100,100)
r1的父节点是r0,父节点下坐标(0,0,100,100)
r2的父节点是r1,父节点下坐标(0,0,100,20)
[cpp]
view plain
copy
bool HelloWorld::init()
{
//////////////////////////////
// 1. super init first
if ( !Layer::init() ) {
return false;
}
// r0加入到根节点上(Layer) 坐标(0,0)
Sprite* r0 = Sprite::create("data/pic/gun.png");
r0->setAnchorPoint(Point(0.f, 0.f));
this->addChild(r0);
// r1加入到r0上
Sprite* r1 = Sprite::create("data/pic/gun.png");
r1->setAnchorPoint(Point(0.f, 0.f));
r1->setPosition(Point(100, 0));
r0->addChild(r1);
// r2加入到r1上
Sprite* r2 = Sprite::create("data/pic/gun.png");
r2->setAnchorPoint(Point(0.f, 0.f));
r2->setPosition(Point(100, 20));
r1->addChild(r2);
}
如何将r2的坐标转换为世界坐标?
如何将r2的坐标转换为r0的局部坐标?
[cpp]
view plain
copy
// 获得r2的世界坐标,两种方法
// 方法1:以r2坐标系为起点,向根节点(世界坐标)变换,坐标必须为(0,0)
Point p2world = r2->convertToWorldSpaceAR(Point(0, 0));
// 方法2:以r1坐标系为起点,向根节点(世界坐标)变换,坐标为r2在父节点r1内的坐标
p2world = r1->convertToWorldSpaceAR(r2->getPosition());
// 获得r2在r0坐标系中的坐标
// convertToNodeSpace要传入的坐标为世界坐标
Point pt = r0->convertToNodeSpace(p2world);
方法如上:
工作原理详见cocos2dx代码
[cpp]
view plain
copy
Point Node::convertToWorldSpace(const Point& nodePoint) const
{
kmMat4 tmp = getNodeToWorldTransform();
kmVec3 vec3 = {nodePoint.x, nodePoint.y, 0};
kmVec3 ret;
kmVec3Transform(&ret, &vec3, &tmp);
return Point(ret.x, ret.y);
}
kmMat4 Node::getNodeToWorldTransform() const
{
kmMat4 t = this->getNodeToParentTransform();
for (Node *p = _parent; p != nullptr; p = p->getParent())
kmMat4Multiply(&t, &p->getNodeToParentTransform(), &t);
return t;
}
cocos2d-x 坐标系详解:http://www.tairan.com/archives/3367
游戏中武器和角色在一个layer上,为了效率,会考虑将bullet, effect和 PhysicsParticle分别放到不用的层上,对应的层上使用batchnode来提高效率
武器和PhysicsParticleLauncher(粒子发射器)绑定,发射的时候,会向PhysicsParticleLayer的武器相同的位置上生成一个物理粒子特效
会经常用到convertToNodeSpace和convertToWorldSpace转换坐标
我们加三个sprite,r0,r1,r2,
r0的父节点是layer, 父节点下坐标(0,0,100,100)
r1的父节点是r0,父节点下坐标(0,0,100,100)
r2的父节点是r1,父节点下坐标(0,0,100,20)
[cpp]
view plain
copy
bool HelloWorld::init()
{
//////////////////////////////
// 1. super init first
if ( !Layer::init() ) {
return false;
}
// r0加入到根节点上(Layer) 坐标(0,0)
Sprite* r0 = Sprite::create("data/pic/gun.png");
r0->setAnchorPoint(Point(0.f, 0.f));
this->addChild(r0);
// r1加入到r0上
Sprite* r1 = Sprite::create("data/pic/gun.png");
r1->setAnchorPoint(Point(0.f, 0.f));
r1->setPosition(Point(100, 0));
r0->addChild(r1);
// r2加入到r1上
Sprite* r2 = Sprite::create("data/pic/gun.png");
r2->setAnchorPoint(Point(0.f, 0.f));
r2->setPosition(Point(100, 20));
r1->addChild(r2);
}
如何将r2的坐标转换为世界坐标?
如何将r2的坐标转换为r0的局部坐标?
[cpp]
view plain
copy
// 获得r2的世界坐标,两种方法
// 方法1:以r2坐标系为起点,向根节点(世界坐标)变换,坐标必须为(0,0)
Point p2world = r2->convertToWorldSpaceAR(Point(0, 0));
// 方法2:以r1坐标系为起点,向根节点(世界坐标)变换,坐标为r2在父节点r1内的坐标
p2world = r1->convertToWorldSpaceAR(r2->getPosition());
// 获得r2在r0坐标系中的坐标
// convertToNodeSpace要传入的坐标为世界坐标
Point pt = r0->convertToNodeSpace(p2world);
方法如上:
工作原理详见cocos2dx代码
[cpp]
view plain
copy
Point Node::convertToWorldSpace(const Point& nodePoint) const
{
kmMat4 tmp = getNodeToWorldTransform();
kmVec3 vec3 = {nodePoint.x, nodePoint.y, 0};
kmVec3 ret;
kmVec3Transform(&ret, &vec3, &tmp);
return Point(ret.x, ret.y);
}
kmMat4 Node::getNodeToWorldTransform() const
{
kmMat4 t = this->getNodeToParentTransform();
for (Node *p = _parent; p != nullptr; p = p->getParent())
kmMat4Multiply(&t, &p->getNodeToParentTransform(), &t);
return t;
}
cocos2d-x 坐标系详解:http://www.tairan.com/archives/3367
相关文章推荐
- Jquery通过ajax请求NodeJS返回json数据
- [转]Node-Webkit配合HTML5实现拍照功能
- 关于MonoDevelop5.9.6_使用总结
- Nodejs 一个简单的后台实例
- 一个由INode节点爆满引起的业务故障
- 关于影响NodeManager执行MR任务constainer数量的设置问题
- Node.js之Console用法小结
- 文件系统(node.js学习笔记)
- NodeJs之npm
- Node debug
- nodejs中的加密模块 crypto 模块
- Node.js、Express框架获取客户端IP地址
- Node.js
- WebStorm配置Node.js IDE
- LeetCode 19. Remove Nth Node From End of List
- inode和文件描述符区别
- [leetcode 116] Populating Next Right Pointers in Each Node---层序遍历标记每一层的末尾
- Hadoop之Secondary NameNode
- leetcode:Delete Node in a Linked List 【Java】
- [nodejs] nodejs开发个人博客(四)数据模型