Axmol Engine – A Multi-platform Engine for Desktop, XBOX (UWP) and Mobile games. (A radical fork of Cocos2d-x-4.0)
Go to file
halx99 8e19969796 Remove print 2020-11-11 22:33:48 -08:00
.github/workflows Merge: 5da2894e1b f80a6ef25c 2020-11-08 13:12:06 +08:00
cmake Remove print 2020-11-11 22:33:48 -08:00
cocos Update CCUserDefault.cpp 2020-11-12 00:32:33 +08:00
docs Sync folder for binding generator config 2020-11-01 20:18:50 +08:00
extensions Merge: d1f0a287ac f5fcd5592c 2020-11-11 01:25:21 -08:00
templates Lock name 2020-10-24 21:57:36 +08:00
tests Prepre for box2d-2.4.1 2020-11-08 13:11:40 +08:00
tools fix cjson can't use 2020-11-11 15:21:29 +08:00
.appveyor.yml Merge: f36866a99b 313a2ac09b 2020-08-27 17:37:49 +08:00
.gitattributes Init Commit 2019-11-23 20:27:39 +08:00
.gitignore Finish cpp and lua template to use env var 'COCOS2DX_ROOT' to avoid copy whole engine source when new project. 2020-10-19 18:33:10 +08:00
.gitmodules Init Commit 2019-11-23 20:27:39 +08:00
.travis.yml Use pyenv manage python version for travis-ci (#229) 2020-10-07 22:45:05 +08:00
AUTHORS Init Commit 2019-11-23 20:27:39 +08:00
CHANGELOG Init Commit 2019-11-23 20:27:39 +08:00
CMakeLists.txt Lock name 2020-10-24 21:57:36 +08:00
CONTRIBUTING.md Init Commit 2019-11-23 20:27:39 +08:00
LICENSE Create LICENSE 2020-08-18 09:21:36 +08:00
README.md Merge: 0a410dbf7f 44fb557458 2020-11-11 01:36:09 -08:00
README_CN.md Merge: 5da2894e1b f80a6ef25c 2020-11-08 13:12:06 +08:00
download-deps.py Make download-deps.py compatible with python3 2020-10-22 15:24:28 +08:00
install-deps-linux.sh fix command 2020-10-24 10:47:07 +08:00
issue_template.md Init Commit 2019-11-23 20:27:39 +08:00
setup.py Lock name 2020-10-24 21:57:36 +08:00

README.md

Engine-x

Android Build Status iOS Build Status Windows Build Status Linux Build Status macOS Build Status

dev

This is another more radical fork of Cocos2d-x-4.0, use OpenAL for all platforms, single texture multi GPU texture handler, C++14/17, etc.

简体中文

Purpose Summary:

  • C++14/17
  • Focus on native game dev (quick starting, easy to use, fast)
  • Bugfixes ASAP
  • Usefull PRs from you are welcome (review/merge ASAP)

Highlight Features:

  • Refactor AudioEngine, OpenAL for all platforms
    • openal-soft, pass -DBUILD_EXT_ALSOFT=ON to cmake to force enable it
    • OpenAL.framework, if no BUILD_EXT_ALSOFT option specified, cmake script will choose it on osx/ios, even through it was mark as deprecated, but still available.
  • Refactor UserDefault with mio
  • Modularize all optional extension, move from engine core to folder extensions
  • Implement all .wav formats supported by openal-soft, such as MS-ADPCM, ADPCM, ...
  • Use modern gl loader glad (instead of glew)
  • Add google angle renderer backend support
  • C++14 standard
  • IOS SDK 9.0 as minimal deployment
  • Use fast pugixml
  • Using curl for transferring data with URL syntax
  • Use SAX parser for all plist file
  • Spine-3.8 support
  • Add engine extension FairyGUI support
  • Add ASTC 4x4/6x6/8x8 support, if hardware decoder not present, use software decoder
  • Add ETC2 RGB/RGBA support, if hardware decoder not present, use software decoder
  • ImGui integrated, easy to write game embedded tools, very ease to use, please read ImGuiEXT

Roadmap

Quick Start

Common Requirement python

  • python-2.7.17+, python-3.7+

Prerequisites

  1. Enter engine-x root directory
  2. Run python download-deps.py
  3. Run python setup.py, restart console after finish

Windows

  1. Install CMake 3.14+
  2. Install Visual Studio 2019 build(we strong recommend you use this version)
  3. Execute follow command at command line(Console, Window Terminal or Powershell)
cd engine-x\
cmake -S . -B build -G "Visual Studio 16 2019" -A Win32

Android

  1. Install Android Studio 4.0+

  2. When first start Android Studio, It will guide you to install sdk and other tools, just install them

  3. Start Android and choose [Open an existing Android Studio Project] to open engine-x\tests\cpp-tests\proj.android

  4. Start Android Studio and Open [Tools][SDKManager], then switch to SDK Tools, check the Show Package Details, choose follow tools and click the button Apply to install them:

    • Android SDK Platform 29 r5
    • Android SDK Build-Tools 29.0.2
    • NDK r16b+
    • CMake 3.10+
  5. Waiting for Gradle sync finish.

  6. Remark: If you use non-sdk provided CMake edition, you need download ninja from https://github.com/ninja-build/ninja/releases, and copy ninja.exe to cmake's bin directory

iOS

  1. Ensure xcode11+ & cmake3.14+ installed, install cmake command line support: sudo "/Applications/CMake.app/Contents/bin/cmake-gui" --install
  2. Execute follow command
    sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer
  3. Generate xcode project
  # for any device
  cmake -S . -B build -GXcode -DCMAKE_TOOLCHAIN_FILE=cmake/ios.mini.cmake

  # for device combined armv7,arm64
  # cmake -S . -B build -GXcode -DCMAKE_TOOLCHAIN_FILE=cmake/ios.mini.cmake "-DCMAKE_OSX_ARCHITECTURES=armv7;arm64"

  # for simulator x86_64
  # cmake -S . -B build -GXcode -DCMAKE_TOOLCHAIN_FILE=cmake/ios.mini.cmake -DCMAKE_OSX_SYSROOT=iphonesimulator -DCMAKE_OSX_ARCHITECTURES=x86_64
  1. After cmake generate finish, you can open xcode project at build folder and run cpp-tests or other test targets.

  2. Notes
    a. The code sign required to run ios app on device, just change bundle identifier until the auto manage siging solved
    b. engine-x only provide armv7,arm64,x86_64 prebuilt libraries for ios

Pitfalls

  • ThreadLocalStorage(TLS)
    • ios x86 simulator ios>=10
    • ios x64 or devices(armv7,arm64) ios sdk>=9.0
    • the openal-soft maintained by kcat use TLS