Cocos2d-3.x版的HelloWorld工程分析 (二)

举报
鱼酱 发表于 2022/01/06 23:05:23 2022/01/06
【摘要】 我们HelloWorld 从applicationDidFinishLaunching()后, 大部分人都会从这部分代码开始研究,如果想要研究main函数 如何调用applicationDidFinishLaunching()  传送门 http://blog.csdn.net/hiwoshixiaoyu/ar...

大笑大笑大笑大笑大笑大笑大笑大笑

我们HelloWorld 从applicationDidFinishLaunching()后,

大部分人都会从这部分代码开始研究,如果想要研究main函数 如何调用applicationDidFinishLaunching() 

传送门 http://blog.csdn.net/hiwoshixiaoyu/article/details/51472707



  
  1. #include "AppDelegate.h"
  2. #include <vector>
  3. #include <string>
  4. #include "HelloWorldScene.h"
  5. #include "AppMacros.h"
  6. //Uncomment the following line to use localize manager
  7. //#include "editor-support/cocostudio/LocalizationManager.h"
  8. //cocos2d的命名空间
  9. USING_NS_CC;
  10. //标准命名空间
  11. using namespace std;
  12. //构造函数
  13. AppDelegate::AppDelegate() {
  14. }
  15. //析构函数
  16. AppDelegate::~AppDelegate()
  17. {
  18. }
  19. //初始化OpenGl的上下文属性
  20. void AppDelegate::initGLContextAttrs()
  21. {
  22. GLContextAttrs glContextAttrs = {8, 8, 8, 8, 24, 8};
  23. GLView::setGLContextAttrs(glContextAttrs);
  24. }
  25. bool AppDelegate::applicationDidFinishLaunching() {
  26. // 获取导演实例
  27. auto director = Director::getInstance();
  28. //获取导演的GLView对象(通过一些函数,GLView可以操作的帧信息EGL视图)
  29. //GLView是一个抽象类
  30. //cocos2d-x提供GLViewImpl,继承它为默认渲染器上下文,你也可以有自己的GLViewImpl,通过继承重写
  31. auto glview = director->getOpenGLView();
  32. //判空
  33. if(!glview) {
  34. //创建窗口名
  35. glview = GLViewImpl::create("Cpp Empty Test");
  36. //设置opengl的视图
  37. director->setOpenGLView(glview);
  38. }
  39. director->setOpenGLView(glview);
  40. // 设置决定的分辨率
  41. glview->setDesignResolutionSize(designResolutionSize.width, designResolutionSize.height, ResolutionPolicy::NO_BORDER);
  42. //获取EGL视图大小
  43. Size frameSize = glview->getFrameSize();
  44. //一个string容器
  45. vector<string> searchPath;
  46. //在这个例子里,我们选择资源根据画面的高度
  47. //如果资源不同于我们的分辨率大小,你需要设置一个contentScaleFactor
  48. //我们使用资源的高度比的高度设计解决
  49. //这样我们可以确保资源的高度 填充设计分辨率的高度
  50. //如果画面的高度比设备的小,选择大的资源
  51. if (frameSize.height > mediumResource.size.height)
  52. {
  53. //高度大于设备高度
  54. //设置选择资源路径
  55. searchPath.push_back(largeResource.directory);
  56. //设置比例(高分辨率的设备可能有一个更高的表面比屏幕尺寸大小)
  57. director->setContentScaleFactor(MIN(largeResource.size.height/designResolutionSize.height, largeResource.size.width/designResolutionSize.width));
  58. }
  59. //如果画面高度大于设置资源高度,选择设置资源
  60. else if (frameSize.height > smallResource.size.height)
  61. {
  62. searchPath.push_back(mediumResource.directory);
  63. director->setContentScaleFactor(MIN(mediumResource.size.height/designResolutionSize.height, mediumResource.size.width/designResolutionSize.width));
  64. }
  65. //如果画面高度小于设置资源高度,选择小的资源
  66. else
  67. {
  68. searchPath.push_back(smallResource.directory);
  69. director->setContentScaleFactor(MIN(smallResource.size.height/designResolutionSize.height, smallResource.size.width/designResolutionSize.width));
  70. }
  71. //设置搜索目录
  72. FileUtils::getInstance()->setSearchPaths(searchPath);
  73. // 如果你想要加载json,用下面的方法
  74. /*
  75. cocostudio::ILocalizationManager * lm = cocostudio::JsonLocalizationManager::getInstance();
  76. lm->initLanguageData("your localize file name.lang.json");
  77. cocostudio::LocalizationHelper::setCurrentManager(lm, false);
  78. */
  79. //如果你想要 载入二进制数据 .csb 用一下方法
  80. /*
  81. cocostudio::ILocalizationManager * lm = cocostudio::BinLocalizationManager::getInstance();
  82. lm->initLanguageData("your localize file name.lang.csb");
  83. cocostudio::LocalizationHelper::setCurrentManager(lm, true);
  84. */
  85. // 显示 FPS
  86. director->setDisplayStats(true);
  87. // 设置 FPS.默认值是 1.0/60
  88. director->setAnimationInterval(1.0 / 60);
  89. // 创建一个自动释放的场景对象,通过一个静态方法
  90. auto scene = HelloWorld::scene();
  91. // 运行场景
  92. director->runWithScene(scene);
  93. return true;
  94. }
  95. //这个函数将被调用,当app是不活跃的。例如打来电话了,它就会被唤起
  96. void AppDelegate::applicationDidEnterBackground() {
  97. Director::getInstance()->stopAnimation();
  98. // 如果使用 SimpleAudioEngine,必须在这pause
  99. // SimpleAudioEngine::sharedEngine()->pauseBackgroundMusic();
  100. }
  101. //当app再次活跃起来的时候,这个函数会被调用
  102. void AppDelegate::applicationWillEnterForeground() {
  103. Director::getInstance()->startAnimation();
  104. // 如果使用SimpleAudioEngine, 你必须在这 resume
  105. // SimpleAudioEngine::sharedEngine()->resumeBackgroundMusic();
  106. }



AppDelegate.cpp中的代码主要实现了游戏启动后执行的操作,游戏启动后的操作:

1、初始化导演类

2、创建的窗口

3、设置openGL 视图

4、设置动画的帧数显示和帧率

5、调用场景

6、运行场景(游戏真正的开始)



  
  1. #ifndef __HELLOWORLD_SCENE_H__
  2. #define __HELLOWORLD_SCENE_H__
  3. #include "cocos2d.h"
  4. class HelloWorld : public cocos2d::Layer
  5. {
  6. public:
  7. //初始化层
  8. virtual bool init() override;
  9. //创建场景
  10. static cocos2d::Scene* scene();
  11. // 响应消息
  12. void menuCloseCallback(Ref* sender);
  13. //
  14. //用于创建:场景、菜单、层等东西 ,宏函数
  15. CREATE_FUNC(HelloWorld);
  16. };
  17. #endif // __HELLOWORLD_SCENE_H__


  
  1. #include "HelloWorldScene.h"
  2. #include "AppMacros.h"
  3. USING_NS_CC;
  4. Scene* HelloWorld::scene()
  5. {
  6. //'scene'是一个自动释放的对象
  7. auto scene = Scene::create();
  8. // 'layer'是一个自动释放的对象
  9. HelloWorld *layer = HelloWorld::create();
  10. // 把 layer作为一个儿子加到 scene上
  11. scene->addChild(layer);
  12. // 返回 scene
  13. return scene;
  14. }
  15. // 在 "init" 你需要初始化你想要的实例
  16. bool HelloWorld::init()
  17. {
  18. //
  19. // 1. 父类 首先初始化
  20. if ( !Layer::init() )
  21. {
  22. return false;
  23. }
  24. /************************************************************************/
  25. /* FrameSize就是屏幕的实际分辨率,这是不变的,比如我用的盖世三的手机分辨率为1280x720,这就是盖世三的FrameSize。
  26. 注意这个FrameSize很容易理解成屏幕的长宽多少,其实不是,分辨率和实际的长宽没有必然联系。
  27. 比如:
  28. 盖世3的尺寸(长宽)为4.8寸,分辨率为1280x720
  29. 盖世4的尺寸(长宽)为4.99寸,分辨率为1920x1080
  30. 所以在设计游戏时,只考虑屏幕的分辨率即可,不用考虑屏幕的实际长宽。 */
  31. /************************************************************************/
  32. /*
  33. WinSize就是设计分辨率,相当于游戏设计的逻辑大小,可以这样理解,上面的FrameSize就是画框,这里的WinSize就是画布。
  34. VisibleSize就是画布显示在画框中的部分,注意:它的大小是用WinSize来表示的。
  35. VisibleOrigin就是VisibleSize在画框中的左下角坐标点,注意也是用WinSize来表示的。
  36. */
  37. auto visibleSize = Director::getInstance()->getVisibleSize();
  38. auto origin = Director::getInstance()->getVisibleOrigin();
  39. // 添加一个关闭按钮icon,设置回调函数,这是一个自动释放的对象
  40. auto closeItem = MenuItemImage::create(
  41. "CloseNormal.png",
  42. "CloseSelected.png",
  43. CC_CALLBACK_1(HelloWorld::menuCloseCallback,this));
  44. closeItem->setPosition(origin + Vec2(visibleSize) - Vec2(closeItem->getContentSize() / 2));
  45. //常见一个菜单,它是一个自动释放的对象
  46. auto menu = Menu::create(closeItem, nullptr);
  47. menu->setPosition(Vec2::ZERO);
  48. this->addChild(menu, 1);
  49. //常见一个label标签,字体是arial.ttf
  50. auto label = Label::createWithTTF("Hello World", "fonts/arial.ttf", TITLE_FONT_SIZE);
  51. // label的位置设置到屏幕中心
  52. label->setPosition(origin.x + visibleSize.width/2,
  53. origin.y + visibleSize.height - label->getContentSize().height);
  54. //添加标签到这个层上
  55. this->addChild(label, 1);
  56. // 添加HelloWorld图片
  57. auto sprite = Sprite::create("HelloWorld.png");
  58. //精灵的位置在屏幕中心
  59. sprite->setPosition(Vec2(visibleSize / 2) + origin);
  60. // 把精灵作为儿子加到层上
  61. this->addChild(sprite);
  62. return true;
  63. }
  64. //回调函数
  65. void HelloWorld::menuCloseCallback(Ref* sender)
  66. {
  67. //Director结束执行,释放资源
  68. Director::getInstance()->end();
  69. #if (CC_TARGET_PLATFORM == CC_PLATFORM_IOS)
  70. //IOS的退出
  71. exit(0);
  72. #endif
  73. }

HelloWorldScene.cpp中的代码中的Scene* HelloWorld::scene(),实现了创建场景的过程:

1、创建场景

2、创建层 

3 、将层加到场景上

4、返回场景

HelloWorldScene.cpp中的代码中的Scene* HelloWorld::init(),实现了初始化实例:

1、初始化父类的Layer

2、得到窗口的大小(WinSiez)

3、得到窗口的坐标(左下角点)

4、创建关闭按钮(Normal、Push)和回调函数

5、设置关闭按钮的位置

6、创建菜单项

7、设置菜单项的位置

8、设置菜单的位置

9、将菜单加到层中

10、创建标签

11、设置标签的位置

12、将标签加到层上

13、创建精灵

14、设置精灵的位置

15、将精灵加到层上




文章来源: yujiang.blog.csdn.net,作者:鱼酱2333,版权归原作者所有,如需转载,请联系作者。

原文链接:yujiang.blog.csdn.net/article/details/51484119

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。