cocos2d for iOS, Android, Win32 and OS X. Built using C++
C++ Lua C Objective-C Objective-C++ Java Other
Switch branches/tags
cocos2d-x-4.0alpha1 cocos2d-x-4.0alpha0 cocos2d-x-3.16 cocos2d-x-3.15.1 cocos2d-x-3.15 cocos2d-x-3.15rc0 cocos2d-x-3.14.1 cocos2d-x-3.14.1rc0 cocos2d-x-3.14 cocos2d-x-3.13.1 cocos2d-x-3.13 cocos2d-x-3.12 cocos2d-x-3.11.1 cocos2d-x-3.11 cocos2d-x-3.10 cocos2d-x-3.9 cocos2d-x-3.8.1 cocos2d-x-3.8 cocos2d-x-3.8rc0 cocos2d-x-3.8beta0 cocos2d-x-3.7.1 cocos2d-x-3.7 cocos2d-x-3.7rc1 cocos2d-x-3.7rc0 cocos2d-x-3.7beta0 cocos2d-x-3.6 cocos2d-x-3.6beta0 cocos2d-x-3.6alpha0 cocos2d-x-3.5 cocos2d-x-3.5rc0 cocos2d-x-3.5beta0 cocos2d-x-3.5-tizen cocos2d-x-3.4 cocos2d-x-3.4rc1 cocos2d-x-3.4rc0 cocos2d-x-3.4beta0 cocos2d-x-3.3 cocos2d-x-3.3rc2 cocos2d-x-3.3rc1 cocos2d-x-3.3rc0 cocos2d-x-3.3beta0 cocos2d-x-3.3alpha0 cocos2d-x-3.2 cocos2d-x-3.2rc0 cocos2d-x-3.2alpha0 cocos2d-x-3.1.1 cocos2d-x-3.1 cocos2d-x-3.1rc0 cocos2d-x-3.1alpha1 cocos2d-x-3.1alpha0 cocos2d-x-3.0 cocos2d-x-3.0rc2 cocos2d-x-3.0rc1 cocos2d-x-3.0rc0 cocos2d-x-3.0rc cocos2d-x-3.0beta2 cocos2d-x-3.0beta cocos2d-x-3.0alpha1 cocos2d-x-3.0alpha0 cocos2d-x-3.0alpha0-pre cocos2d-x-2.2.6 cocos2d-x-2.2.5 cocos2d-x-2.2.4 cocos2d-x-2.2.3 cocos2d-x-2.2.2 cocos2d-x-2.2.1 cocos2d-x-2.2 cocos2d-x-2.1.5 cocos2d-x-2.1.4 cocos2d-2.1rc0-x-2.1.3 cocos2d-2.1rc0-x-2.1.2 cocos2d-2.1beta3-x-2.1.1 cocos2d-2.1beta3-x-2.1.0 cocos2d-2.0-x-2.0.4 cocos2d-2.0-x-2.0.3 cocos2d-2.0-x-2.0.2 cocos2d-2.0-rc2-x-2.0.1 cocos2d-2.0-rc0a-x-2.0 cocos2d-1.0.1-x-0.13.0-beta cocos2d-1.0.1-x-0.12.0 cocos2d-1.0.1-x-0.11.0 cocos2d-1.0.1-x-0.10.0 cocos2d-1.0.1-x-0.9.2 cocos2d-1.0.1-x-0.9.1 cocos2d-1.0.0-x-0.9.0 cocos2d-0.99.5-x-0.8.5 cocos2d-0.99.5-x-0.8.4 cocos2d-0.99.5-x-0.8.3 cocos2d-0.99.5-x-0.8.2 cocos2d-0.99.5-x-0.8.1 cocos2d-0.99.5-x-0.8.0 cocos2d-0.99.5-x-0.7.2 cocos2d-0.99.4-x-0.7.1 cocos2d-0.99.4-x-0.7.0
Nothing to show
Clone or download
Pull request Compare This branch is 62 commits ahead, 16614 commits behind cocos2d:v3.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
build
cocos
docs
extensions
external
licenses
plugin @ 96dc748
templates
tests
tools
.gitattributes
.gitignore
.gitmodules
.travis.yml
AUTHORS
CHANGELOG
CMakeLists.txt
README.md
download-deps.py
setup.py

README.md

cocos2d-x

Build Status Build Status

cocos2d-x is a multi-platform framework for building 2d games, interactive books, demos and other graphical applications. It is based on cocos2d-iphone, but instead of using Objective-C, it uses C++. It works on iOS, Android, Windows Phone, OS X, Windows and Linux.

cocos2d-x is:

  • Fast
  • Free
  • Easy to use
  • Community Supported

Git user attention

  1. After cloning the repo, please execute download-deps.py to download and install some dependences.

      $ cd cocos2d-x
      $ python download-deps.py
    
  2. Please execute download-deps.py once you synchronize with this repo. If there aren't any updates, it will not download dependences again.

How to start a new game

  1. Download the code from cocos2d download site
  2. Run setup.py
  3. Run the cocos script

Example:

$ cd cocos2d-x
$ ./setup.py
$ source FILE_TO_SAVE_SYSTEM_VARIABLE
$ cocos new MyGame -p com.your_company.mygame -l cpp -d NEW_PROJECTS_DIR
$ cd NEW_PROJECTS_DIR/MyGame

Build and run new project for android

$ cocos run -p android -j 4

Build and run new project for iOS

$ cocos run -p ios

Build and run new project for OSX

$ cocos run -p mac

Build and run new project for linux

if you never run cocos2d-x on linux, you need to install all dependences by the script in cocos2d/build/install-deps-linux.sh

$ cd cocos2d-x/build
$ ./install-deps-linux.sh

Then

$ cd NEW_PROJECTS_DIR/MyGame
$ cocos run -p linux

Run

$ bin/MyGame

Build and run new project for win32

$ cocos run -p win32

Main features

  • Scene management (workflow)
  • Transitions between scenes
  • Sprites and Sprite Sheets
  • Effects: Lens, Ripple, Waves, Liquid, etc.
  • Actions (behaviours):
    • Trasformation Actions: Move, Rotate, Scale, Fade, Tint, etc.
    • Composable actions: Sequence, Spawn, Repeat, Reverse
    • Ease Actions: Exp, Sin, Cubic, Elastic, etc.
    • Misc actions: CallFunc, OrbitCamera, Follow, Tween
  • Basic menus and buttons
  • Integrated with physics engines: Box2d and Chipmunk
  • Particle system
  • Skeleton Animations: Spine and Armature support
  • Fonts:
    • Fast font rendering using Fixed and Variable width fonts
    • Support for .ttf fonts
  • Tile Map support: Orthogonal, Isometric and Hexagonal
  • Parallax scrolling
  • Motion Streak
  • Render To Texture
  • Touch/Accelerometer on mobile devices
  • Touch/Mouse/Keyboard on desktop
  • Sound Engine support (CocosDenshion library) based on OpenAL
  • Integrated Slow motion/Fast forward
  • Fast and compressed textures: PVR compressed and uncompressed textures, ETC1 compressed textures, and more
  • Resolution Independence
  • Language: C++, with Lua and JavaScript bindings
  • Open Source Commercial Friendly: Compatible with open and closed source projects
  • OpenGL ES 2.0 (mobile) / OpenGL 2.1 (desktop) based

Build Requirements

  • Mac OS X 10.7+, Xcode 4.6+
  • or Ubuntu 12.10+, CMake 2.6+
  • or Windows 7+, VS 2012+
  • Python 2.7.5

Runtime Requirements

  • iOS 5.0+ for iPhone / iPad games
  • Android 2.3+ for Android games
  • Windows Phone 8+ for Windows Phone games
  • OS X v10.6+ for Mac games
  • Windows 7+ for Win games

Running Tests

Select the test you want from Xcode Scheme chooser.

  • For OS X / iOS
$ cd cocos2d-x/build
$ open cocos_tests.xcodeproj
  • For Linux
$ cd cocos2d-x/build
$ ./install-deps-linux.sh
$ cmake ..
$ make

Run Samples

$ bin/cpp-empty-test/cpp-empty-test
or
$ bin/lua-empty-test/lua-empty-test
  You may meet building errors when building libGLFW.so. It is because libGL.so directs to an error target,
  you should make it to direct to a correct one. `install-deps-linux.sh` only has to be run once.
  • For Windows

Open the cocos2d-x/build/cocos2d-win32.vc2012.sln

  • For Android
$ cd cocos2d-x/build
$ python ./android-build.py cpp-empty-test -p 10
$ adb install ../tests/cpp-empty-tst/proj.android/bin/CppEmptyTest-debug.apk

Then click item on Android device to run tests. Available value of -p is the API level, cocos2d-x supports from level 10.

Contributing to the Project

Did you find a bug? Do you have feature request? Do you want to merge a feature?

Contact us