This plugin provides the functionality to support vendor-specific XR devices (e.g: Meta, Pico devices) and access vendor-specific OpenXR extensions
Note:
Version 2.x
and higher of this plugin requires Godot 4.2.
Check the 1.x
branch and releases
for support on prior versions of Godot 4.
After cloning this project, run the following command in the project root directory to initialize
the godot-cpp
submodule:
git submodule update --init
The following build command run all the build commands mentioned in the 'Expanded build instructions' section below.
Run the following command from the root directory to build the plugin artifacts:
./gradlew buildPlugin
Run the following command from the root directory to build the plugin artifacts:
gradlew.bat buildPlugin
These are all the build commands that are being run by the gradlew buildPlugin
command.
They are detailed here for those needing to customize / troubleshoot their build process.
Build the Android C++ bindings using the following commands.
cd thirdparty/godot-cpp
scons platform=android target=template_debug arch=arm64 custom_api_file=../godot_cpp_gdextension_api/extension_api.json
scons platform=android target=template_release arch=arm64 custom_api_file=../godot_cpp_gdextension_api/extension_api.json
scons platform=android target=template_debug arch=x86_64 custom_api_file=../godot_cpp_gdextension_api/extension_api.json
scons platform=android target=template_release arch=x86_64 custom_api_file=../godot_cpp_gdextension_api/extension_api.json
When the command is completed, you should have static libraries stored in thirdparty/godot-cpp/bin
that will be used for compilation by the plugin.
Run the following command from the root directory to generate the editor gdextension plugin:
scons target=template_debug custom_api_file=thirdparty/godot_cpp_gdextension_api/extension_api.json
scons target=template_release custom_api_file=thirdparty/godot_cpp_gdextension_api/extension_api.json
Run the following command from the root directory to build the vendors AAR
Android binaries:
./gradlew build
Run the following command from the root directory to build the vendors AAR
Android binaries:
gradlew.bat build
It is possible to download compiled assets that have been released from releases. The latest official release will be made available in Godot's asset library.
Work in progress builds are available under actions.
The use of a Godot Android plugin requires the use of the gradle build option in Godot:
- Open your Godot XR project in Godot
- Open the
Project
menu - Select
Install Android Build templates
When downloading this asset from Godot's asset library it should place the required files into
the addons
directory.
If you've downloaded the zip file from the releases page, copy the files in asset/addons
manually to addons
in your project. You may need to create the addons
folder.
If you have build the asset from source, you need to create the addons
folder in your project
if it doesn't exist already, and then copy the content of the demo/addons
folder to addons
in your project.
Back in Godot open the Project
menu and select Export...
:
- If it doesn't already exist, create an Android export configuration by pressing
Add...
and selectingAndroid
- Tick the
Use Gradle Build
tickbox - Select
OpenXR
as the XR Mode under the XR Features section - Enable the XR vendor you need to use
- Scroll down to the bottom to see additional features for specific platforms.
Note: Do not select multiple vendors in the same export template! You can instead create multiple export templates, one for each vendor.
When contributing to the source code for the plugin, we highly recommend you install clang-format and copy the contents of the hooks
folder into the folder .git/hooks/
.
This will ensure clang-format is run on any changed files before commiting the changes to github and prevent disappointment when formatting issues prevent changes from being merged.
Unless specified otherwise, sources in this repository are licensed under MIT, see LICENSE
for more information.
Note that some vendor-specific components are licensed under separate license terms, which are listed in their corresponding folders.
This repository was created and maintained by Bastiaan "Mux213" Olij. The original setup for this plugin was created by Gergely Kis and Gabor Pal Korom at Migeran.
See CONTRIBUTORS.md for further contributions.