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 f0276f37ae Update README files [skip appveyor] [skip travis] 2020-08-17 19:09:54 +08:00
cmake Add ios framework required by SDL2, check whether SDL2 support strip it later 2020-08-15 17:47:40 +08:00
cocos Improve shared library for android, remove mojoal,sdl2, still use OpenAL.framework on apple platform, alsoft on other platforms. 2020-08-17 18:45:14 +08:00
docs update error link 2019-12-12 23:55:05 +08:00
extensions Sync from official-v4 pr 2020-08-14 18:57:08 +08:00
licenses Remove license files. 2019-12-12 23:53:27 +08:00
templates Improve shared library for android, remove mojoal,sdl2, still use OpenAL.framework on apple platform, alsoft on other platforms. 2020-08-17 18:45:14 +08:00
tests Update README files [skip appveyor] [skip travis] 2020-08-17 19:09:54 +08:00
tools Set CC_USE_ALSOFT_ON_APPLE=ON at travis build script 2020-07-31 15:11:13 +08:00
.appveyor.yml Merge: 5d29919586 7676fe2c6c 2020-05-19 14:18:39 +08:00
.gitattributes Init Commit 2019-11-23 20:27:39 +08:00
.gitignore Update build guide [skip appveyor] [skip travis] 2020-08-06 16:01:00 +08:00
.gitmodules Init Commit 2019-11-23 20:27:39 +08:00
.travis.yml Merge: 2a02db76d8 2d3e162e21 2020-02-12 16:58:47 +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 Add full fairygui-tests 2020-08-04 13:15:02 +08:00
CONTRIBUTING.md Init Commit 2019-11-23 20:27:39 +08:00
README.md Update README files [skip appveyor] [skip travis] 2020-08-17 19:09:54 +08:00
README_CN.md Update README files [skip appveyor] [skip travis] 2020-08-17 19:09:54 +08:00
download-deps.py Init Commit 2019-11-23 20:27:39 +08:00
install-deps-linux.sh Init Commit 2019-11-23 20:27:39 +08:00
issue_template.md Init Commit 2019-11-23 20:27:39 +08:00
setup.py Init Commit 2019-11-23 20:27:39 +08:00

README.md

EGNX

Build Status Windows Build Status

This is another more radical fork of cocos2d-x v4, use opanal for all platforms, single texture multi gpu texture handler, c++14/17...

简体中文

Purpose Summary:

  • C++14/17
  • Forcus on native game dev only
  • Fix bugs ASAP
  • Review PR ASAP
  • Excellent PRs from any guys are welcome, we will review & merge ASAP

Highlight Features:

  • Refactor AudioEngine, OpenAL for all platforms
    • openal-soft, pass -DCC_USE_ALSOFT=ON to cmake to force enable it
    • OpenAL.framework, if no CC_USE_MOJOAL and CC_USE_ALSOFT option specified, cmake script will choose it on osx/ios, even through it was mark as deprecated, but still avaiable.
  • Refactor UserDefault with mio, very fast
  • Modularize all optional extension, all 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 to instead glew
  • Add google angle renderer backend support
  • Set default C++ standard to 14
  • Set min deploy target ios sdk to 9.0
  • Remove tinyxml2, use more fast pugixml instead
  • Use curl for HttpClient,Downloader on all platforms
  • Use SAX parser for all plist file, remove apple platform spec for getValueMapFromFile stubs
  • Spine-3.8 support
  • Add engine extension FairyGUI support

Roadmap

Quick Start

Common Requirement python

  • python-2.7.17+, python-3.7+ also works

Windows

  1. Install CMake 3.6+
  2. Install Visual Studio 2019 build(we strong recommand you install 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 28 r3
    • Android SDK Build-Tools 29.0.2
    • NDK r16b+
    • CMake 3.6
  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+ installed
  2. Install brew: /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    when finish, install follow tools:
    brew update
    brew install git
    brew install cmake
    brew install autoconf
    brew install automake
    brew install libtool
  1. Execute follow command
    sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer
  2. Generate xcode project
  mkdir engine-x/build
  cd engine-x/build
  cmake .. -GXcode -DCMAKE_SYSTEM_NAME=iOS -DCMAKE_OSX_SYSROOT=iphonesimulator
  # for simulator64
  # cmake .. -G Xcode -DCMAKE_TOOLCHAIN_FILE=../cmake/ios.toolchain.cmake -DPLATFORM=SIMULATOR64 -DENABLE_ARC=0 -DENABLE_BITCODE=0
  # for (armv7, armv7s, arm64)
  # cmake .. -G Xcode -DCMAKE_TOOLCHAIN_FILE=../cmake/ios.toolchain.cmake -DPLATFORM=OS -DENABLE_ARC=0 -DENABLE_BITCODE=0
  # for device 64
  # cmake .. -G Xcode -DCMAKE_TOOLCHAIN_FILE=../cmake/ios.toolchain.cmake -DPLATFORM=OS64 -DENABLE_ARC=0 -DENABLE_BITCODE=0
  1. After cmake generate finish, you can open xcode project at build folder and run cpp-tests or other test targets.

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