青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

f(sixleaves) = sixleaves

重劍無鋒 大巧不工

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  95 隨筆 :: 0 文章 :: 7 評論 :: 0 Trackbacks
cocos2dx坐標系與笛卡爾坐標系
簡而言之,cocos2dx的2d中的坐標系與我們初中所學(xué)的笛卡爾坐標系一樣。也就是向右為X正軸,向上為Y正軸。
在屏幕中,其原點位于屏幕的左下方。

屏幕坐標系
屏幕坐標系的Y正軸是向下,X正軸不變。原點位于左上方。


World Coordinate與Node Local
World Coordinate == > 世界坐標系、絕對坐標系
Node Local == > 本地坐標系、相對坐標系

世界坐標系的意思是指游戲世界。Node Local坐標系其實就是我們在調(diào)用setPositon的時候設(shè)置的位置是相對于父節(jié)點的,是相對坐標,而不是絕對坐標。

我們需要知道的一個比較重要的東西就是Anchor Point == > 錨點
之所以有錨點這個概念,是因為在游戲中,每個節(jié)點都有自己的坐標系,這樣我們setPositon才能是相對于父親節(jié)點的,也就是相對坐標系。
但是每個節(jié)點的坐標系原點,可能不一樣。所以我們就把這個點成為錨點。簡而言之,錨點就是游戲中節(jié)點的坐標系原點。而且每個節(jié)點都有自己的坐標系。
驗證:看如下官方文檔。

我們用以下代碼為例,使用默認Anchor Point值,將紅色層放在屏幕左下角,綠色層添加到紅色層上:

1
2
3
4
5
6
7
auto red = LayerColor::create(Color4B(255, 100, 100, 128), visibleSize.width/2, visibleSize.height/2);
 
auto green = LayerColor::create(Color4B(100, 255, 100, 128), visibleSize.width/4, visibleSize.height/4);
 
red->addChild(green);
 
this->addChild(red, 0);

anchorPoint

我們用以下代碼為例,將紅色層的Anchor Point設(shè)為中點放在屏幕中央,綠色層添加到紅色層上,綠色層錨點為右上角:

注:因為Layer比較特殊,它默認忽略錨點,所以要調(diào)用ignoreAnchorPointForPosition()接口來改變錨點,關(guān)于ignoreAnchorPointForPosition()接口的使用說明,我們將在后面詳細講解。

1
2
3
4
5
6
7
8
9
10
11
auto red = LayerColor::create(Color4B(255, 100, 100, 128), visibleSize.width/2, visibleSize.height/2);
red->ignoreAnchorPointForPosition(false);
red->setAnchorPoint(Point(0.5, 0.5));
red->setPosition(Point(visibleSize.width/2 + origin.x, visibleSize.height/2 + origin.y));
 
auto green = LayerColor::create(Color4B(100, 255, 100, 128), visibleSize.width/4, visibleSize.height/4);
green->ignoreAnchorPointForPosition(false);
green->setAnchorPoint(Point(1, 1));
red->addChild(green);
 
this->addChild(red, 0);

anchorPoint

我的理解:
怎么理解呢,如果你明白了我剛才說的話,就能夠理解第二個代碼運行的效果。我們把紅色的錨點設(shè)置成0.5,05,綠色的設(shè)置成1,1則如圖上所示,兩個錨點分別為期兩個節(jié)點的坐標原點。而綠色沒有設(shè)置位置,所以其位置默認是相對于紅色是0,0位置。
為什么紅色成的左下角為本地坐標原點了。你可以這樣理解。
1.每個節(jié)點的本地坐標原點都是在左下角。
2.每個節(jié)點還有一個與AnchorPoint有關(guān)的坐標系,其坐標原點就是AnchorPoint,我們把其成為Anchor坐標系。
3.setPosition針對的是AnchorPoint坐標系下的節(jié)點,與父親本地節(jié)點坐標系的位置。(此時AnchorPoint即代表這個節(jié)點,而節(jié)點的之后的渲染效果就看節(jié)點的AnchorPoint是在節(jié)點的什么位置



幾個知識要點換種說法:
ignoreAnchorPointForPosition(true); == > 本質(zhì)上就是setAnchorPoint(0,0);
什么時候把參數(shù)設(shè)置為false呢?
這種情況只有在Layer類中才需要使用,因為Layer的錨點是(0,0)。也就是等效于ignoreAnchorPointForPosition(true);
所以我們要修改其錨點需要先ignoreAnchorPointForPosition(false);


VertexZ,PositionZ和zOrder

關(guān)于這三個參數(shù)先看官方解釋。
  • VerextZ是OpenGL坐標系中的Z值
  • PositionZ是Cocos2d-x坐標系中Z值
  • zOrder是Cocos2d-x本地坐標系中Z值

在實際開發(fā)中我們只需關(guān)注zOrder。

可以通過setPositionZ接口來設(shè)置PositionZ。

以下是setPositionZ接口的說明:

1
Sets the 'z' coordinate in the position. It is the OpenGL Z vertex value.

即PositionZ的值即為opengl的z值VertexZ。同樣節(jié)點的PositionZ也是決定了該節(jié)點的渲染順序,值越大,但是與zOrder不同的區(qū)別在于,PositionZ是全局渲染順序即在根節(jié)點上的渲染順序,而zOrder則是局部渲染順序,即該節(jié)點在其父節(jié)點上的渲染順序,與Node的層級有關(guān)。

我的理解:
我們開發(fā)中真正用到的也就是PositionZ,而PositionZ等效于VertexZ。PositionZ是什么呢,其實PositionZ就是三維坐標中的Z軸,而cocos2dx的坐標系和OpenGl、笛卡爾坐標系是一致的,簡而言之前兩種都是笛卡爾坐標系。也就是說我們以屏幕左下角為原點。
向右為X軸正向,向上為Y軸正向。所以Z軸就是向我們對著屏幕的這邊,也就是所我們設(shè)置Z軸,其實可以想象成立體的空間,在這個空間內(nèi),節(jié)點的是有順序的,Z值越高,我們看過去越能先看到,因為我們所看的屏幕相當于俯視圖。對把屏幕想成一張俯視圖。
所以Z軸值越大,就越先看到,越能蓋住它下面的東西,因為我們看的是俯視圖。有趣吧!.
那么OrderZ又是什么呢,OrderZ只是設(shè)置,在父親節(jié)點下,他們的繪制順序。但是PositionZ是決定最終呈現(xiàn)在屏幕面前的視覺順序。


我們接著來看官方所講述的觸摸事件于坐標系的關(guān)系。先看官方文檔解釋如下:(我修改了官方注釋,請看我的理解)

觸摸點(Touch position)

所以在處理觸摸事件時需要用重寫以下四個函數(shù):

1
2
3
4
virtual bool onTouchBegan(Touch *touch, Event * event);
virtual void onTouchEnded(Touch *touch, Event * event);
virtual void onTouchCancelled(Touch *touch, Event * event);
virtual void onTouchMoved(Touch *touch, Event * event);

在函數(shù)中獲取到touch,我們在設(shè)計游戲邏輯時需要用到觸摸點在Cocos2d坐標系中的位置,就需要將touch的坐標轉(zhuǎn)換成OpenGL坐標系中的點坐標。

Touch position是屏幕坐標系中的點,OpenGL position是Cocos2d-x用到的OpenGL坐標系上的點坐標。通常我們在開發(fā)中會使用兩個接口getLocation()getLocationInView()來進行相應(yīng)坐標轉(zhuǎn)換工作。

在開發(fā)中一般使用getLocation()獲取觸摸點的GL坐標,而getLocation()內(nèi)部實現(xiàn)是通過調(diào)用Director::getInstance()->convertToGL(_point);返回GL坐標。

此外,關(guān)于世界坐標系和本地坐標系的相互轉(zhuǎn)換,在Node中定義了以下四個常用的坐標變換的相關(guān)方法。

1
2
3
4
5
6
7
8
9
10
11
// 把世界坐標轉(zhuǎn)換到當前節(jié)點的本地坐標系中
Point convertToNodeSpace(const Point& worldPoint) const;
 
// 把基于當前節(jié)點的本地坐標系下的坐標轉(zhuǎn)換到世界坐標系中
Point convertToWorldSpace(const Point& nodePoint) const;
 
// 基于Anchor Point把基于當前節(jié)點的本地坐標系下的坐標轉(zhuǎn)換到世界坐標系中
Point convertToNodeSpaceAR(const Point& worldPoint) const;
 
// 基于Anchor Point把世界坐標轉(zhuǎn)換到當前節(jié)點的本地坐標系中
Point convertToWorldSpaceAR(const Point& nodePoint) const;

下面通過一個例子來說明這四個方法的理解和作用:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
auto *sprite1 = Sprite::create("HelloWorld.png");
sprite1->setPosition(ccp(20,40));
sprite1->setAnchorPoint(ccp(0,0));
this->addChild(sprite1);  //添加到父親節(jié)點下,sprite1的錨點相對于父親節(jié)點的本地坐標系的位置是x = 20, y = 40。而這個錨點又是自身的左下角。所以你可以畫出如下圖
 
auto *sprite2 = Sprite::create("HelloWorld.png");
sprite2->setPosition(ccp(-5,-20));
sprite2->setAnchorPoint(ccp(1,1));
this->addChild(sprite2); //意思如上
 
//將 sprite2 這個節(jié)點的坐標ccp(-5,-20) 轉(zhuǎn)換為 sprite1節(jié)點 下的本地(節(jié)點)坐標系統(tǒng)的 位置坐標
Point point1 = sprite1->convertToNodeSpace(sprite2->getPosition());
 
//將 sprite2 這個節(jié)點的坐標ccp(-5,-20) 轉(zhuǎn)換為 sprite1節(jié)點 下的世界坐標系統(tǒng)的 位置坐標
Point point2 = sprite1->convertToWorldSpace(sprite2->getPosition());
 
log("position = (%f,%f)",point1.x,point1.y);
log("position = (%f,%f)",point2.x,point2.y);
1
2
3
4
運行結(jié)果:
 
Cocos2d: position = (-25.000000,-60.000000)
Cocos2d: position = (15.000000,20.000000)

convert1

convert2

其中:Point point1 = sprite1->convertToNodeSpace(sprite2->getPosition());

相當于sprite2這個節(jié)點添加到(實際沒有添加,只是這樣理解)sprite1這個節(jié)點上,那么就需要使用sprite1這個節(jié)點的節(jié)點坐標系統(tǒng),這個節(jié)點的節(jié)點坐標系統(tǒng)的原點在(20,40),而sprite1的坐標是(-5,-20),那么經(jīng)過變換之后,sprite1的坐標就是(-25,-60)。

其中:Point point2 = sprite1->convertToWorldSpace(sprite2->getPosition());

此時的變換是將sprite2的坐標轉(zhuǎn)換到sprite1的世界坐標系下,而其中世界坐標系是沒有變化的,始終都是和OpenGL等同,只不過sprite2在變換的時候?qū)?code style="margin: 0px; border: 1px solid #dddddd; border-radius: 3px; padding: 0px; background-color: #f8f8f8;">sprite1作為了”參照“而已。所以變換之后sprite2的坐標為:(15,20)。

convert3

我的理解:
其實這四種相應(yīng)Layer層的方法已經(jīng)被廢棄,但是我們現(xiàn)在的關(guān)注點是坐標系的理解,不必管它。
官方文檔說要闡述的是,說我們通過這些事件回調(diào)函數(shù),在touch中取得的坐標是屏幕坐標。但是由于數(shù)據(jù)的封裝性,我們不用管,
我們只需要getLocation即可獲得笛卡爾坐標系。
其他的Point convertToNodeSpace(const Point& worldPoint) const;的轉(zhuǎn)換例子,我修改了官方的注釋,只要理解了我上面所有的敘述,理解這個是十分容易的。不再復(fù)述。
說對就不難理解代碼的運行效果了。

2015/4/6上午1:53:18
posted on 2015-04-06 01:53 swp 閱讀(3044) 評論(0)  編輯 收藏 引用 所屬分類: cocos2dx
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲人体一区| 亚洲精品欧美日韩| 亚洲精品在线三区| 亚洲国产小视频| 亚洲免费播放| 亚洲私拍自拍| 翔田千里一区二区| 久久久久久噜噜噜久久久精品| 午夜精品一区二区三区在线视 | 伊人一区二区三区久久精品| 国产一区二区欧美日韩| 国产专区一区| 亚洲精品视频一区| 亚洲一区二区三区在线视频| 香蕉成人啪国产精品视频综合网| 亚洲精选在线观看| 韩国一区二区三区在线观看| 91久久精品www人人做人人爽 | 一区视频在线| 一本色道久久88综合亚洲精品ⅰ| 亚洲欧美日韩精品| 欧美成人第一页| 亚洲综合视频在线| 免费观看亚洲视频大全| 国产精品成人一区| 亚洲国产天堂久久综合| 欧美一区二区精品久久911| 免费看成人av| 亚洲综合清纯丝袜自拍| 玖玖国产精品视频| 国产欧美日韩另类一区 | 亚洲欧洲一区| 欧美在线视频日韩| 亚洲精品视频二区| 久久亚洲欧美| 国产亚洲精品一区二区| 亚洲一级二级在线| 免费中文字幕日韩欧美| 亚洲午夜在线观看| 欧美久久久久免费| 亚洲国产女人aaa毛片在线| 欧美一区久久| 一区二区三区日韩精品| 欧美精品在线免费| 国产精品萝li| 亚洲香蕉伊综合在人在线视看| 亚洲在线免费观看| 欧美国产激情| 欧美一区二区三区免费视| 国产精品99久久不卡二区 | 一区二区久久| 亚洲人成在线影院| 久久精品视频免费播放| 亚洲高清色综合| 久久免费的精品国产v∧| 欧美午夜不卡在线观看免费| 99在线精品观看| 免费成人小视频| 国产在线观看精品一区二区三区| 亚洲影院在线观看| av成人福利| 欧美日韩另类综合| 99视频精品| 日韩午夜免费| 欧美日韩播放| 亚洲一区www| 亚洲精品美女| 欧美婷婷久久| 亚洲欧美综合国产精品一区| 亚洲欧美国产精品va在线观看 | 99精品热视频| 亚洲国产精品嫩草影院| 欧美高清在线视频观看不卡| 亚洲人www| 亚洲乱码国产乱码精品精可以看| 欧美男人的天堂| 亚洲欧美日韩精品在线| 午夜精品久久久久久久久久久久| 国产欧美日韩免费看aⅴ视频| 久久久久久久久岛国免费| 久久国产高清| 亚洲免费大片| 午夜在线视频观看日韩17c| 国模精品一区二区三区| 欧美国产日韩a欧美在线观看| 欧美激情一区二区三区成人| 亚洲一二区在线| 久久av最新网址| 亚洲美女免费精品视频在线观看| 99热在这里有精品免费| 国产无一区二区| 亚洲国产99精品国自产| 国产精品麻豆va在线播放| 狂野欧美一区| 欧美日韩中文精品| 裸体一区二区| 国产精品美女诱惑| 亚洲高清av在线| 国产精品午夜电影| 亚洲国产成人一区| 国产精品夜夜嗨| 亚洲国产欧美一区二区三区久久 | 欧美亚洲日本网站| 久久婷婷国产综合精品青草| 99视频精品全部免费在线| 欧美亚洲视频| 亚洲小视频在线| 免费成人性网站| 久热这里只精品99re8久| 国产精品久久久久国产精品日日| 欧美二区乱c少妇| 狠狠v欧美v日韩v亚洲ⅴ| 在线视频日本亚洲性| 亚洲国产毛片完整版| 欧美亚洲一区二区三区| 亚洲天堂成人| 欧美紧缚bdsm在线视频| 久久久久这里只有精品| 国产精品九色蝌蚪自拍| 亚洲毛片av在线| 亚洲精品国产欧美| 久久婷婷久久一区二区三区| 欧美在线亚洲| 国产精品视频免费观看| 99re6热在线精品视频播放速度| 亚洲激情视频网站| 久久久久国产精品厨房| 久久国产精品一区二区三区| 国产精品福利影院| 一本色道久久综合亚洲精品婷婷| 一区二区三区精品视频在线观看| 麻豆国产精品va在线观看不卡| 久久久久免费视频| 玖玖玖国产精品| 一本色道**综合亚洲精品蜜桃冫| 亚洲精品日韩综合观看成人91| 免费看亚洲片| 欧美成人午夜激情| 亚洲高清不卡在线| 另类激情亚洲| 亚洲人成网站999久久久综合| 亚洲国产欧美在线人成| 免费的成人av| 亚洲精品国产欧美| 亚洲视频观看| 国产精品久久77777| 亚洲一区二区三区精品在线观看| 亚洲欧美伊人| 狠狠色狠狠色综合日日小说| 久久久天天操| 91久久国产自产拍夜夜嗨| 亚洲影院在线| 国产日韩欧美综合| 久久久久综合网| 91久久精品国产91久久| 亚洲一区二区三区四区五区午夜| 国产精品日韩欧美一区二区三区| 欧美亚洲日本网站| 欧美国产日产韩国视频| 亚洲小视频在线观看| 国内精品久久久久伊人av| 久久尤物视频| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲精品久久嫩草网站秘色| 一区二区三区 在线观看视频| 欧美性色综合| 久久久久99| 亚洲精品在线观看视频| 羞羞视频在线观看欧美| 伊人狠狠色丁香综合尤物| 欧美精品www| 午夜在线成人av| 亚洲国产日韩综合一区| 午夜精彩国产免费不卡不顿大片| 精品999日本| 国产精品久久久久久久久久妞妞| 久久久久久久成人| 一区二区欧美日韩视频| 久久精品视频99| 日韩一区二区精品视频| 国产香蕉97碰碰久久人人| 欧美高清在线视频| 欧美伊人久久久久久久久影院| 亚洲全黄一级网站| 久久亚洲美女| 午夜精品av| 日韩午夜免费| 樱桃国产成人精品视频| 国产精品日韩| 欧美日韩一区二区三区| 久久综合伊人77777麻豆| 亚洲欧美日韩综合aⅴ视频| 亚洲人成啪啪网站| 欧美黄色网络| 老司机午夜精品| 免费观看久久久4p| 99视频精品全部免费在线| 亚洲国产一区二区精品专区| 国产一区欧美| 国产一区二区三区免费在线观看|