亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

讓Cocos Studio 2.3.2制作UI界面中控件支持運行3d動作特效的間接途徑

2019-11-11 04:46:40
字體:
來源:轉載
供稿:網友

引子

  下了課有點小空,回想起前天的Studio中UI控件的3D動作問題,還是有點放心不下,畢竟3D高級動作特效是一件游戲開發的“法寶”。在仔細地研究了Waves3D等3D高級動作特效之后,我找到了一種如本文標題所示的間接途徑。有興趣的朋友可以參考一下。

 

實現過程記錄

 

先上圖,下圖給出的是我的教學游戲中游戲中啟動場景在Cocos Studio 2.3.2中的截圖,同學們可以注意我在圖中標記的部分。

wKiom1ZS3AmSoTeXAAIVeBRu8Ak752.jpg

  顯然,在上圖中,我在原先的Cocos2d-x 2.x(結合早期的CocoStudio 2.4.0.1)環境下可以很輕松地讓按鈕Button_Start運行Waves3D動作。但是,由于當前的Waves3D動作要求運行此動作者必須是NodeGrid類型,而上面的按鈕繼承自Widget,Widget又繼承自PRotectedNode,所以以前的代碼在運行到下面相應的運行Waves3D動作代碼時拋出異常。

123 CCActionInterval* waves1 = CCWaves3D::create(10, CCSizeMake(15,10), 18, 5);  Button_Start->runAction(CCRepeatForever::create(waves1));

 

在不甘心之余,我又分析起cpp-tests中的相關代碼。主要參考文件是EffectsAdvancedTest.cpp,相關代碼也不少,主要參考如下代碼:

123456789    auto waves = Waves::create(5, Size(15,10), 5, 20, truefalse);     auto shaky = Shaky3D::create(5, Size(15,10), 4, false);           _target1->runAction( RepeatForever::create( waves ) );     _target2->runAction( RepeatForever::create( shaky ) );

注意:_target1和_target2這兩個變量類型都是NodeGrid類型指針。

顯然,如果我的Button_Start是NodeGrid類型子類,那么一切就OK了,但恰恰不是。

 

接下來,我又分析如下圖實例。

wKiom1ZS3tnT2mgLAAFZyqbAfgE466.jpg

此實例介紹的是在Studio創建的Widget控件中動態在向場景添加一般的Node的方案。關鍵代碼如下所示:

12345678910111213void UIWidgetAddNodeTest_Editor::configureGUIScene(){    UIScene_Editor::configureGUIScene();    Size rootSize = _layout->getContentSize();    // Create the ui widget    Widget* widget = Widget::create();    widget->setPosition(Vec2(rootSize.width / 2.0f, rootSize.height / 2.0f));    widget->setLocalZOrder(_layout->getLocalZOrder() + 1);    _layout->addChild(widget);         Sprite* sprite = Sprite::create("cocosui/ccicon.png");    widget->addChild(sprite);}

大家注意最后一句?。?!

 

接下來,我又想到如今的Studio中可以很容易地在Widget控件中加入Sprite子結點,如下圖所示。

wKioL1ZS4DeRkV5xAAKQo93_oQs548.jpg

  上面這幅圖至關重要。

  Sprite_1的默認錨點是(0.5,0.5),而上面那個Button的錨點也是(0.5,0.5)。只是Sprite_1的坐標是(0,0)。顯然,這是相對其父的相對坐標,如果你仔細觀察(上圖中沒有),你當然會注意到那個Button的坐標,也就是相對整個場景的世界坐標。

 

解決方案

 

根據上面幾個代碼的綜合分析,我們可以給Widget添加NodeGrid子結點,然后再給NodeGrid添加Sprite結點,并調整NodeGrid在其父結點下的相對坐標位置。最后,讓NodeGrid運行Waves3D這種特效動作即可。

在我的上述示例中,相關答案代碼如下:

12345678910111213141516171819 Button* Button_Start = static_cast<Button*>(Helper::seekWidgetByName(Panel_Back, "Button_Start"));  NodeGrid *_bgNode = NodeGrid::create();  //經測試,與下面的錨點坐標沒有關系//  _bgNode->setAnchorPoint(Vec2(0.5, 0.5));  Button_Start->addChild(_bgNode);  auto bg = Sprite::create("Images/backbtnnormal.png");  _bgNode->addChild(bg);  _bgNode->setPosition(Vec2(Button_Start->getBoundingBox().size.width / 2, Button_Start->getBoundingBox().size.height / 2));  ActionInterval* waves1 = Waves3D::create(10, CCSizeMake(15, 10), 18, 5);  _bgNode->runAction(CCRepeatForever::create(waves1));

小結與補充

  大家看,上面的確拐了一個彎,但終究是實現了我們的渴望已久的動畫效果。歸納來看,還有一個需要補充的部分:使用上述方案的話,在Studio設計時刻只能使用一些臨時的占位符方法了,例如一個1*1像素的精靈圖片先占住Button的位置。這一點恐怕同學們不難理解,在此就不贅述了。

 

登錄樂搏學院官網http://www.learnbo.com/

或關注我們的官方微博微信,還有更多驚喜哦~

本文出自 “青峰” 博客,請務必保留此出處http://zhuxianzhong.blog.51cto.com/157061/1716084


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩国产高清污视频在线观看| 91日本视频在线| 欧美精品videossex88| 国产成人精品久久二区二区91| 久久久av一区| 国产精品黄色av| 亚洲精品资源美女情侣酒店| www.日韩不卡电影av| 欧美极度另类性三渗透| 午夜欧美大片免费观看| 国产精品久久久久久久久久尿| 亚洲娇小xxxx欧美娇小| 亚洲国产欧美久久| 成人黄色av网站| 一本色道久久综合狠狠躁篇的优点| 最近2019中文免费高清视频观看www99| 亚洲天堂免费观看| 一本色道久久88亚洲综合88| 日韩中文字幕在线| 亚洲精品www| 91av视频在线免费观看| 美女精品视频一区| 亚洲缚视频在线观看| 国产精品一区二区女厕厕| 欧美亚洲视频在线观看| 亚洲欧美日韩一区在线| 欧美疯狂做受xxxx高潮| 日韩欧美在线视频| 91九色在线视频| 亚洲精品福利在线观看| 欧美午夜激情在线| 国产99久久精品一区二区 夜夜躁日日躁| 韩国三级日本三级少妇99| 国产精品久久99久久| 91亚洲国产精品| 欧美极度另类性三渗透| 91免费福利视频| 成人自拍性视频| 97人人爽人人喊人人模波多| 亚洲精品一区中文字幕乱码| 黑人狂躁日本妞一区二区三区| 日韩视频―中文字幕| 亚洲欧美国产日韩中文字幕| 日韩资源在线观看| 亚洲精品国产精品久久清纯直播| 国产精品美女久久久免费| 欧美一级黄色网| 久久久久亚洲精品| 精品久久久久久亚洲精品| 琪琪第一精品导航| 这里只有视频精品| 日韩成人在线观看| 亚洲国内精品视频| 国产99久久久欧美黑人| 国产午夜精品一区二区三区| 日韩av综合中文字幕| 亚洲视频自拍偷拍| 日韩中文字幕精品| 亚洲综合小说区| 亚洲欧美精品伊人久久| 国产精品丝袜久久久久久高清| 亚洲欧美在线磁力| 欧美一级在线亚洲天堂| 国产丝袜一区二区三区| 日韩成人久久久| 美日韩精品免费视频| 亚洲自拍偷拍一区| 亚洲成人网久久久| 亚洲摸下面视频| 久久久久久久久久久亚洲| 91色视频在线导航| 午夜精品久久久久久久久久久久| 日韩国产高清污视频在线观看| 国产精品成人va在线观看| 精品国产一区二区三区久久久| 亚洲国产中文字幕久久网| 日韩av在线高清| 成人激情av在线| 国产成人精品在线观看| 国产精品久久久久久久天堂| 日韩视频在线观看免费| 日产日韩在线亚洲欧美| 97av在线视频免费播放| 中文字幕v亚洲ⅴv天堂| 亚洲美女自拍视频| 亚洲老头同性xxxxx| 亚洲国产精品美女| 欧美日本在线视频中文字字幕| 2021国产精品视频| 国产日韩欧美夫妻视频在线观看| 日韩欧美国产网站| 怡红院精品视频| 亚洲国产欧美一区二区三区同亚洲| 国产一区二区三区在线观看视频| 亚洲精品一区二三区不卡| 国产精品视频精品视频| 国产成人精品在线| 韩国三级日本三级少妇99| 国产情人节一区| 亚洲自拍小视频免费观看| 亚洲日本aⅴ片在线观看香蕉| 亚洲精品久久视频| 亚洲白虎美女被爆操| 45www国产精品网站| 中文字幕av一区中文字幕天堂| 精品美女永久免费视频| 国产精品高潮呻吟久久av野狼| 日韩经典一区二区三区| 午夜精品一区二区三区在线| 一区二区三区动漫| 国产999视频| 国产精品一二三在线| 日韩中文娱乐网| 精品色蜜蜜精品视频在线观看| 69视频在线播放| 久久久久国产精品免费| 亚洲免费电影在线观看| 欧美福利视频在线观看| 欧美日韩国产成人在线观看| 性色av一区二区三区红粉影视| 亚洲级视频在线观看免费1级| 久久精品视频一| 国产成人午夜视频网址| 日韩欧美精品网址| 狠狠干狠狠久久| 亚洲成人黄色在线观看| 亚洲在线免费视频| 懂色aⅴ精品一区二区三区蜜月| 精品久久久久久久久久久久久| 国产美女久久精品| 米奇精品一区二区三区在线观看| 黑人巨大精品欧美一区二区免费| 国产女精品视频网站免费| 中文字幕精品影院| 欧美乱大交做爰xxxⅹ性3| 久久韩剧网电视剧| 97在线观看免费高清| 亚洲精品影视在线观看| 法国裸体一区二区| 国产日韩精品一区二区| 亚洲人成网站免费播放| 国产91露脸中文字幕在线| 精品国产一区二区三区四区在线观看| 亚洲 日韩 国产第一| 亚洲男人天堂2023| 欧美大尺度在线观看| 国产精品成人免费视频| 91美女片黄在线观| 国产自产女人91一区在线观看| 欧美日本亚洲视频| 一区二区三区精品99久久| 日韩a**站在线观看| 久久国产精品久久久| 91免费版网站入口| 国产精品久久视频| 欧美老女人xx| 91网站在线免费观看| 日韩精品一区二区视频| www.国产精品一二区| 亚洲高清一区二| 2018日韩中文字幕| 国产欧美日韩中文字幕在线| 亚洲精品视频免费在线观看| 久久中国妇女中文字幕|