Cocos2d-x 3.x 之 坐标系

  次阅读 作者:智能小宝 来源:互联网 2015-09-28 13:27 我要评论(0)

继续夯一下基础,

今天研究下——坐标系

内容:

> UI坐标

> OpenGLzuobiao

> 世界坐标和模型坐标

1.关于 坐标系

在图形图像和游戏应用开发中坐标系是非常重要的。

在 Android 和 iOS等平台应用开发的时候,它们所使用的二维坐标系的 原点 是在 左上角。

But,在Cocos2d-x坐标系中 原点 是在 左下角 的,而且Cocos坐标系又分为 世界坐标系 和 模型坐标系。

2.UI坐标

UI坐标 就是指 Android 和 iOS等应用开发时候,所使用的坐标系,

就像:

UI坐标 的原点是在 左上角,x轴右向为正,y轴下向为正。

上面也说过,cocos2d-x默认坐标系并不是这样的,但是并非全不是,

在触摸事件的时候,触摸到的坐标,就是UI坐标,

就像这样获得的: Vec2 touchLocation = touch -> getLocationInView();

当然,我们也可以进行坐标转换,将它转换成cocos2d-x的默认坐标:

Vec2 touchLocation2 = Director::getInstance()->convertToGL(touchLocation);

3.OpenGL坐标

OpenGL坐标是三维坐标,

由于cocos2d-x底层采用OpenGL渲染,因此默认坐标就是OpenGL坐标,只不过只采用两维。

若不考虑z轴,OpenGL坐标的原点在 左下角:

PS:三维坐标根据z轴指向不同分为 左手坐标(z轴正向指向屏幕内) 和 右手坐标(z轴正向指向屏幕外)。

OpenGL坐标是右手坐标,Microsoft平台的 Direct3D是左手坐标。

4.世界坐标 与 模型坐标

因为 OpenGL坐标 可以分为世界坐标和模型坐标,

所以 cocos2d-x坐标 也分为世界坐标和模型坐标。

参照物的不同,造就两个不同的坐标,

比如:

描述A点的位置:

世界坐标,就是直接说A点为(5,5)

而模型坐标,可以以B点为参照物,就是(-1,1)

既然有这两个不同参照物的坐标,肯定需要互相转换,

cocos2d-x提供了几个函数:

> 将世界坐标转换为模型坐标

Vec2 convertToNodeSpace(const Vec2& worldPoint);

> 将世界坐标的触摸点转换为模型坐标

Vec2 convertTouchToNodeSpace(const Vec2& worldPoint);

> 将模型坐标转换为世界坐标

Vec2 convertToWorldSpace(const Vec2& nodePoint);

在Cocos2d-x中,每个Node都有一个锚点的存在,

这个锚点,就和我们在Word编辑文字中的 左对齐-右对齐-居中 一样,

它代表这个Node的中心,我们每次setPosition时候,其实放的是锚点的位置。

比如,我们把一个图片的锚点设定在正中央,让它展现在背景的中央位置,图片就是在正中央;如果我们把一个图片锚点设定在 左上角,让它展现在背景的中央位置,整个图片会在背景的右下角位置,就像下面的图一样:

? 中间位置

// 添加一个Button

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...