LoginSignup
11
11

More than 5 years have passed since last update.

Cocos2d-xのLuaプロジェクトの作成

Posted at

「Cocos2d-x Advent Calendar 2014」の8日目は @zukkun が担当します。

Cocos2d-xのLuaプロジェクトをコマンドラインから作る流れを紹介します。

環境はMac OS X 10.9.5です。

Cocos2d-xをダウンロード

Download Cocos2d-x Cocos2d-html5 Cocos Studio | Cocos2d-x

上記ページからCocos2d-xの「Download v3.2」を選び、Cocos2d-xをダウンロードします。

cocos2d-x-download.png

ダウンロードしたzipファイルを好きな場所に展開します。

セットアップ

コマンドラインで、その展開したディレクトリに移動し、setup.pyを実行します。

$ cd <Cocos2d-x path>
$ ./setup.py

途中でAndroid NDKとAndroid SDKのパスを聞かれますが、今回はスキップします。

使用しているシェルの設定ファイルに設定が追加された旨言われますので、指示に従いsourceコマンドで実行を行います。(自分の環境では~/.zshrcになりました)

Please execute command: "source <使用しているシェルの設定ファイル>" to make added system variables take effect
$ source <使用しているシェルの設定ファイル>

cocosコマンドが使えるようになっているのを確認します。

$ cocos -v
0.7

プロジェクトファイルの作成

プロジェクトディレクトリを作りたい場所に移動し、cocos newコマンドを使ってプロジェクトを作成します。今回、使用するディレクトリは/Users/zukkunを例として進めます。

ここでは、例としてプロジェクト名「HogeLua」として作成を行います。

$ cd /Users/zukkun/
$ cocos new HogeLua -p com.your_company.hogelua -l lua -d .

cocos newコマンドのパラメータとして、最初にHogeLuaとしている部分がプロジェクト名です。

次に、-p com.your_company.hogeluaとしているところがアプリパッケージ名で、iOSアプリ、Androidアプリなどをビルドする際に使用されます。

-l luaとしているところが「どのプロジェクトテンプレートを使用するか」という指定で、今回はLuaとしています。Luaでのゲームロジックの実装がすぐにできる状態でのプロジェクトが生成されます。他にcppを指定してC++での開発のためのテンプレートを使用することもできます。

上記コマンドを実行し、以下のように表示されたらプロジェクトファイルの作成の成功です。

Running command: new
> Copy template into /Users/zukkun/HogeLua
> Copying files from template directory...
> Copying cocos2d-x files...
> Rename project name from 'HelloLua' to 'HogeLua'
> Replace the project name from 'HelloLua' to 'HogeLua'
> Replace the project package name from 'org.cocos2dx.hellolua' to 'com.your_company.hogelua'

ディレクトリ構造

作成されたプロジェクトファイルのディレクトリ構造は以下のようになっています。

├── frameworks
│   ├── cocos2d-x -> こちらの内容のディレクトリ構造は省略
│   └── runtime-src
│       ├── Classes
│       ├── proj.android
│       ├── proj.ios_mac
│       ├── proj.linux
│       └── proj.win32
├── res
│   └── fonts
├── runtime
│   └── ios
└── src

frameworks/cocos2d-xをシンボリックリンクで対応する

frameworks/cocos2d-xは、ダウンロードしてきて展開したCocos2d-xのディレクトリへのシンボリックリンクでも代用できますので、バージョン管理する際はそうしておいた方がいいかもしれません。

今回、念のためそうしておきましょう。

まず、元のディレクトリをまるっと消してから、シンボリックリンクを貼ります。

$ cd /Users/zukkun/HogeLua
$ rm -rf frameworks/cocos2d-x
$ ln -s <Cocos2d-x path> framewoks/cocos2d-x

ビルドを試す

上記のシンボリックリンクが正しく行われているかどうかの確認も含め、プロジェクトのビルドを試します。

ビルドにはcocos compileコマンドを使用します。

$ cd /Users/zukkun/HogeLua
$ cocos compile -p mac

-p macは、ビルド対象のプラットフォームの指定で、今回Macで動作するもののビルドを試します。

※Mac, iOS向けのビルドにはXcodeがインストールされている必要があります

ビルドを実行すると、Cocos2d-xのエンジン全体のコンパイルが行われますので、ビルドに時間を要します。マシンのCPUファンが唸りを上げると思います。

最後に以下のような表示がされたら、ビルド成功です。

** BUILD SUCCEEDED **

build succeeded.

実行する

ビルドができたらcocos runコマンドで実行してみます。

$ cocos run -p mac

-p macは、cocos compileの時と同じ対象プラットフォームの指定になります。

上記の実行を行いますと、新たにウィンドウが開かれ、プロジェクトテンプレートに入っているままのサンプルが動作します。

cocos-lua-sample.png

陽気な音楽と共に、リスらしき生命体が延々と歩き出します。

ソースを読む

このテンプレートのサンプルのゲームロジックに相当するプログラムは、src/main.luaに記述されています。

ゲームロジックを書いていく場合、こちらのファイルを触ることになります。

実行されるLuaのファイルを変更する

プロジェクトテンプレートとしてsrc/main.luaが実行されるようになっているのは、C++側でsrc/main.luaが実行されるように記述されているからで、それを変更することで、実行されるLuaのファイルを変えることができます。

Luaが実行される記述がされているファイルはframeworks/runtime-src/Classes/AppDelegate.cppになります。

こちらのファイルに以下のような記述があります。

frameworks/runtime-src/Classes/AppDelegate.cpp
bool AppDelegate::applicationDidFinishLaunching()
{
    auto engine = LuaEngine::getInstance();
    ScriptEngineManager::getInstance()->setScriptEngine(engine);
    if (engine->executeScriptFile("src/main.lua")) {
        return false;
    }

    return true;
}

上記のengine->executeScriptFile("src/main.lua")がLuaの実行部分なので、ここを改変することが可能です。

また、プロジェクトテンプレートとしては、ゲームロジックすべてをLuaで書くことを想定しているような印象ですが、上記のようにC++側で任意にLuaを実行することが可能ですので、一部のゲームロジックのみLuaで記述したり、イベントスクリプトのような用途でのみLuaで記述する、といったことも可能ですが、比較的テクニカルな領域になりますので、さくっとゲームを作りたい、という場合は、ゲームロジックはすべてLuaで書く、という使用方法を選択するのが良さそうです。

サンプルの内容

src/main.luaの内容の読み解きとその解説もしようと思っていましが、けっこう時間を要しそう&長くなりそうなので、今回は割愛します。

Cocos2d-xの書籍

Cocos2d-xと言えば @giginet さんですが、そんなgiginetさんがCocos2d-xの本を出します!2014年12月24日発売予定です。

『cocos2d-xではじめるスマートフォンゲーム開発』という本を出版します - 5.1さらうどん

書籍には、Luaに関する解説は無いようですが、Luaから実行できるCocos2d-xのAPIは、C++のものと同じですので、本書はLuaでの開発にも生かせると思います。私も買います。

明日は @kyokomi さんです。

11
11
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
11
11