Based on the original community demo of Wwise Cocos2d-x engine integration, this fork aims to:
- Temporarily fix compatibility with recent Wwise and Cocos2d-x versions, with no guaranteed long-term maintenance.
- Add missing features added in recent IntegrationDemo.
- Keep the code clean for a better sample.
Compared to The Wwise SDK IntegrationDemo, which adopts a control scheme using virtual joysticks, the original author improves the user experience by implementing a more intuitive touch screen UX, exemplified by the footsteps and positioning demos.
The demo supports the following platforms:
- Android
- iOS
- Mac
- Windows
Content
- Updated to support Wwise 2017.1 and Cocos2d-x 3.16.
- Added previously disabled Background Music demo.
- Added new plugin registration including Wwise Reflect and Wwise Recorder.
- Fixed: Crashes when quitting Footstep demo.
- Simplified source file and folder structure.
- Lots of refactoring.
Tested with the following software versions:
- Wwise 2017.1.4.6407
- cocos2d-x 3.16
- Android 6.0.1, on Huawei Honor 5X (KIW-AL10)
- iOS 11.2.5, iPhone 6
- macOS Sierra 10.12.6
- Windows 10
- Xcode 9.2
- Visual Studio 2017
- JDK 1.8, Android SDK API 24, NDK r12b, Apache ANT 1.8.2
First, clone the demo.
git clone https://github.com/cocos2dx-IntegrationDemo wwise-cocos-demo
This is a pre-configured cocos application project.
Then, because the demo code depends on partial code of the Wwise SDK IntegrationDemo, you need to install a supported Wwise version with Wwise SDK of the target platforms。
Finally, copy the demo into the SDK IntegrationDemo's folder. After that, your clone's root folder (e.g., wwise-cocos-demo
) should be placed under <Wwise Root>/SDK/samples/IntegrationDemo/
, e.g.:
<Wwise Root>/SDK/samples/IntegrationDemo/wwise-cocos-demo
To run the demo, you need to build it from source first.
For each supported platform, there is a ready-to-use IDE solution or project. A full Cocos2d-x engine distribution is also available as part of the clone, as expected with a cocos project. You can build all the demos for your chosen platforms with a single click or a single command on top of the bundled Cocos2d-x.
If you want to work with your own version of Cocos2d-x, you'll need to replace the cocos2d
folder with the corresponding folder in your Cocos distribution and set up your project by hand.
Two build configurations are prepared for each supported platform. The Debug build can be remotely profiled using Wwise Authoring Tool, but is not optimized. The Release build is optimized but disables profiling.
Prerequisites
- Windows 7 or higher
- Visual Studio 2017
- DirectX SDK
- Wwise SDK installed with the following component: SDK (Windows, Visual Studio 2017)
Notes on DirectX:
- Install the DirectX SDK version mentioned in Wwise's Platform Requirements.
- Restart your Windows Explorer or reboot your machine to ensure the environment variable DXSDK_DIR is in effect. The Visual Studio project depends on this variable.
How to build
- Build the solution under
<Wwise Root>/SDK/samples/IntegrationDemo/cocos2dx-demo/proj.win32/IntegrationDemo-cocos2d-x.sln
with your Visual Studio. - Open the IntegrationDemo's Wwise project with the compatible Wwise version.
- Generate the SoundBanks for Windows under their default path.
Prerequisites
- Xcode with a developer credential.
- Wwise SDK installed with the following component: SDK (macOS)
How to build
- Open
<Wwise Root>/SDK/samples/IntegrationDemo/cocos2dx-demo/proj.ios_mac/IntegrationDemo-cocos.xcodeproj
with Xcode. - Build the Scheme
IntegrationDemo-cocos-desktop
. - Open the IntegrationDemo's Wwise project with the compatible Wwise version.
- Generate the SoundBanks for Mac under their default path.
Prerequisites
- Xcode with a developer credential.
- Wwise SDK installed with the following component: SDK (iOS)
How to build
- Open
<Wwise Root>/SDK/samples/IntegrationDemo/cocos2dx-demo/proj.io
s_mac/IntegrationDemo-cocos.xcodeproj` with Xcode. - Build the Scheme
IntegrationDemo-cocos-mobile
. - Open the IntegrationDemo's Wwise project with the compatible Wwise version.
- Generate the SoundBanks for iOS under their default path.
Prerequisites
- Android SDK/NDK/Apache ANT
- Python 2.7.x
- Wwise SDK installed with the following component: SDK (Android)
How to build
- Open Terminal/Command Prompt:
cd cocos2dx-demo/proj.android
. - Run Cocos command to set up Android environment variables.
- Compile the project
- Debug:
cocos compile -p android -m debug NDK_DEBUG=1 V=1 NDK_LOG=1
- Release:
cocos compile -p android
- Debug:
- Open the IntegrationDemo's Wwise project with the compatible Wwise version.
- Generate the SoundBanks for Android under their default path.
- Build the APK and run
- Debug:
cocos run -p android -m debug NDK_DEBUG=1 V=1 NDK_LOG=1
- Release:
cocos run -p android
- Debug:
Use the demo's menu system to navigate to individual demo topics. You can use keyboard, mouse, or touch screen to control the demo.
Browse the The Demos
section of the original documentation to get to know how each demo works. The major difference here is in user input scheme. On mobile platforms, this demo uses touch screen gestures instead of virtual joysticks, thanks to Cocos2d-x's facility; on desktop, it supports mouse gestures while the SDK IntegrationDemo does not.
You need to generate the SoundBanks of your target platform for the demo to work on that platform. SoundBanks are the output of a Wwise project. The Wwise project for this demo is the same one for the SDK IntegrationDemo, available at <Wwise Root>/SDK/samples/IntegrationDemo/WwiseProject
.
Read Wwise documentation to learn how to generate SoundBanks. Once that's done, by default they will be in GeneratedSoundBanks
sub-folder under the Wwise project folder.
Compared to the community demo repo, the Wwise integration code has been refactored to make it easier to follow what needs to be done for each platform integration as a whole. This was achieved mainly by separating extract cross-platform code and separate it from the platform-specific code. Of course, ad-hoc platform branching code is still inevitable, but that is now at a bare minimum.
A few pointers for you to walk around the code base:
Classes/Scene*.h
andClasses/Scene*.cpp
along with the cocos template AppDelegate code are the demo application code.Classes/WwiseWrapper.h
andClasses/WwiseWrapper.cpp
handle cross-platform Wwise sound engine lifecycle.- All the platform-specific code and IDE solution or project files are under the folders named after those platforms.
cocos2dx-demo/proj.android/
cocos2dx-demo/proj.ios_mac/ios/
cocos2dx-demo/proj.ios_mac/mac/
cocos2dx-demo/proj.win32/
<platform>/WwisePlatformHelper.h
and<platform>/WwisePlatformHelper.cpp
handle platform-specific code for Wwise sound engine lifecycle.<platform>/PlatformCocos.h
and<platform>PlatformCocos.cpp
define platform-specific global variables and functions. They complements thePlatform.h
andPlatform.cpp
of the SDK IntegrationDemo.
This forked demo shares the same license as the original project.
You may raise issues here at the Issues section but there is no guarantee that they will be answered soon enough.