mirror of
https://github.com/bevyengine/bevy
synced 2024-11-26 14:40:19 +00:00
04ca832dfe
- attempt to clarify with better docstrings the default behaviour of WindowPlugin and the component type it accepts. # Objective - I'm new to Rust and Bevy, I got a bit confused about how to customise some window parameters (title, height, width etc) and while the docs do show the struct code for that field `Option<Window>` I was a bit of a doofus and skipped that to read the docstring entry for `primary_window` and then the `Window` component directly which aren't linked together. This is a minor improvement which I think will help in-case others, like me, have a doofus moment. --------- Co-authored-by: Sélène Amanita <134181069+Selene-Amanita@users.noreply.github.com>
173 lines
6.3 KiB
Rust
173 lines
6.3 KiB
Rust
#![allow(clippy::type_complexity)]
|
|
|
|
#[warn(missing_docs)]
|
|
mod cursor;
|
|
mod event;
|
|
mod raw_handle;
|
|
mod system;
|
|
mod window;
|
|
|
|
pub use crate::raw_handle::*;
|
|
|
|
pub use cursor::*;
|
|
pub use event::*;
|
|
pub use system::*;
|
|
pub use window::*;
|
|
|
|
pub mod prelude {
|
|
#[doc(hidden)]
|
|
pub use crate::{
|
|
CursorEntered, CursorIcon, CursorLeft, CursorMoved, FileDragAndDrop, Ime, MonitorSelection,
|
|
ReceivedCharacter, Window, WindowMoved, WindowPlugin, WindowPosition,
|
|
WindowResizeConstraints,
|
|
};
|
|
}
|
|
|
|
use bevy_app::prelude::*;
|
|
use std::path::PathBuf;
|
|
|
|
impl Default for WindowPlugin {
|
|
fn default() -> Self {
|
|
WindowPlugin {
|
|
primary_window: Some(Window::default()),
|
|
exit_condition: ExitCondition::OnAllClosed,
|
|
close_when_requested: true,
|
|
}
|
|
}
|
|
}
|
|
|
|
/// A [`Plugin`] that defines an interface for windowing support in Bevy.
|
|
pub struct WindowPlugin {
|
|
/// Settings for the primary window.
|
|
///
|
|
/// `Some(custom_window)` will spawn an entity with `custom_window` and [`PrimaryWindow`] as components.
|
|
/// `None` will not spawn a primary window.
|
|
///
|
|
/// Defaults to `Some(Window::default())`.
|
|
///
|
|
/// Note that if there are no windows the App will exit (by default) due to
|
|
/// [`exit_on_all_closed`].
|
|
pub primary_window: Option<Window>,
|
|
|
|
/// Whether to exit the app when there are no open windows.
|
|
///
|
|
/// If disabling this, ensure that you send the [`bevy_app::AppExit`]
|
|
/// event when the app should exit. If this does not occur, you will
|
|
/// create 'headless' processes (processes without windows), which may
|
|
/// surprise your users. It is recommended to leave this setting to
|
|
/// either [`ExitCondition::OnAllClosed`] or [`ExitCondition::OnPrimaryClosed`].
|
|
///
|
|
/// [`ExitCondition::OnAllClosed`] will add [`exit_on_all_closed`] to [`Update`].
|
|
/// [`ExitCondition::OnPrimaryClosed`] will add [`exit_on_primary_closed`] to [`Update`].
|
|
pub exit_condition: ExitCondition,
|
|
|
|
/// Whether to close windows when they are requested to be closed (i.e.
|
|
/// when the close button is pressed).
|
|
///
|
|
/// If true, this plugin will add [`close_when_requested`] to [`Update`].
|
|
/// If this system (or a replacement) is not running, the close button will have no effect.
|
|
/// This may surprise your users. It is recommended to leave this setting as `true`.
|
|
pub close_when_requested: bool,
|
|
}
|
|
|
|
impl Plugin for WindowPlugin {
|
|
fn build(&self, app: &mut App) {
|
|
// User convenience events
|
|
app.add_event::<WindowResized>()
|
|
.add_event::<WindowCreated>()
|
|
.add_event::<WindowClosed>()
|
|
.add_event::<WindowCloseRequested>()
|
|
.add_event::<WindowDestroyed>()
|
|
.add_event::<RequestRedraw>()
|
|
.add_event::<CursorMoved>()
|
|
.add_event::<CursorEntered>()
|
|
.add_event::<CursorLeft>()
|
|
.add_event::<ReceivedCharacter>()
|
|
.add_event::<Ime>()
|
|
.add_event::<WindowFocused>()
|
|
.add_event::<WindowScaleFactorChanged>()
|
|
.add_event::<WindowBackendScaleFactorChanged>()
|
|
.add_event::<FileDragAndDrop>()
|
|
.add_event::<WindowMoved>()
|
|
.add_event::<WindowThemeChanged>();
|
|
|
|
if let Some(primary_window) = &self.primary_window {
|
|
app.world
|
|
.spawn(primary_window.clone())
|
|
.insert(PrimaryWindow);
|
|
}
|
|
|
|
match self.exit_condition {
|
|
ExitCondition::OnPrimaryClosed => {
|
|
app.add_systems(PostUpdate, exit_on_primary_closed);
|
|
}
|
|
ExitCondition::OnAllClosed => {
|
|
app.add_systems(PostUpdate, exit_on_all_closed);
|
|
}
|
|
ExitCondition::DontExit => {}
|
|
}
|
|
|
|
if self.close_when_requested {
|
|
// Need to run before `exit_on_*` systems
|
|
app.add_systems(Update, close_when_requested);
|
|
}
|
|
|
|
// Register event types
|
|
app.register_type::<WindowResized>()
|
|
.register_type::<RequestRedraw>()
|
|
.register_type::<WindowCreated>()
|
|
.register_type::<WindowCloseRequested>()
|
|
.register_type::<WindowClosed>()
|
|
.register_type::<CursorMoved>()
|
|
.register_type::<CursorEntered>()
|
|
.register_type::<CursorLeft>()
|
|
.register_type::<ReceivedCharacter>()
|
|
.register_type::<WindowFocused>()
|
|
.register_type::<WindowScaleFactorChanged>()
|
|
.register_type::<WindowBackendScaleFactorChanged>()
|
|
.register_type::<FileDragAndDrop>()
|
|
.register_type::<WindowMoved>()
|
|
.register_type::<WindowThemeChanged>();
|
|
|
|
// Register window descriptor and related types
|
|
app.register_type::<Window>()
|
|
.register_type::<PrimaryWindow>()
|
|
.register_type::<Cursor>()
|
|
.register_type::<CursorIcon>()
|
|
.register_type::<CursorGrabMode>()
|
|
.register_type::<CompositeAlphaMode>()
|
|
.register_type::<WindowResolution>()
|
|
.register_type::<WindowPosition>()
|
|
.register_type::<WindowMode>()
|
|
.register_type::<WindowLevel>()
|
|
.register_type::<PresentMode>()
|
|
.register_type::<InternalWindowState>()
|
|
.register_type::<MonitorSelection>()
|
|
.register_type::<WindowResizeConstraints>()
|
|
.register_type::<WindowTheme>()
|
|
.register_type::<EnabledButtons>();
|
|
|
|
// Register `PathBuf` as it's used by `FileDragAndDrop`
|
|
app.register_type::<PathBuf>();
|
|
}
|
|
}
|
|
|
|
/// Defines the specific conditions the application should exit on
|
|
#[derive(Clone)]
|
|
pub enum ExitCondition {
|
|
/// Close application when the primary window is closed
|
|
///
|
|
/// The plugin will add [`exit_on_primary_closed`] to [`Update`].
|
|
OnPrimaryClosed,
|
|
/// Close application when all windows are closed
|
|
///
|
|
/// The plugin will add [`exit_on_all_closed`] to [`Update`].
|
|
OnAllClosed,
|
|
/// Keep application running headless even after closing all windows
|
|
///
|
|
/// If selecting this, ensure that you send the [`bevy_app::AppExit`]
|
|
/// event when the app should exit. If this does not occur, you will
|
|
/// create 'headless' processes (processes without windows), which may
|
|
/// surprise your users.
|
|
DontExit,
|
|
}
|