Skip to content

Integrate the Bevy engine into existing iOS | Android apps.

Notifications You must be signed in to change notification settings

jason-ni/bevy-in-app

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Bevy in App

Integrate the Bevy engine into existing iOS | Android apps.

If you want to add a mini-game to an existing app, or implement some dynamic UI components, charts ..., or just want to take advantage of the Motion Sensors on your phone for some cool gameplay, you can't use WinitPlugin. Because winit will take over the entire app initialization process and windowing, but we need to create bevy::App in an existing app instance, and we may also want bevy::App to run in an iOS UIView or Android SurfaceView of any size.

This repository implements such a scenario and uses the phone's motion sensor to play breakout mini-games.

Screenshot

Bevy in iOS App Bevy in Android App

iOS

# Add iOS target
rustup target add aarch64-apple-ios

# Build for iOS target
sh ./ios_build.sh --release

Then, Open iOS/bevy_in_iOS.xcodeproj with Xcode,connect an iOS device and run.

Android

Set up Android environment

Assuming your computer already has Android Studio installed, go to Android Studio > Tools > SDK Manager > Android SDK > SDK Tools. Check the following options for installation and click OK.

  • Android SDK Build-Tools
  • Android SDK Command-line Tools
  • NDK(Side by side)

Then, set two following environment variables:

export ANDROID_SDK_ROOT=$HOME/Library/Android/sdk
# Replace the NDK version number with the version you installed
export NDK_HOME=$ANDROID_SDK_ROOT/ndk/23.1.7779620

Add build targets

# Since simulator and virtual devices only support GLES,
# `x86_64-linux-android` and `i686-linux-android` targets are not necessary
rustup target add aarch64-linux-android

Build

# Install cargo-so subcommand
cargo install cargo-so

# Build
sh ./android_build.sh --release

About

Integrate the Bevy engine into existing iOS | Android apps.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 46.7%
  • WGSL 22.6%
  • Kotlin 14.7%
  • Swift 9.0%
  • CMake 2.1%
  • Shell 2.1%
  • Other 2.8%