`

第一个Cocos2d-x Lua游戏

阅读更多

我们的编写的第一个Cocos2d-x Lua程序,命名为HelloLua,从该工程开始学习其它的内容。
创建工程
我们创建Cocos2d-x Lua工程可以通过Cocos2d-x提供的命令工具cocos实现,但这种方式不能与Cocos Code IDE集成开发工具很好地集成,不便于程序编写和调试。由于Cocos Code IDE工具是Cocos2d-x开发的专门为Cocos2d-JS和Cocos2d-x Lua开发设计的,因此使用Cocos Code IDE工具很方便创建Cocos2d-x Lua工程。
首先我们需要在Cocos Code IDE工具中先配置Lua框架,打开Cocos Code IDE工具,选择菜单Window→Preferences,弹出对话框如图所示,选择Cocos→Lua在右边的Lua Frameworks中选择<Cocos2d-x引擎目录>。

配置Lua框架

Lua框架配置不需要每次都进行,只是在最开始的配置一下,但创建工程的时候,Cocos Code IDE工具会从这个Lua框架目录中创建工程文件。
接下来我们就可以创建Lua工程了,选择菜单File→New→Project,如下图所示,弹出项目类型选择对话框。

项目类型选择对话框



我们选中Cocos Lua Project,然后点击Next按钮,弹出如下图所示的对话框。我们在Project Name项目中输入工程名称,Create Project in Workspace是在Workspace目录中创建工程,我们需要选中该项目,Create From Existing Resource项目选中可以让我们从已经存在的工程创建,现在我们不需要选中该项目。
选择完成点击Next按钮进入到如图所示配置运行环境对话框,在该对话框中我们可以配置项目运行时信息。Orientation项目是配置模拟器的朝向,其中landscape是横屏显示,portriat是竖屏显。Desktop Runtime Settings中的Title是设置模拟器的标题,Desktop Windows initialize Size是设置模拟器的大小。Add Native Codes是设置添加本地代码到工程,在本来中我们不需要添加本地代码。最后点击Finish按钮完成创建操作,创建好工程之后,如后图所示。

新建项目对话框

 

配置运行环境对话框

 

创建工程成功界面

Cocos Code IDE中运行
创建好工程后我们可以测试一下,在左边的工程导航面板中选中HelloLua工程,右键菜单中选择Run As→Cocos luainding运行我们刚刚创建的工程,运行结果如下图所示。

 

运行工程界面

我们主要编写的程序代码是在src目录下,在本例中Lua 文件负责处理主要的场景界面逻辑。如果我们想调试程序,可以设置断点,如下图所示,点击行号之前的位置,设置断点。

设置断点

调试运行过程,右键菜单中选择Debug As→Cocos Luabinding菜单。如下图所示,程序运行到第31行挂起,并进入调试视图,在调试视图中我们可以查看程序运行的堆栈、变量、断点、计算表达式和单步执行程序等操作。


 

运行到断点挂起



工程文件结构
我们创建的HelloLua工程已经能够运行起来了,下面我们介绍一下HelloLua工程中的文件结构,我们使用Cocos Code IDE打开HelloLua工程,左侧的导航面板如下图所示。

 

 HelloLua工程中的文件结构



在上图所示导航面板中,res文件夹存放资源文件的,src文件夹是主要的程序代码main.lua和GameScene.lua,其中main.lua是程序入口文件,Cocos2d-x会在底层绑定该文件,并且启动和运行它。GameScene.lua中实现了游戏场景。

代码解释
HelloLua工程中主要有两文件下面我们详细解释一下它们内部的代码: 

1、main.lua文件
main.lua是程序入口文件代码如下:

r

[html] view plaincopy
 
  1. equire "Cocos2d"                                                        ①  
  2.   
  3. -- cclog  
  4. local cclog = function(...)                                                 ②  
  5.     print(string.format(...))                                               ③  
  6. end  
  7.   
  8.   
  9. -- for CCLuaEngine traceback  
  10. function __G__TRACKBACK__(msg)                                      ④  
  11.     cclog("----------------------------------------")  
  12.     cclog("LUA ERROR: " .. tostring(msg) .. "\n")  
  13.     cclog(debug.traceback())  
  14.     cclog("----------------------------------------")  
  15.     return msg  
  16. end  
  17.   
  18.   
  19. local function main()                                                       ⑤  
  20.     collectgarbage("collect")                                               ⑥  
  21.     -- avoid memory leak  
  22.     collectgarbage("setpause", 100)                                     ⑦  
  23.     collectgarbage("setstepmul", 5000)                                      ⑧  
  24.       
  25.     cc.FileUtils:getInstance():addSearchPath("src")  
  26.     cc.FileUtils:getInstance():addSearchPath("res")  
  27.     cc.Director:getInstance():getOpenGLView():setDesignResolutionSize(480, 320, 0)  
  28.       
  29.     --create scene   
  30.     local scene = require("GameScene")                                      ⑨  
  31.     local gameScene = scene.create()                                        ⑩  
  32.     gameScene:playBgMusic()  
  33.       
  34.     if cc.Director:getInstance():getRunningScene() then                         ⑪  
  35.         cc.Director:getInstance():replaceScene(gameScene)                         
  36.     else  
  37.         cc.Director:getInstance():runWithScene(gameScene)                         
  38.     end  
  39.   
  40.   
  41. end  
  42.   
  43.   
  44.   
  45.   
  46. local status, msg = xpcall(main, __G__TRACKBACK__)                          ⑫  
  47. if not status then  
  48.     error(msg)  
  49. end  



上述代码第①行require是在加载Cocos2d模块,并且可以避免重复加载。第②行代码是声明cclog函数,该函数的作用是输出日志信息。第③行代码print(string.format(...))是输出函数。
第④行代码是声明__G__TRACKBACK__(msg)函数,在程序出错的时候由第⑫行的xpcall调用,并输出堆栈信息。下面是日志输出的堆栈信息:

[html] view plaincopy
 
  1. [LUA-print] stack traceback:  
  2.     [string ".\src/main.lua"]:13: in function '__index'  
  3.     [string ".\GameScene.lua"]:52: in function <[string ".\GameScene.lua"]:49>  
  4. [LUA-print] ----------------------------------------  

第⑤行代码是main()函数,它是由第⑫行的xpcall函数调用。第⑥行代码collectgarbage("collect")中的collectgarbage是垃圾收集器的通用接口函数,用于操作垃圾收集器,其它的定义如下:
collectgrabage(opt [, arg])  
其中的 opt参数是操作方法标志,标志包括如下:
collect : 执行一次全垃圾收集周期,见代码第⑥行。 
stop : 停止垃圾收集器。
restart : 重启垃圾收集器。
count : 返回当前Lua中使用的内存数量,单位KB。
step : 单步执行一个垃圾收集,步长中的size属性是由参数arg指定,如果完成一次收集周期,将返回true。
setpause: 设置arg/100的值作为垃圾收集暂停时长,见代码第⑦行。
setstepmul: 设置arg/100的值,作为步长的增幅,即“新步长” = “旧步长” * (arg/100),见代码第⑧行。  


上述代码第⑨行local scene = require("GameScene")加载GameScene模块,返回值是table类型全局变量。第⑩行代码local gameScene = scene.create()从通过静态create()函数创建GameScene场景。
代码第⑪行cc.Director:getInstance():getRunningScene()是判断是否有一个场景正在运行,如果有场景运行则通过cc.Director:getInstance():replaceScene(gameScene)语句使用gameScene场景替换当前场景,否则通过cc.Director:getInstance():runWithScene(gameScene)语句运行gameScene场景,无论是replaceScene还是runWithScene函数游戏都会是进入到gameScene场景。
代码第⑫行local status, msg = xpcall(main, __G__TRACKBACK__)中的xpcall函数是Lua提供,用于调用其它函数,并且可以捕获到错误,xpcall函数的定义如下:
xpcall (f, err)
其中f参数是要调用的函数,err是捕获道错误时候调用的函数。返回值status是错误状态和msg是错误消息。
事实上第⑫行代码local status, msg = xpcall(main, __G__TRACKBACK__)才是程序的入口。由它调用main()函数,如图3-19所示调用堆栈中,能够看出它们的调用顺序。

调用堆栈



2、GameScene.lua文件
GameScene.lua负责创建游戏主场景,我们看到的图3-15所示的场景就是在GameScene.lua中实现的,GameScene.lua主要代码如下: 
r

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. equire "Cocos2d"  
  2. require "Cocos2dConstants"  
  3. --声明GameScene类  
  4. local GameScene = class("GameScene",function()                              ①  
  5.     return cc.Scene:create()  
  6. end)  
  7. --静态创建函数  
  8. function GameScene.create()                                             ②  
  9.     local scene = GameScene.new()                                       ③  
  10.     scene:addChild(scene:createLayerFarm())                                 ④  
  11.     scene:addChild(scene:createLayerMenu())                                 ⑤  
  12.     return scene  
  13. end  
  14.   
  15.   
  16. --构造函数  
  17. function GameScene:ctor()                                               ⑥  
  18.     self.visibleSize = cc.Director:getInstance():getVisibleSize()  
  19.     self.origin = cc.Director:getInstance():getVisibleOrigin()  
  20.     self.schedulerID = nil  
  21. end  
  22. --播放背景音乐  
  23. function GameScene:playBgMusic()  
  24.     local bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("background.mp3")   
  25.     cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true)  
  26.     local effectPath = cc.FileUtils:getInstance():fullPathForFilename("effect1.wav")  
  27.     cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath)  
  28. end  
  29. --创建Dog精灵  
  30. function GameScene:creatDog()                                           ⑦  
  31.    … …  
  32.   
  33.   
  34.     local spriteDog = cc.Sprite:createWithSpriteFrame(frame0)  
  35.    … …  
  36.   
  37.   
  38.     return spriteDog  
  39. end  
  40.   
  41.   
  42. -- create farm 创建农场层  
  43. function GameScene:createLayerFarm()                                        ⑧  
  44.     local layerFarm = cc.Layer:create()                                     ⑨  
  45.     … …  
  46.   
  47.   
  48.     return layerFarm  
  49. end  
  50.   
  51.   
  52. -- create menu 创建菜单层  
  53. function GameScene:createLayerMenu()                                        ⑩  
  54.   
  55.   
  56.     local layerMenu = cc.Layer:create()  
  57.     … …  
  58.       
  59.     return layerMenu  
  60. end  
  61.   
  62.   
  63. return GameScene                  



我们在GameScene.lua中创建GameScene场景,并在场景中添加了农场层和菜单层。第①行代码是声明GameScene场景类,class("GameScene",function(){…})函数是由Cocos2d-x Lua引擎提供的,可以通过Lua创建创建对象。class函数定义如下:
class(classname, super) 
其中参数classname是函数名,它是字符串类型,super是调用父类构造函数。
第②行代码声明GameScene.create()静态函数,在main.lua中通过scene.create()语句调用。第③行代码local scene = GameScene.new()是创建GameScene创建对象,new()函数会调用第⑥行的GameScene:ctor()函数,ctor()是构造函数,用来初始化GameScene场景对象。第④行代码是调用GameScene场景对象的createLayerFarm()函数创建农场层(见代码第⑧行)。第⑤行代码是调用GameScene场景对象的createLayerMenu()函数创建菜单层(见代码第⑩行)。
代码第⑦行函数是创建Dog精灵,使用cc.Sprite:createWithSpriteFrame(frame0)语句创建精灵对象,我们将在后面详细介绍。
在创建农场层函数createLayerFarm()中的⑨行local layerFarm = cc.Layer:create()是创建层对象,我们将在后面详细介绍。

第⑪行代码返回GameScene变量,它是table类型,它是在main()函数中调用local scene = require("GameScene")语句时候返回的。

 

更多内容请关注最新Cocos图书《Cocos2d-x实战:JS卷——Cocos2d-JS开发

本书交流讨论网站:http://www.cocoagame.net

欢迎加入Cocos2d-x技术讨论群:257760386

更多精彩视频课程请关注智捷课堂Cocos课程:http://v.51work6.com

《Cocos2d-x实战 JS卷》现已上线,各大商店均已开售:

 

 

 

 

 

京东:http://item.jd.com/11659698.html

欢迎关注智捷iOS课堂微信公共平台,了解最新技术文章、图书、教程信息

分享到:
评论

相关推荐

    Cocos2d-x之C++和Lua通信5个入门Demo

    木头Cocos2d-x教程 Lua篇 Demo源代码。 教程地址: 第1章:http://blog.csdn.net/musicvs/article/details/8440707 第2章:http://blog.csdn.net/musicvs/article/details/8440919 第3章:...

    关东升-Cocos2d-x实战:Lua卷

    《Cocos2d-x实战 Lua卷》是介绍Cocos2d-x Lua游戏编程和开发技术的书籍,本书是第1版,带完整书签

    Cocos2d-Lua-社区:基于Cocos2d-x 4.0,打造易用稳定的Cocos2d-x lua引擎

    Cocos2d-Lua社区Cocos2d-Lua-Community是Cocos2d-x 4.0的改进,并且易于使用Lua游戏引擎。 它是与Quick-Cocos2dx-Community v3.7.x兼容的Lua“框架”。得到帮助 QQ群:社区版千人群(1群)号:361920466社区版2群:...

    Cocos2d-x实战:Lua卷(第2版)书籍代码

    这是书籍 Cocos2d-x实战:Lua卷(第2版)的代码,关东升老师的,这里分享出来。除了章节的小示例代码外,还有一个《迷失航线》的游戏示例代码。这是一个下载地址。

    cocos2d-x半即时战斗rpg游戏demo源码

    本游戏主要用于技术的研究和积累 游戏第一次启动的时候会把数据库复制到可写文件夹,若数据库结构因为一些改动发生了变化,需要把旧的数据库删除。...编译时需要将本游戏的目录复制到cocos2d-x-2.2.x/projects/。

    Cocos2D-X游戏开发技术精解

    第1章 Cocos2D-X引擎的介绍 1 1.1 何为游戏引擎 1 1.1.1 游戏的核心—引擎 1 1.1.2 引擎的特点 2 1.1.3 知名的引擎介绍 4 1.1.4 引擎的分类 5 1.2 Cocos2D-X引擎的来历 8 1.3 引擎的版本 9 1.4 下载与安装 10 1.5 ...

    Cocos2d x手机游戏开发与项目实战详解.part3

    第一部分:基础篇[1] 第一章主要是手机游戏概述,包括游戏概述、手机游戏类型和开发平台的分析;  第二章介绍手机游戏的策划,包括分析玩家需求,编写策划文案,游戏原型的实现。  第三章介绍C、C++编程基础,对于...

    Cocos2d-x3.X游戏开发入门精解 [渥瑞达,冉伟,李连胜 编著] 2015年版

    第13~15 章讲解Cocos2d-x 中的Lua 脚本语言开发、CocosStudio 工具及粒子系统的使用方法;第16~19 章讲解数据统计工具的使用方法、项目跨平台移植发布、iOS 真机测试与发布、SVN 版本控制;第20 章讲解一个完整的...

    Quick-Cocos2dx-社区:Cocos2d-Lua社区版

    Cocos2d-x Lua社区版是在Cocos2d-x的基础上,关注于Lua进行游戏开发的引擎框架变种,意在减少重复造轮,节省开发人员的时间。 官方网站 社区版千人群(1群)号:361920466 社区版2群:138934064 相关开源仓库地址 ...

    genius-x:基于 Cocos2d-x 的实体组件系统框架

    Genius-xGenius-x是一个基于以属性为中心的游戏对象模型构建的游戏框架,它基于Cocos2d-x,目前支持使用C++/Lua两种语言进行开发,Genius-x最大的目标是要实现数据驱动,使程序中关于关卡设计的部分可以最大限度地从...

    engine-x:这是Cocos2d-x-4.0的另一个更根本的分支,在所有平台上使用OpenAL,单纹理多GPU纹理处理程序C ++ 1417。

    引擎-x 这是Cocos2d-x-4.0的另一个更根本的分支,在所有平台上使用OpenAL,单纹理多GPU纹理处理程序,C ++ 14/17等(更多信息,请参见“突出功能”)。目的摘要C ++ 14/17 专注于本机游戏开发人员(快速启动,易于...

    cocos2d 纯lua写的连连看游戏

    用Lua写的一个连连看小游戏,里面资源和代码都在里面,由于是本人第一次练习写的,有些游戏的优化还有待提高。

    Fariy2D:由OpenGL和Lua支持的简单2D游戏引擎

    1 用到的第三方库包括lua,tcmalloc,stb_image,glew等 2 程序最大的优点是简单明了,最大的缺点是绘制图形时没有合并batch,绘一张图提交一次。(不过可以修改lua来合并batch) 3 代码比较规范除了某个头文件使用了...

    网狐荣耀版开发使用常见问题解答

    三、安装cocos,这里我们使用的是cocos2d-x 3.10,3.10版本,Cocos2d-x与cocos整合升级为Cocos引擎,下载后是exe程序,双击直接安装,很简单。 四、下载自动提示补全词典,我还下载了cocos2dx-3.10-api.lua,把下载...

Global site tag (gtag.js) - Google Analytics