Cocos2d-x不仅是有框架,而且还提供了一个编辑器,可以让我们对动画、UI、骨骼动画和场景进行编辑。使用这些工具,大大缩短了Cocos2d-x开发的周期。现在MAC的版本也出来了。
下图是界面
data:image/s3,"s3://crabby-images/f7970/f7970c804acef0a84519616fd5046a3946f25415" alt="1405998679849171.jpg"
data:image/s3,"s3://crabby-images/f66d0/f66d0d65dcacba2cd347275d03155db45395aad6" alt="1405998796413684.png"
然后启动,新建一个项目:
data:image/s3,"s3://crabby-images/fa3a5/fa3a59e260c6b58c73fc6304f8b7a0751f0355bd" alt="1405998900981479.png"
data:image/s3,"s3://crabby-images/077c1/077c1de697d9e6a6291f759b78723dc6f950b7f8" alt="1405998905920315.png"
data:image/s3,"s3://crabby-images/50f07/50f07efdf416e8c189997ae70515cc85f17d3f02" alt="1405998909202288.png"
这样就完成项目的创建。
在编辑之前,需要先给项目提供资源,一种是把资源拖到右边的资源列表或都在资源列表打开选择资源对话框。
data:image/s3,"s3://crabby-images/86d0b/86d0b291644d08efaf5370d7b808126e4eb9e750" alt="1405998973276980.png"
data:image/s3,"s3://crabby-images/39fa0/39fa00ad33147c271868c4923e8d19fba86cf026" alt="1405999013773119.png"
data:image/s3,"s3://crabby-images/9b27d/9b27d905531812fc6d7dffb563ef18062f16f5ca" alt="1405999039345509.png"
插入结果
data:image/s3,"s3://crabby-images/e60ff/e60ff655074badb319df49b9f6b5e252e2b7b3e5" alt="1405999104641526.png"
其它资源依此类推。
项目创建会默认创建一个画布和一个容器panel:
data:image/s3,"s3://crabby-images/9fd86/9fd865b1905b3b93dddeae5b17c135bb8f52fce7" alt="11.png"
在正式编辑UI之前,需要先设置画面大小,这个跟据你项目的要求设置。
data:image/s3,"s3://crabby-images/34836/348360f416c6cd63374c44de5fcbfd444879f311" alt="12.png"
下面在画面中,填加一个图片。很不幸,你不能从资源列表直接拖到中间的画布上只,只能在画布或对象列表使用右键,弹出右键菜单,添加图片对象。
data:image/s3,"s3://crabby-images/526b7/526b715fbf2aea571a29f48161d136b2a7449ddb" alt="1405999197862797.png"
data:image/s3,"s3://crabby-images/fea91/fea91d2830cd017511a31a7360ffe115c29bccdb" alt="1405999250593006.png"
然后,用鼠标选这个对象。在画面的右边,会有一个对象的属性面板。
data:image/s3,"s3://crabby-images/f8b03/f8b030d8e207cfe43adae883f614c5b8f7c1bd32" alt="1405999279730190.png"
属性面版有尺寸和模式、常规、控件布局、特性。大家可以尝试设置,就知道他的作用了。添加完成后,把具体的图片资源拖到属性面版->特性->文件框内,就可以了。
data:image/s3,"s3://crabby-images/2b825/2b825185bc47276890740c1fbb6619c82f8c5fff" alt="16.png"
结果
data:image/s3,"s3://crabby-images/3ba31/3ba31ad229fcc8e70bf73d4c598e7f9faf2b97a4" alt="1405999344486403.png"
这样就OK了。
在属性面板有一个Tag属性和名子属性要注意一下,我面在加载UI后,可以通过这两个属性取得UI中的这个对象。
可能调整渲染层级达到调整显示次序的效果。
按照上面的步骤,就可以很快的做出UI了。
做完后,就需要导出UI了,Cocos2d-x是不能直接使用UI工程的,需要使用导出的。
data:image/s3,"s3://crabby-images/f7885/f7885766a3a35bd408678ceab511471bc625dd36" alt="111.png"
data:image/s3,"s3://crabby-images/37c29/37c298b7d92ac425ad12038bf17e6ff1b54b04ba" alt="1405999417463294.png"
在导出资源这块,要注意一下,使用大图,会把用到的资源拼成一个大图,可以提高效率。使用小图,则把资源的图原样复制过去。这个看你的取舍了。
导出完成后,把导出的目录复制到cocos2dx工程的Resource这个目录下面,就可以在项目中使用了。
data:image/s3,"s3://crabby-images/c05eb/c05eb9beb1f95701e3c013be5f34026ca26e37d9" alt="1405999449931960.png"
最后在需要使用这个UI的场景,增加下面代码:
gui::TouchGroup* ul = gui::TouchGroup::create();
ul->addWidget(GUIReader::shareReader()->widgetFromJsonFile("NewUi_1/NewUi_1.ExportJson"));
this->addChild(ul, 2);
如果要访问这个资源,就可以通过tag来操作。 ul->getWidgetByTag(42)。注意不是ui->getChildByTag(42),这个不会遍历所有的子节点!这样就完成一个完全的UI操作!