使用cocos2d-x v3.1开发小游戏(基本框架)

小游戏的组成

  • 欢迎界面

在游戏资源未全部加载完之前就需要载入,避免进入游戏会有一段黑屏时间。

可以用来展示游戏名称或者开发者logo。

  • 开始菜单界面

一般用于显示游戏名称和关卡选择(或者称游戏难度选择)。

可以外加一些设置性功能,如声音开关,帮助入口等等。

如果游戏设置内容较多可以把设置作为一个单独界面,在开始菜单上提供入口即可。

有的小游戏是以弹窗方式的菜单

  • 主游戏界面

游戏的中心部分,比如2048游戏的格子滑动界面,扫雷游戏的扫雷界面,贪吃蛇游戏的蛇移动的界面,等等。

小游戏拥有这一个界面也能算一个小游戏,但是没有其他界面会使游戏缺少更多选择。

游戏的主要逻辑都是在完成这个界面。

  • 游戏结束界面

游戏结束一般都会有个分数,用于展示本次游戏得分和历史最高得分对比。

在这个界面上可以添加再玩一次的按钮,让玩家重新玩一次。

大多数小游戏都是以弹窗的方式展示游戏结果。

  • 排行榜界面 (可选)

游戏中有分数这个概念就会有排名。

可以是单机的排行榜,也可以是联机的排行榜(需要服务器保存数据)。

排行榜可以促进玩家拿到更高的分数(也是有缺点的,看到其他玩家玩的分数太高了而放弃了)。

cocos2d-x v3.1 lua 框架的使用

  • lua代码结构

src
├── conf.lua                  # 配置文件,一些不变的配置保存在这里
├── GameOverScene.lua         # 游戏结束的界面
├── GameScene.lua             # 游戏主逻辑界面
├── HelloScene.lua            # 欢迎界面,在这里做资源更新检测
├── main.lua                  # 游戏lua脚本的入口
├── MainMenuScene.lua         # 游戏主菜单界面
├── RankScene.lua             # 排行榜界面
└── util.lua                  # 通用功能函数实现

 

每个XXOOScene.lua 文件的样子如下:
local XXOOScene = {}

XXOOScene.newScene = function ()
    local scene = cc.Scene:create()
    -- do other XXOO things
    return scene
end

return XXOOScene

 

关于Scene界面跳转,在util中封装一个通用函数用于界面跳转。
function util.toScene(scene)
    -- 增加一个统一的界面跳转动画
    scene = cc.TransitionSlideInR:create(0.5, scene)
    if cc.Director:getInstance():getRunningScene() then
        cc.Director:getInstance():replaceScene(scene)
    else
        cc.Director:getInstance():runWithScene(scene)
    end
end

 

main.lua用户进入HelloScene界面
  • HelloScene = require("src/HelloScene")
     
    local function main()
        cc.FileUtils:getInstance():addSearchResolutionsOrder("src")
        cc.FileUtils:getInstance():addSearchResolutionsOrder("res")
     
        HelloScene.newScene()
    end
     
     
    local status, msg = xpcall(main, __G__TRACKBACK__)
    if not status then
        error(msg)
    end

     

    游戏启动logo的Scene特殊处理

因为加载lua资源需要时间,待所有资源都加载完再创建游戏启动界面会出现启动的时候黑屏。我在1G的安卓机上测试需要5秒才能进入到lua创建的Scene。

解决方案:在 C++ 中创建启动画面,HelloScene.lua中不做创建Scene的操作,直接getRunningScene。

  • AppDelegate::applicationDidFinishLaunching () {
    
        // ... other xxoo things
    
        auto scene = Scene::create();
        auto s = Director::getInstance()->getWinSize();
        auto layer = LayerColor::create(Color4B(255, 255, 255, 255), s.width, s.height);
        auto logo = Sprite::create("res/logo.png");
        layer->addChild(logo);
        logo->setPosition(Vec2(s.width*0.5,s.height*0.7));
        scene->addChild(layer,0);
        director->runWithScene(scene);
     
        // 特殊处理,延迟加载lua(创建好logoScene再加载)
        auto action = CallFunc::create(startLua);
        layer->runAction(action);
    
        return true;
    }

     

    cocos2d-x v3.1 引擎的精简

起因: 引擎编译完之后发现lib文件相比2.x版本的大了不少。由于是做小游戏,一般都会有用不到的引擎部分,比我我就没用到ui编辑器,所以就想办法不编译ui编辑器部分。

步骤:

  • 找到mk文件: $ find . -name "Android.mk"

  • 修改mk文件,把与ui编辑器相关的语句注释掉。

  • 编译,在编译错误提示中找出还有什么需要注释的代码。我遇到的问题主要是CCB那些。需要在lua_cocos2dx_extension_manual.cpp中把CCB的代码注释。

  • CCLuaStack.cpp中也需要注释几个注册函数。

我还精简了物理引擎,刚开始是用到了的,但后面看小游戏用不上就把它也干掉了(大概省下1M)。

  • cocos/scripting/lua-bindings/auto/ 下的文件生成

看README后执行生成命令,遇到了一些问题:

  • 问题1:官方只提供ubuntu 64位的libclang.so文件,在32位机子上跑会报下面这个错误

  • LibclangError: libclang.so: wrong ELF class: ELFCLASS64. To provide a path to libclang use Config.set_library_path() or Config.set_library_file().

  • 解决方法:在llvm官网下载4.3版本的llvm和clang。编译生成libclang.so.3.4。拷贝到bindings-generator/libclang/下覆盖libclang.so文件。怎么编译的那个博客现在找不到了,步骤大概是:

  • clang-3.4.src.tar.gz 和 llvm-3.4.src.tar.gz 。解压,然后把clang目录拷贝到llvm-3.4/tools/下。编译,在llvm-3.4同一个目录下建一个build文件夹,进入到build,执行cmake ../llvm-3.4/CMakeLists.txt

文字描述可能不清晰,目录结构如下:

 

. -> build
| ->llvm-3.4  -> tools -> clang -> CMakeLists.txt
             |-> CMakeLists.txt

 

  • 问题2: 找不到头文件,报错出现unkown type name ,原因是官方配置的android_headers路径和我电脑上的不一样,主要是gcc的版本,我的是4.8的,官方配置是4.7。如下:

  • details = "unknown type name '__locale_t'"

  • 解决方法:修改cocos2dx.ini中的android_headers 的值把/cxx-stl/gnu-libstdc++/4.7/ 改成/cxx-stl/gnu-libstdc++/4.8/ 。有两个地方要修改。这个问题要看自己的安卓ndk的配置情况,也许你的还是4.6呢,自己可以去ndk对应的路径下找找看自己的ndk版本。

全民顶爆菊花

应用宝:http://android.myapp.com/myapp/detail.htm?apkName=com.hanxi.runtodie

百度手机助手:http://as.baidu.com/a/item?docid=6678809

豌豆荚:http://www.wandoujia.com/apps/com.hanxi.runtodie

代码地址:https://github.com/hanxi/cocos2d-x-v3.1

【加几张游戏效果图】

posted @ 2014-07-16 10:07  涵曦  阅读(5166)  评论(2编辑  收藏  举报