Cocos2d-x 3.0 开发(七)在程序中处理cocoStudio导出动画

前端之家收集整理的这篇文章主要介绍了Cocos2d-x 3.0 开发(七)在程序中处理cocoStudio导出动画前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。


1、概述

使用cocoStudio可以方便的制作动画,接下来的工作就是在我们的程序中使用制作的动画。这篇中,我将使用程序将两个动画连接起来。有图有真相:


2、制作动画

承接上一篇,我们再制作一个动画。制作动画的方法与之前没有差别,不太熟悉的同学可以看:Cocos2d-x 3.0开发(六)使用cocoStudio创建一个骨骼动画。在“动作列表”中右击,“添加动画”然后编辑就成。

我们新制作的动画的结束点,要与上一篇中制作动画的开始点重合,这样在连接的时候,画面就不会跳动。




制作好后我们将动画导出。

3、制作UI

既然能够方便的制作UI,我就顺手做了一个控制动画播放的UI。制作方法之前也提到过。没有什么差别。使用UI编辑器制作UI,并将其导出。




4、关联到项目

运行脚本创建我们的项目,将导出的动画、UI放到Resource文件夹中。

然后重写init方法


  1. boolHelloWorld::init()
  2. {
  3. //////////////////////////////
  4. //1.superinitfirst
  5. if(!Layer::init())
  6. {
  7. returnfalse;
  8. }
  9. SizevisibleSize=Director::getInstance()->getVisibleSize();
  10. Pointorigin=Director::getInstance()->getVisibleOrigin();
  11. autoui=dynamic_cast<Layout*>(CCUIHELPER->createWidgetFromJsonFile("ControlUI.ExportJson"));
  12. ui->getChildByTag(UI_BUTTON_PLAY1)->addTouchEventListener(this,toucheventselector(HelloWorld::touchCallBack));
  13. ui->getChildByTag(UI_BUTTON_PLAY2)->addTouchEventListener(this,toucheventselector(HelloWorld::touchCallBack));
  14. ui->getChildByTag(UI_BUTTON_CONN)->addTouchEventListener(this,toucheventselector(HelloWorld::touchCallBack));
  15. ui->getChildByTag(UI_BUTTON_DISCONN)->addTouchEventListener(this,toucheventselector(HelloWorld::touchCallBack));
  16. autouiLayer=UILayer::create();
  17. uiLayer->addWidget(ui);
  18. this->addChild(uiLayer);
  19. returntrue;
  20. }
  21. voidHelloWorld::touchCallBack(Object*obj,TouchEventTypetype)
  22. {
  23. //willplay
  24. }

5、加载动画

动画的导出文件也是一个json。载入后被封装到一个Armature对象中。Armature是NodeRGBA的子类,所以它可以直接被addChild到父节点中。加载所用的是ArmatureManager中的方法。它是一个单例,管理整个场景中的Armature。我们在编辑器中编辑的动画是Animation,它被封装在Armature中了。因此这是一个三层的结构。ArmatureManager最大,然后是Armature,最后是Animation。我们播放动画用的都是Animation中的方法

说完了原理,我们来看看代码。首先在init中添加加载Armature。


  1. ArmatureDataManager::getInstance()->addArmatureFileInfo("MyAnimation.ExportJson");
  2. Armature*armature=Armature::create("MyAnimation");
  3. armature->setTag(AM_MYANIMATION);
  4. armature->setPosition(Point(origin.x+visibleSize.width/2,
  5. origin.y+visibleSize.height/2));
  6. this->addChild(armature);

然后重写touchCallback方法控制播放动画。


  1. voidHelloWorld::touchCallBack(Object*obj,TouchEventTypetype)
  2. {
  3. autouiBt=dynamic_cast<UIButton*>(obj);
  4. if(!uiBt)
  5. {
  6. return;
  7. }
  8. inttag=uiBt->getTag();
  9. autoarmature=(Armature*)getChildByTag(AM_MYANIMATION);
  10. switch(type)
  11. {
  12. caseTouchEventType::TOUCH_EVENT_ENDED:
  13. if(tag==UI_BUTTON_PLAY1)
  14. {
  15. armature->getAnimation()->play("hit");
  16. }
  17. elseif(tag==UI_BUTTON_PLAY2)
  18. {
  19. armature->getAnimation()->play("fall");
  20. }
  21. elseif(tag==UI_BUTTON_CONN)
  22. {
  23. //willconn
  24. }
  25. elseif(tag==UI_BUTTON_DISCONN)
  26. {
  27. //willdisconn
  28. }
  29. break;
  30. default:
  31. break;
  32. }
  33. }

6、处理动画事件

Animation中有动画事件的概念,每一个动画开始和结束都会事件。我们需要做的就是监听这个事件并为其写好响应函数

所以接下来我们完善touchCallback函数,并添加一个监听函数


  1. //......
  2. elseif(tag==UI_BUTTON_CONN)
  3. {
  4. armature->getAnimation()->setMovementEventCallFunc(this,movementEvent_selector(HelloWorld::movementCallback));
  5. }
  6. elseif(tag==UI_BUTTON_DISCONN)
  7. {
  8. armature->getAnimation()->setMovementEventCallFunc(this,nullptr);
  9. }
  10. //......
  11. voidHelloWorld::movementCallback(Armature*armature,MovementEventTypetype,constchar*name)
  12. {
  13. if(type==COMPLETE)
  14. {
  15. if(strcmp(name,"fall")==0)
  16. {
  17. Armature*arm=(Armature*)getChildByTag(AM_MYANIMATION);
  18. arm->getAnimation()->play("hit");
  19. }
  20. }
  21. }


编译运行,就可以看到动画连接起来了。

7、总结

通过ArmatureDataManager单例来加载动画,将其关联到程序中。动画事件的监听,对动画的行为进行处理。使用这些方法我们可以灵活的使用cocoStudio创建的动画了。

Demo下载:http://download.csdn.net/detail/fansongy/6439225



本篇博客出自阿修罗道,转载请注明出处禁止用于商业用途http://blog.csdn.net/fansongy/article/details/12955989

猜你在找的Cocos2d-x相关文章