从零开始写一个武侠冒险游戏-0-开发框架Codea简介

  • 作者:FreeBlues
  • 修订记录
    • 2016.06.21 初稿完成.
    • 2016.08.03 增加对 XCode 项目文件的说明.

概述

本游戏全程使用一款运行于 iPad 上的开发工具类 APP--Codea 来开发, Codea 是一款 轻量级 + 全功能的开发工具, 它既是一个:

  • 运行时库-Runtime

也是一个:

  • 框架-Frameworks

还是一个:

  • 集成开发环境-IDE

更是一个:

  • 调试服务器-debugSever, 可通过浏览器来云端调试代码.

它还是 Lua 语言的一种扩展, 本质上它就是一个运行于 iPad 上可以动态加载运行 Lua 代码的应用程序.

它实现了一个非常易于使用的编程框架(类似于 ProcessingOpenFrameWorks):

  • setup() 函数, 负责初始化工作, 程序启动时运行一次;
  • draw() 函数, 负责屏幕绘制, 1秒钟刷新 60 次;
  • touched(touch) 函数, 负责处理屏幕触摸;
  • keyboard(key) 函数, 负责处理键盘操作;
  • collide(contact) 函数, 负责处理物理模拟中的碰撞检测;
  • orientationchanged(newOrientation) 函数, 负责检测屏幕位置(是否翻转)

用它提供的功能丰富的函数你可以在 iPad 上编写各种程序, 它提供了:

  • 基本绘图函数, 实现一些基本的绘图函数
  • 高级绘图函数, 支持 OpenGL ES 2.0/3.0, 直接编写 shader 代码, 即时查看运行结果;
  • Lua 语言的大多数函数, 如 table相关, string 相关, os 相关, 以及 math 相关的一些函数, 还包括协程 coroutine;
  • Lua 的一些库, 如 socket, lpeg, json
  • 触控函数, 负责处理屏幕触摸事件;
  • 调试函数, 负责处理程序调试工作;
  • 物理模拟函数, 封装 box2D 提供了相关的物理模拟函数;
  • 动画函数, 一个专门的动画类, 可以利用它来实现各种动画效果;
  • 声音函数, 负责处理播放声音以及生成各种音效;
  • 显示函数, 负责处理显示模式设置以及视频录制等等
  • 矢量函数, 提供了二维, 三维, 四维向量以及相关的各种操作;
  • 传感器函数, 负责处理 GPS 定位传感器和 加速度 传感器;
  • 网络函数, 提供了封装后的 http.request() 函数
  • 存储函数, 提供了各种存取函数, 用于存取游戏数据到 iPad 上.

它提供了一个 IDE, 可以编辑/调试/运行代码, 非常适合触屏操作. 也非常适合那些希望能随时随地拿起平板就能编程的开发者, 据本软件开发者 Simen 自述, 最初就是因为他想在平板电脑上随时运行一些代码片段, 于是萌生了这个想法, 结果一步步搞出这么一个超级方便很受欢迎的 iPad 开发工具来.

它可以把你编写的代码导出为一个 XCode 项目, 然后编译成一个真正的 APP 发布到 APP Store, 当然了, 需要你拥有一个开发者账号.

我用过很多 iPad 上的编程工具, 最喜欢的一款是 Codea , 而且为了更好地发挥它的作用, 专门去认真学了 Lua.

接下来我们会对 Codea 做一个介绍, 让读者对我们后续即将使用的开发工具有一个初步了解.

界面

启动进入

启动 Codea 后进入主界面, 如下:

示例

Codea 自带了一些示例程序, 如下:

左侧菜单栏

点开左侧菜单栏, 出现 4 个选项

内置函数手册

Codea 中内置了全部的函数说明, 非常方便在编程时随手查阅

shader实验室

左侧菜单栏的第二项是一个 shader 实验室, 你可以在里面调试自己的 shader 代码

自带素材库

左侧菜单栏第三项是 Codea 自带的素材库, 有一些可以免费使用的图片素材和音乐音效素材, 还有一些 shader模板, 用户也可以自行添加素材到素材库

编辑界面

编辑界面自带联想输入, 非常方便直接在 Codea 上输入代码

程序框架说明

Codea 的运行机制是这样的:

  • setup() 只在程序启动时执行一次
  • draw() 在程序执行完 setup() 后反复循环执行, 每秒执行 60
  • touched()draw() 类似, 也是反复循环执行

简单说, 就是类似于这样的一个程序结构:

setup()

while true do
...
draw()
touched(touch)
...
end

如果读者有过使用 ProcessingOpenFrameWorks 的经验, 就比较熟悉这种框架了, 这种框架的优点就是结构简单易懂, 流程非常清晰, 容易上手, 而且功能也不弱, 反而 Cocos2d-x 的那种又是场景, 又是导演的框架比较麻烦.

如果你愿意, 也很容易在它的基础上自己搞一个 MVC 架构出来, 如果你想实现更复杂的流程控制, 可以通过 Luacoroutine 自行扩展, 也可以参考本教程提供的用 coroutine 实现的 Threads 类.

主要函数说明

Codea 的函数大多数都支持可变参数, 根据输入实参的个数决定对应哪些形参, 好像在面向对象中叫多态. 下面在每种函数中选择两个常用的函数

基本绘图函数

  • background( )

    • 语法
    • background( gray )
    • background( gray, alpha )
    • background( red, green, blue )
    • background( red, green, blue, alpha )
    • background( color )
  • rect( )

    • 语法
    • rect( x, y, width, height )
  • sprite( name, x, y )

    • 语法
    • sprite( name, x, y )
    • sprite( name, x, y, width )
    • sprite( name, x, y, width, height )
    • sprite( image, x, y )
    • sprite( image, x, y, width )
    • sprite( image, x, y, width, height )

高级绘图函数

提供 shadermesh

支持 OpenGL ES 2.0/3.0

Lua 语言

Lua中的 , 时间,字符串数学运算 以及一部分 os 函数

触控函数

负责处理屏幕触摸事件;

调试函数

负责处理程序调试工作;

物理模拟函数

封装 box2D 提供了相关的物理模拟函数;

动画函数

一个专门的动画类, 可以利用它来实现各种动画效果;

声音函数

负责处理播放声音以及生成各种音效;

显示函数

负责处理显示模式设置以及视频录制等等

矢量函数

提供了二维, 三维, 四维向量以及相关的各种操作;

传感器函数

负责处理 GPS 定位传感器和 加速度 传感器;

网络函数

提供了封装后的 http.request() 函数

存储函数

提供了各种存取函数, 用于存取游戏数据到 iPad 上.

其他在 iPad 上运行的开发工具

除了 Codea, 还有很多可以运行在 iPad 上的编程工具, 比如 Processing, TechBASIC 等等, 它们各有所长.

苹果在最近的 WWDC 上宣布 iOS 10 会提供一款名为 Swift Playground 的免费开发工具, 看来随着平板电脑性能的提升, 用平板编写代码已经是趋势所向.

如何使用本教程中的源码

你有两种方式来运行本教程的示例, 一种是下载源码, 直接在 iPad 上通过 Codea 来运行, 另一种是下载对应的 XCode 项目文件包, 然后在 XCode 中把它编译为一个 ipa 应用, 再把它加载到模拟器上运行.

直接在 iPad 上用 Codea 加载代码

如果你有 iPad, 并且购买了 Codea, 那么你可以打开 Codea, 新建一个项目, 把例程代码拷贝进去, 同时要把例程中用到的图像资源下载拷贝到 Codea 的素材库目录下, 一般是 Documents, 然后就可以运行了.

这种方法最简单, 也最方便, 唯一的不便之处是需要预先手动下载保存好图片素材(不过后续我会写几个自动下载保存图片的函数来提供更方便的使用)

通过 XCode 的 iOS 模拟器来运行

如果你没有 iPad, 或者虽然有 iPad, 但是暂时还不准备花 15 美元购买一份 Codea, 那么你还可以通过模拟器来运行.

这就需要你有一台安装了 XCodeMac 电脑, 或者你有一个安装了 XCodeOSX 虚拟机, 你只要把每章对应的 XCode 项目文件包下载回去, 然后在 XCode 中打开它, 编译运行, 就可以在模拟器中看到运行结果了.

而且你也可以在 XCode 中修改代码, 重新编译查看效果.

XCode项目文件夹结构

项目文件夹结构如下:

Air:Write-A-Adventure-Game-From-Zero admin$ tree
.
MyAdventureGame
├── Assets
│   ├── ...
├── Libs
│   ├── ...
├── MyAdventureGame
│   ├──...
├── MyAdventureGame.codea
│   ├──...
├── MyAdventureGame.xcodeproj
│   ├──...
└── libversion

其中我们编写的 Lua 脚本放在 MyAdventureGame.codea 目录下, 以 main.lua 命名, 如下:

Air:Write-A-Adventure-Game-From-Zero admin$ tree ./MyAdventureGame/MyAdventureGame.codea
./MyAdventureGame/MyAdventureGame.codea
├── Info.plist
├── Main.lua
├── Sprites.lua
└── Status.lua 0 directories, 4 files
Air:Write-A-Adventure-Game-From-Zero admin$

Codea的运行时库文件

  • 注意: 在用 XCode 编译项目时, 需要用到 Codea 的两个库文件: libcodea.alibtools.a.

当前版本 2.3.2, XCode 会自动从 Codea 官网下载, 不过貌似会被屏蔽, 再加上这两个文件稍微大了点(一个20 M, 一个 50M), 就没有放在 github 上, 改为放到百度网盘上Codea库文件下载, 下载回来后解压得到名为 libcodea.alibtools.a 的两个文件, 将其拷贝到项目文件夹的 Libs 目录下即可.

参考资源

官网函数手册

官方wiki

官网论坛

中文函数手册

所有章节链接

Github项目地址

Github项目地址, 源代码放在 src/ 目录下, 图片素材放在 assets/ 目录下, XCode项目文件放在 MyAdventureGame 目录下, 整个项目文件结构如下:

Air:Write-A-Adventure-Game-From-Zero admin$ tree
.
├── MyAdventureGame
│   ├── Assets
│   │   ├── ...
│   ├── Libs
│   │   ├── ...
│   ├── MyAdventureGame
│   │   ├──...
│   ├── MyAdventureGame.codea
│   │   ├──...
│   ├── MyAdventureGame.xcodeproj
│   │   ├──...
│   └── libversion
├── README.md
├── Vim 列编辑功能详细讲解.md
├── assets
│   ├── ...
│   └── runner.png
├── src
│   ├── c01.lua
│   ├── c02.lua
│   ├── c03.lua
│   ├── c04.lua
│   ├── c05.lua
│   ├── c06-01.lua
│   ├── c06-02.lua
│   ├── c06-03.lua
│   └── c06.lua
├── 从零开始写一个武侠冒险游戏-0-开发框架Codea简介.md
├── 从零开始写一个武侠冒险游戏-1-状态原型.md
├── 从零开始写一个武侠冒险游戏-2-帧动画.md
├── 从零开始写一个武侠冒险游戏-3-地图生成.md
├── 从零开始写一个武侠冒险游戏-4-第一次整合.md
├── 从零开始写一个武侠冒险游戏-5-使用协程.md
├── 从零开始写一个武侠冒险游戏-6-用GPU提升性能(1).md
├── 从零开始写一个武侠冒险游戏-6-用GPU提升性能(2).md
└── 从零开始写一个武侠冒险游戏-6-用GPU提升性能(3).md 2 directories, 26 files
Air:Write-A-Adventure-Game-From-Zero admin$

从零开始写一个武侠冒险游戏-0-开发框架Codea简介的更多相关文章

  1. 从零开始写一个武侠冒险游戏-8-用GPU提升性能(3)

    从零开始写一个武侠冒险游戏-8-用GPU提升性能(3) ----解决因绘制雷达图导致的帧速下降问题 作者:FreeBlues 修订记录 2016.06.23 初稿完成. 2016.08.07 增加对 ...

  2. 从零开始写一个武侠冒险游戏-7-用GPU提升性能(2)

    从零开始写一个武侠冒险游戏-7-用GPU提升性能(2) ----把地图处理放在GPU上 作者:FreeBlues 修订记录 2016.06.21 初稿完成. 2016.08.06 增加对 XCode ...

  3. 从零开始写一个武侠冒险游戏-6-用GPU提升性能(1)

    从零开始写一个武侠冒险游戏-6-用GPU提升性能(1) ----把帧动画的实现放在GPU上 作者:FreeBlues 修订记录 2016.06.19 初稿完成. 2016.08.05 增加对 XCod ...

  4. 从零开始写一个Tomcat(叁)--请求解析

    挖坑挖了这么长时间也该继续填坑了,上文书讲到从零开始写一个Tomcat(贰)--建立动态服务器,讲了如何让服务器解析请求,分离servlet请求和静态资源请求,读取静态资源文件输出或是通过URLCla ...

  5. 一起学习造轮子(二):从零开始写一个Redux

    本文是一起学习造轮子系列的第二篇,本篇我们将从零开始写一个小巧完整的Redux,本系列文章将会选取一些前端比较经典的轮子进行源码分析,并且从零开始逐步实现,本系列将会学习Promises/A+,Red ...

  6. 一起学习造轮子(一):从零开始写一个符合Promises/A+规范的promise

    本文是一起学习造轮子系列的第一篇,本篇我们将从零开始写一个符合Promises/A+规范的promise,本系列文章将会选取一些前端比较经典的轮子进行源码分析,并且从零开始逐步实现,本系列将会学习Pr ...

  7. 从零开始写一个npm包及上传

    最近刚好自己需要写公有npm包及上传,虽然百度上资料都能找到,但是都是比较零零碎碎的,个人就来整理下,如何从零开始写一个npm包及上传. 该篇文件只记录一个大概的流程,一些细节没有记录. tips:  ...

  8. 2019-5-24-WPF-源代码-从零开始写一个-UI-框架

    title author date CreateTime categories WPF 源代码 从零开始写一个 UI 框架 lindexi 2019-05-24 15:54:36 +0800 2018 ...

  9. 从零开始写一个前端脚手架四、初始化进程提示(chalk)

    我们之前说过bin里面的index.js文件是作为入口文件存在的.实际上的初始化内容在.action里面操作的,为了方便管理,我们把实际操作的代码抽出来放一块儿管理 创建指令文件 在根目录创建一个co ...

随机推荐

  1. C#_备份sqlserver数据库

    C# 代码备份数据库 ,不需要 其他 DLL protected void Button1_Click(object sender, EventArgs e)    {        ///     ...

  2. java的struts2项目实现网站首页只显示域名不显示index.do的做法

    自己的网站快做完了,发现首页显示的时候总是跳转到http://www.xxxxxx.com/index.do 而我想让http://www.xxxxxx.com/ 这样的方式来访问,不想带有后边的in ...

  3. 《Linux内核》读书笔记 第十八章

  4. Linux内核分析(第五周)

    系统调用的三层皮(下) 一.给MenuOs增加time和time-asm命令 ls rm menu -rf git clone xx(克隆新版本) cd menu make rootfs(自动编译生成 ...

  5. 剑指offer:合并两个排序的链表

    题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 解题思路: 这道题应该考察也是链表的相关操作.具体实现,新建一个新的链表,用两个指针分别指向两 ...

  6. 哥java学识有大进 干回之前的小学生系统像切菜一样简单 不说了 来代码

    package runok; import java.util.*; import java.awt.*; import java.awt.event.ActionEvent; import java ...

  7. Daily Scrum - 11/19

    今天任烁帮忙更新了大家在Sprint 2中的Task,基本每人的Task都是细分到每天的,这样大家初期的工作应该会更有效率一点. 任烁今天表示“进度条背词法”应该是可以融合到原有算法中的,期待他的改进 ...

  8. cdq分治解决三维偏序

    问题背景 在三维坐标系中有n个点,坐标为(xi,yi,zi). 定义一个点A比一个点B小,当且仅当xA<=xB,yA<=yB,zA<=zB.问对于每个点,有多少个点比它小.(n< ...

  9. ipmitool+python应用处理大量带外地址

    ipmitool 是一种可用在 linux 系统下的命令行方式的 ipmi 平台管理工具,它支持 ipmi 1.5 规范(最新的规范为 ipmi 2.0),通过它可以实现获取传感器的信息.显示系统日志 ...

  10. Caffe搭建:Ubuntu14.04 + CUDA7.0 + opencv3.0 + Matlab2014A

    从Hinton在science上发表深度学习训练开创新的文章以来,深度学习火了整整有3年多,而且随着新的硬件和算法的提出,深度学习正在应用于越来越多的领域,发挥其算法的优势. 实验室并没有赶上第一波深 ...