__________ .__ .___________
\______ \____ ______ |__| __| _/ _____/_____ _____ ____
| _|__ \ \____ \| |/ __ / \ ___\__ \ / \_/ __ \
| | \/ __ \| |_> > / /_/ \ \_\ \/ __ \| Y Y \ ___/
|____|_ (____ / __/|__\____ |\______ (____ /__|_| /\___ >
\/ \/|__| \/ \/ \/ \/ \/
RapidGame is a commandline tool for Mac and Windows (Linux support is planned) which:
-
Prebuilds cocos2d-x libraries for Mac, iOS, Android and Windows for multiple architectures and configurations, virtually eliminating the need to ever rebuild cocos2d-x or its Javascript bindings.
-
A game project templating system for creating cross-platform games for a variety of game engines, including cocos2d-x, Unity, Corona and Appcelerator Titanium. The default game template creates a simple Breakout clone with a menu and game scene.
Prefer somebody explaining and showing it? Check out the overview video.
- August 17, 2015: Fixes for Visual Studio 2015.
- August 11, 2015: On Windows, the path to MSBuild.exe, Lib.exe and VCTargetsPath can be set manually in case they cannot be automatically located.
- August 2, 2015: Upgraded to cocos2d-x 3.7 (cocos2d-js and cocos2d-x have now been merged into just cocos2d-x).
- June 2, 2015: Can now prebuild Android on Windows thanks to Samuel Ørsnæs.
- May 4, 2015: Upgraded to cocos2d-x 3.6 / cocos2d-js 3.6.
- Mar 15, 2015: Fixed another bug related to MSBuild path on Windows (thanks, Adam Yocum). Fixed the cocos2d-x Android template.
- Feb 24, 2015: Now has separate cocos2d-x and cocos2d-js templates. Fixed a bug on Windows: "Unable to find MSBuild path."
- Feb 19, 2015: Fixed a bug in Xcode projects (reference to script folder).
- Feb 7, 2015: Prebuilder updated for cocos2d-js 3.2 final / cocos2d-x 3.3.
- Dec 28, 2014: Prebuilder updated for cocos2d-js 3.2 rc0 / cocos2d-x 3.3.
- Aug 14, 2014: Prebuilder updated for cocos2d-js 3.0 rc2 / cocos2d-x 3.2.
You'll first need Node.js and Git.
There's no need to clone this repo, just install RapidGame:
sudo npm install rapidgame -g
Or, on Windows leave off the sudo
and ensure that git
is a part of your PATH:
npm install rapidgame -g
And, create a cocos2d-x game named "HeckYeah" (run this as administrator on Windows):
rapidgame create cocos2dx "HeckYeah" org.myorg.heckyeah
Or, a Unity game named "ZombieMatrix":
rapidgame create unity "ZombieMatrix" com.mycompany.zombiematrix
For usage instructions:
rapidgame --help
New to the cocos2d family of game engines? In general, cocos2d-x (rapidgame create cocos2dx
) is C++ and cocos2d-js (rapidgame create cocos2djs
) is Javascript.
Mac OS X: Xcode 5 or newer, Git and Node.js.
Windows: Visual Studio 2012 or newer (get it for free here), Git, and Node.js. Read the Windows Notes for additional notes you should be aware of.
Linux: support is planned.
Android: please read the Android README or watch the video to find out what you will need for Android development.
- The
rapidgame create
orrapidgame prebuild
command must be run in an admin console. This allows symlinks to be properly created, otherwise what should be symlinks will become regular folders and the command will fail. - If you have freshly installed Visual Studio, then you will need to run it once in order for it to download the necessary build tools.
- To compile the Android libraries successfully,
rapidgame prebuild
must be run via Cygwin. Read about all the specific requirements in the Android README, or watch the video instead. - Windows cannot build the cocos2d-x libraries or cocos2d-js bindings for iOS and Mac. If you want to use RapidGame to develop for these platforms, you must use a Mac.
Thanks to Samuel Ørsnæs for getting the Android build working in Windows!
A detailed guide has been written specifically for how to build Android projects using RapidGame. You can read it here, or alternatively find it in your cocos2d-x/js project as [APPNAME]/Projects/android/README.html
.
RapidGame provides:
- Tested game project templates for cocos2d-x / cocos2d-js, Unity, Corona and Titanium
- A cross-platform game project creator
- A library prebuilder for cocos2d-x
The templates have:
- Cross-platform project files
- Resolution / ratio-independence
- Viewport setup
- Menu & Game scenes
- Sprites
- Custom TTF fonts
- Sound
- Music
- Physics
- HTTP game servers (HTML5-based platforms)
The project creator makes a copy of one of the templates, does a search and replace on the game title & package name, then installs any required modules. Viola. Your own rapidly-created game ready to go. Here is some example output from running the project creator:
$ rapidgame create Corona "SwordBall" org.myorg.swordball
Rapidly creating a game
Engine: Corona
Template: TwoScene
Copying project files
Setting project name: Sword Ball
Setting package name: org.myorg.swordball
Done
Congratulations on creating a Corona game!
Run it by opening the `main.lua` file in the Corona Simulator.
Ready to code? Start with the `main.lua` file.
The library prebuilder creates static libraries that virtually eliminate build times for the cocos2d-x engine. With hundreds of source files to be compiled, building cocos2d-x for just one platform can take at least five minutes. This can be a real time sink, especially when switching from the simulator to device triggers a rebuild.
The prebuilder automatically downloads cocos2d-x, patches it to ensure that it can be built from the commandline, then prebuilds cocos2d-x for all possible platforms, configurations and architectures. It is then possible to compile and link native cocos2d-x games in seconds. Even better, the project creator will absolutely symlink to the location of the prebuilt libraries so your game projects stay lightweight and can be moved easily. A regular cocos2d-x game project directory can be half a gigabyte or more. A RapidGame project is around two megabytes.
A project created by RapidGame uses exactly the same underlying API as cocos2d-x / cocos2d-js. One can still get the running scene, for example, like this cocos2d::Director::getInstance()->getRunningScene()
(C++) or this cc.director.getRunningScene()
(Javascript).
RapidGame extends upon the cocos2d-js API with the Game object. This object provides methods which are commonly used in game development, but were missing from cocos2d-js at the time of writing. Game.rand(5)
, for example, returns a random integer between 0 and 5.
While the underlying API stays the same, the file / folder structure of a project created by RapidGame is different than that of a "normal" cocos2d-x project. A normal project is created with the cocos
command:
cocos new -p com.mycompany.mygame -l js -d MyGame
This results in a project folder approximately 500 MB which contains all the files necessary to build cocos2d-x from scratch. Subfolders include:
frameworks/ - All cocos2d-js and cocos2d-x source files, as well as project files for the game
res/ - Game assets
runtime/ - An executable which can run the iOS Simulator from the commandline
src/ - The Javascript files
tools/ - Miscellaneous tools
By contrast, a RapidGame project is only 2 MB (because it symlinks to the prebuilt cocos2d-x libraries) and has a more organized folder structure:
Assets/ - The game assets and Javascript files
lib/ - A symlink to the prebuilt cocos2d-x libraries
Projects/ - The project files for the game
Server/ - The server which provides an API and serves files for the HTML5 version of the game (cocos2d-js only)
Inside the project files there are other differences. Take the Xcode project as an example. The normal cocos2d-x project is setup to build all of cocos2d-x, depends on several sub-projects (Targets > Build Phases > Target Dependencies) and references several User Header Search Paths (example: $(SRCROOT)/../../js-bindings/cocos2d-x
) within the frameworks
folder.
The RapidGame project is more efficient, relying on the symlinked lib
folder. Instead of depending on sub-projects and rebuilding all of cocos2d-x, it uses two Other Linker Flags to include the prebuilt cocos2d-x libraries (-lcocos2dx-prebuilt
) and specifies an additional Library Search Path in which to find them: $(SRCROOT)/../lib/cocos2d/x/lib/$(CONFIGURATION)-iOS/$(PLATFORM_NAME)
. User Header Search Paths also use the symlink, $(SRCROOT)/../lib/cocos2d/x/include/cocos
, so that by simply swapping the lib
folder one can upgrade to a newer prebuilt version of cocos2d-js/x.
The command to prebuild cocos2d-x static libraries used by cocos2d-js on native platforms:
rapidgame prebuild
When the command is finished, you'll have a directory (~/Library/Developer/RapidGame
on Mac and C:\Users\[USERNAME]\AppData\Roaming\npm\node_modules\rapidgame
on Windows) with include files, java files, make files, Javascript bindings and prebuilt library files for all currently available architectures, platforms and configurations.
RapidGame can be used on any platform that is capable of running Node.js.
The cocos2d-x library prebuilder currently works on the following development platforms:
- Mac
- Windows
Linux support is planned.
If you are just using cocos2d-x or you have your own custom project layout, you can still use the prebuilt libraries. Use this command to create a symlink to the libraries directory:
cd MyGame && rapidgame init .
Then setup your Xcode target to reference the headers. Example:
USER_HEADER_SEARCH_PATHS = $(inherited)
$(SRCROOT)/../lib/cocos2d/x/include/cocos
$(SRCROOT)/../lib/cocos2d/x/include/cocos/2d
...
And the libraries:
LIBRARY_SEARCH_PATHS = $(SRCROOT)/../lib/cocos2d/x/lib/$(CONFIGURATION)-iOS/$(PLATFORM_NAME)
Then link with the library:
OTHER_LDFLAGS = -lcocos2dx-prebuilt
It's possible to create your own game templates. Here's the step-by-step instructions:
-
Create your game directory. If your game is called "ZombieMatrix", name the directory
ZombieMatrix
. -
Use the name of your game throughout your game project. RapidGame will automatically search and replace the title in most types of source and project files.
-
If you prefer for a file or directory renamed, make sure it starts with your game's title. For example, if you have
ZombieMatrix.xcodeproj
it will get changed toMyNewGame.xcodeproj
. -
Whenever there is an instance of your package name, replace the beginning with
com.wizardfu.
, lowercase the title and remove any punctuation, socom.mycompany.zombierevolution
becomescom.wizardfu.zombierevolution
. This will get changed by the templating system when creating new game projects. -
Copy your game template to the
templates/<engine>
directory of RapidGame. On Mac / Linux this is/usr/local/lib/node_modules/rapidgame
. You can use thenpm prefix -g
command to determine where Node modules are installed on your system. If you're on Mac OS X, the template is for Unity and it is called "ZombieMatrix" then the final directory would be/usr/local/lib/node_modules/rapidgame/templates/unity/ZombieMatrix/
. -
Your template is now ready for testing. Try it out like this:
rapidgame create <engine> MyNewGame com.mycompany.mynewgame -t "ZombieMatrix"
.
Submit pull requests or open issues as you see fit.
RapidGame is licensed under the MIT license.