mirror of https://github.com/axmolengine/axmol.git
103 lines
6.9 KiB
Markdown
103 lines
6.9 KiB
Markdown
<p align="center"><a href="https://axmolengine.github.io/axmol" target="_blank" rel="noopener noreferrer"><img width="160" src="docs/logo.png" alt="axmol logo"></a></p>
|
|
|
|
# Axmol Engine
|
|
|
|
## A Multi-platform Engine for Desktop, XBOX (UWP) and Mobile games. (A radical fork of Cocos2d-x-4.0)
|
|
|
|
[data:image/s3,"s3://crabby-images/14e6c/14e6c71c1f62e3054c1893e66e5ac29bfee309b1" alt="dev"](https://github.com/axmolengine/axmol/releases)
|
|
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="LICENSE"](https://github.com/axmolengine/axmol/blob/master/LICENSE)
|
|
[data:image/s3,"s3://crabby-images/a6d03/a6d03ca749afd8d8be07757e88c742700806f6a5" alt="Codacy Badge"](https://www.codacy.com/gh/axmolengine/axmol/dashboard?utm_source=github.com&utm_medium=referral&utm_content=axmolengine/axmol&utm_campaign=Badge_Grade)
|
|
[data:image/s3,"s3://crabby-images/60beb/60beb0113e52c756dcbeae78452e427705901a91" alt="PRs Welcome"](https://github.com/axmolengine/axmol/pulls)
|
|
[data:image/s3,"s3://crabby-images/11b17/11b1706242ffd545b2e2ca9f0e411164f32b2408" alt="vscode.dev"](https://vscode.dev/github/axmolengine/axmol)
|
|
|
|
data:image/s3,"s3://crabby-images/d2cae/d2caecf48ee4cc91e624e613f677a378bd1024c9" alt="issues"
|
|
data:image/s3,"s3://crabby-images/1605f/1605f8a28309e0fed7ec8c8a4f695fc2c7be1527" alt="forks"
|
|
data:image/s3,"s3://crabby-images/de850/de850f3fb3d39753d731a897f254b6032ac24bdf" alt="stars"
|
|
data:image/s3,"s3://crabby-images/6b503/6b50311c035b016f52f510a9ca5e132f38e6a903" alt="GitHub code size in bytes"
|
|
|
|
**[简体中文](README_CN.md)**
|
|
|
|
## Supported Platforms
|
|
|
|
| Build | Status (github) |
|
|
|-------|-----------------|
|
|
| Windows(win32,winuwp,win32-clang)|[data:image/s3,"s3://crabby-images/f1294/f12947218e0ecd358f95178654a4c666b86a06d6" alt="Win32 CI"](https://github.com/axmolengine/axmol/actions/workflows/windows.yml)|
|
|
| Android | [data:image/s3,"s3://crabby-images/959ef/959ef70744c13cc3cc07bc2769067604abc58a55" alt="Android Build Status"](https://github.com/axmolengine/axmol/actions?query=workflow%3Aandroid)|
|
|
| iOS |[data:image/s3,"s3://crabby-images/9ea49/9ea496448663303a11a336fd050fab60143af885" alt="iOS Build Status"](https://github.com/axmolengine/axmol/actions?query=workflow%3Aios)|
|
|
| tvOS |[data:image/s3,"s3://crabby-images/905d1/905d19ac1b73007f21d1a4828b9fa221427a0930" alt="tvOS Build Status"](https://github.com/axmolengine/axmol/actions?query=workflow%3Atvos)|
|
|
| Linux |[data:image/s3,"s3://crabby-images/bb287/bb287a544a851a65610ff743dbd80615ed1516aa" alt="Linux Build Status"](https://github.com/axmolengine/axmol/actions?query=workflow%3Alinux)|
|
|
| macOS |[data:image/s3,"s3://crabby-images/60268/60268818b00cf52e078aeeaef6011d072efb03c1" alt="macOS Build Status"](https://github.com/axmolengine/axmol/actions?query=workflow%3Aosx)|
|
|
|
|
## New MediaPlayer
|
|
|
|
The new `ui::MediaPlayer`(renamed from `ui::VideoPlayer`) render video as Texture2D with designed corss-platform MediaEngine, the MediaEngine inspired from microsoft
|
|
media foundation `IMFMediaEngine`, the `MediaPlayer` support all platforms which axmol engine does.
|
|
|
|
| Target Platform | Video Compress Format | Video Pixel Format | Container Format | Backend |
|
|
|-----------------------|-----------------------|----------------------|----------------- |--------------------|
|
|
| Windows Desktop | H264, HEVC, VP90 | YUY2, NV12, RGB32 | .mp4,.mkv,.webm | IMFMediaSession |
|
|
| Windows UWP | H264, HEVC, VP90 | BGR32 | .mp4,.mkv,.webm | IMFMediaEngine |
|
|
| Apple macOS | H264, HEVC(hvc1) | NV12, BGR32 | .mp4 | AVFoundation |
|
|
| Apple tvOS | H264, HEVC(hvc1) | NV12, BGR32 | .mp4 | AVFoundation |
|
|
| Apple iOS | H264, HEVC(hvc1) | NV12, BGR32 | .mp4 | AVFoundation |
|
|
| Android | H264, HEVC | NV12 | .mp4,.mkv,.webm | ExoPlayer2 |
|
|
| Linux | H264, HEVC | NV12 | .mp4,.mkv,.webm | libVLC |
|
|
|
|
## Building
|
|
|
|
View the [Dev setup instructions](docs/DevSetup.md).
|
|
|
|
## Highlighted Features
|
|
|
|
- Windows UWP support, refer to: https://github.com/axmolengine/axmol/pull/1108
|
|
- Add apple M1, android x64 support, contributed by @pietpukkel
|
|
- Improve windows workflow, support linking with engine prebuilt libs, read [windows workflow guide](https://github.com/axmolengine/axmol/issues/564)
|
|
- Windows video player support (based on microsoft media foundation)
|
|
- Windows x64 build support
|
|
- Reimplement HttpClient based on yasio for concurrent http requests processing.
|
|
- ['Upstream-Version-License'](thirdparty/README.md) Third-party
|
|
- Third-party license overview for easier publishing of your commercial apps based on axmol framework.
|
|
- Some links to third party libs which support axmol too.
|
|
- ['Upstream-Version-License'](extensions/README.md) Extensions
|
|
- Extensions license overview for easier publishing of your commercial apps based on axmol framework.
|
|
- Spine-3.8 support
|
|
- ```FairyGUI``` support
|
|
- DragonBones support
|
|
- Live2D support
|
|
- **ImGui integrated, easy to write game embedded tools, very easy to use, read [ImGui](extensions/ImGui/README.md) for more info**
|
|
- Refactor AudioEngine, OpenAL for all platforms
|
|
- [OpenAL Soft](https://github.com/kcat/openal-soft), pass -DAX_USE_ALSOFT=ON to cmake to force enabling it
|
|
- [OpenAL.framework](https://opensource.apple.com/tarballs/OpenAL), if no ```AX_USE_ALSOFT``` option specified, cmake script will choose it on osx/ios/tvos, even though it was marked as deprecated, but still available.
|
|
- Refactor UserDefault with [mio](https://github.com/mandreyel/mio)
|
|
- Modularize all optional extensions, move from engine core folder to an extensions folder
|
|
- Implement all .wav formats supported by ```OpenAL Soft```, such as MS-ADPCM, ADPCM, ...
|
|
- Use a modern GL loader ```Glad```
|
|
- Google [angle](https://github.com/google/angle) renderer backend support
|
|
- C++ 17/20
|
|
- IOS/TVOS SDK 9.0 as minimal deployment
|
|
- Use fast pugixml
|
|
- Use [curl](https://github.com/curl/curl) for transferring data with URL syntax
|
|
- Use SAX parser for all plist files
|
|
- ASTC 4x4/6x6/8x8 support (if hardware decoding is not supported, then software decoding is used)
|
|
- ETC2 RGB/RGBA support (if hardware decoding is not supported, then software decoding is used)
|
|
- Supported 2D physics engines (see also [APPENDIX.md](APPENDIX.md)):
|
|
- Box2D
|
|
- Box2D-optimized
|
|
- Chipmunk2D
|
|
- Supported 3D physics engines:
|
|
- Bullet Physics SDK
|
|
|
|
[Read Full changes since cocos2d-x-4.0](CHANGELOG)
|
|
|
|
Open [APPENDIX.md](APPENDIX.md) for additional information and see [Milestones](https://github.com/axmolengine/axmol/milestones) for planed features too.
|
|
|
|
## Reference links
|
|
|
|
- [buildware](https://github.com/axmolengine/buildware), the axmol prebuilt build-bot
|
|
- [Some interesting related projects based on axmol](https://github.com/axmolengine/axmol/discussions/694)
|
|
- [Axmols contributing guide](https://github.com/axmolengine/axmol/discussions/411)
|
|
- [Official Cocos2d-x](https://github.com/cocos2d/cocos2d-x)
|
|
|
|
## The axmol Active Stats
|
|
data:image/s3,"s3://crabby-images/681f8/681f8ece87fce0969ba6396e6aa80a78c2b6b48e" alt="Alt"
|