1 unstable release
0.1.0 | May 18, 2024 |
---|
#1978 in Game dev
15KB
329 lines
Micro Bevy Splash
A simple, one-shot logo splash screen plugin for Bevy
Render a splash screen logo with optional tweening that will subsequently transition to another state when complete.
A basic use case for splash screens is to provide visual interest while loading assets. To achieve this, you can perform the following flow:
- Configure your game states such that you have one to trigger asset loading, one in which the splash screen should be shown, and one that shows a loading indicator if there are any remaining assets
- Preload your splash screen assets, and then trigger the loading of your other assets
- Specify
micro_bevy_splash
to render in your splash state via the plugin settings, and transition to that state once loading has begun - Specify the loading screen state as the exit state for
micro_bevy_splash
via the plugin settings - In your loading state, check for any assets that haven't been loaded yet, and render a loading indicator for them - users may skip the splash screen, or loading might take longer than your splash duration, so you should assume that there will be some assets not fully loaded when transitioning away from the splash state
Usage
Include micro_bevy_splash
in your project's Cargo.toml
[dependencies]
micro_bevy_splash = "0.1.0"
and then configure the plugin for your app, including what state to render in, and what state to transition to.
The states can be any type that implements the States
trait from bevy
, but both states must be of the
same concrete type - typically an enum
use micro_bevy_splash::{MicroSplashPlugin, SplashSettings};
// Import all of the usual bevy libraries here
#[derive(Clone, Copy, Eq, PartialEq, Ord, PartialOrd, Debug, Hash, States, Default)]
enum AppState {
Preload,
Setup,
Splash,
Menu,
}
fn main() {
App::new()
.add_plugins((
DefaultPlugins::default(),
MicroSplashPlugin::with_settings(SplashSettings {
// Specify when the plugin runs, and what it transitions to
run_in: AppState::Splash,
transition_to: AppState::Menu,
// Specify the asset path that the default bevy asset server will
// use to look up the splash logo to display, and the musical sting
// that will play over the screen
logo_path: String::from("splash/splash_clean.png"),
sting_path: String::from("splash/sting.ogg"),
// Allow users to press Space, Return, or Escape to skip to the exit state
skip_on_input: true,
// How long to stay on this screen. This differs from any time spent tweening
// the assets, as you typically want to hang on a static view of the logo
// for some short period of time
duration: Duration::from_secs(3),
// Specify tween values for animating the background colour and the logo colour
// These can be specified independently, and providing `None` will not tween
// that component
bg_color_tween: Some((Color::Black, Color::Red)),
tween_duration: Some(Duration::from_secs(2)),
logo_color_tween: None,
})
))
.run();
}
Bevy Compatibility
micro_bevy_splash | bevy |
---|---|
0.1.0 | 0.13.x |
Dependencies
~38–77MB
~1.5M SLoC