diff --git a/Cargo.toml b/Cargo.toml index 245d5ba..a41a0b3 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -13,11 +13,11 @@ version = "0.15.0" bevy_egui = ["dep:bevy_egui"] [dependencies] -bevy = {version = "0.14", features = ["bevy_render"], default-features = false} -bevy_egui = {version = "0.30", optional = true, default-features = false} +bevy = { version = "0.15", features = ["bevy_window", "bevy_core_pipeline"], default-features = false } +bevy_egui = { version = "0.31", optional = true, default-features = false } [dev-dependencies] -bevy = {version = "0.14", default-features = false, features = [ +bevy = {version = "0.15", default-features = false, features = [ "bevy_render", "bevy_asset", "bevy_sprite", @@ -25,8 +25,8 @@ bevy = {version = "0.14", default-features = false, features = [ "bevy_core_pipeline", "x11", # github actions runners don't have libxkbcommon installed, so can't use wayland ]} -bevy-inspector-egui = { version = "0.27", default-features = false, features = ["bevy_render"]} -bevy_egui = {version = "0.30", default-features = false, features = ["default_fonts"]} +bevy-inspector-egui = { version = "0.28", default-features = false, features = ["bevy_render"] } +bevy_egui = { version = "0.31", default-features = false, features = ["default_fonts"] } rand = "0.8" [[example]] diff --git a/README.md b/README.md index ad7daf0..eb3f1bb 100644 --- a/README.md +++ b/README.md @@ -30,8 +30,10 @@ App::new() Add the component to an orthographic camera: ```rust ignore -commands.spawn(Camera2dBundle::default()) - .insert(PanCam::default()); +commands.spawn(( + Camera2d, + PanCam::default(), +)) ``` This is enough to get going with sensible defaults. @@ -39,8 +41,9 @@ This is enough to get going with sensible defaults. Alternatively, set the fields of the `PanCam` component to customize behavior: ```rust ignore -commands.spawn(Camera2dBundle::default()) - .insert(PanCam { +commands.spawn(( + Camera2d, + PanCam { grab_buttons: vec![MouseButton::Left, MouseButton::Middle], // which buttons should drag the camera move_keys: DirectionKeys { // the keyboard buttons used to move the camera up: vec![KeyCode::KeyQ], // initalize the struct like this or use the provided methods for @@ -52,8 +55,13 @@ commands.spawn(Camera2dBundle::default()) enabled: true, // when false, controls are disabled. See toggle example. zoom_to_cursor: true, // whether to zoom towards the mouse or the center of the screen min_scale: 1., // prevent the camera from zooming too far in - max_scale: Some(40.), // prevent the camera from zooming too far out - }); + max_scale: 40., // prevent the camera from zooming too far out + min_x: f32::NEG_INFINITY, // minimum x position of the camera window + max_x: f32::INFINITY, // maximum x position of the camera window + min_y: f32::NEG_INFINITY, // minimum y position of the camera window + max_y: f32::INFINITY, // maximum y position of the camera window + }, +)); ``` See the [`simple`](./examples/simple.rs) and [`toggle`](./examples/toggle.rs) examples. diff --git a/examples/camera_scaling_mode.rs b/examples/camera_scaling_mode.rs index f6a65d7..0e9b72b 100644 --- a/examples/camera_scaling_mode.rs +++ b/examples/camera_scaling_mode.rs @@ -4,17 +4,20 @@ use rand::prelude::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default())) + .add_plugins((DefaultPlugins, PanCamPlugin)) .add_systems(Startup, setup) .run(); } fn setup(mut commands: Commands) { - let mut cam = Camera2dBundle::default(); - cam.projection.scaling_mode = ScalingMode::FixedVertical(10.0); + let mut ortho = OrthographicProjection::default_2d(); + ortho.scaling_mode = ScalingMode::FixedVertical { + viewport_height: 10.0, + }; commands.spawn(( - cam, + Camera2d, + ortho, PanCam { min_x: -10., max_x: 10., @@ -33,15 +36,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing + offset; let y = y as f32 * spacing + offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/clamped_borders.rs b/examples/clamped_borders.rs index c837959..c471a39 100644 --- a/examples/clamped_borders.rs +++ b/examples/clamped_borders.rs @@ -4,14 +4,14 @@ use rand::prelude::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default())) + .add_plugins((DefaultPlugins, PanCamPlugin)) .add_systems(Startup, setup) .run(); } fn setup(mut commands: Commands) { commands.spawn(( - Camera2dBundle::default(), + Camera2d, PanCam { // prevent the camera from zooming too far out max_scale: 40., @@ -40,15 +40,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing - offset; let y = y as f32 * spacing - offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/egui.rs b/examples/egui.rs index 1123ca9..e5288f4 100644 --- a/examples/egui.rs +++ b/examples/egui.rs @@ -8,7 +8,7 @@ use rand::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default(), EguiPlugin)) + .add_plugins((DefaultPlugins, PanCamPlugin, EguiPlugin)) .add_systems(Update, egui_ui) .add_systems(Startup, setup) .run(); @@ -33,7 +33,7 @@ fn egui_ui(mut contexts: EguiContexts) { } fn setup(mut commands: Commands) { - commands.spawn((Camera2dBundle::default(), PanCam::default())); + commands.spawn((Camera2d, PanCam::default())); let n = 20; let spacing = 50.; @@ -44,15 +44,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing - offset; let y = y as f32 * spacing - offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/inspector.rs b/examples/inspector.rs index 99a0b4e..5a9011a 100644 --- a/examples/inspector.rs +++ b/examples/inspector.rs @@ -5,17 +5,13 @@ use rand::random; fn main() { App::new() - .add_plugins(( - DefaultPlugins, - PanCamPlugin::default(), - WorldInspectorPlugin::default(), - )) + .add_plugins((DefaultPlugins, PanCamPlugin, WorldInspectorPlugin::new())) .add_systems(Startup, setup) .run(); } fn setup(mut commands: Commands) { - commands.spawn((Camera2dBundle::default(), PanCam::default())); + commands.spawn((Camera2d, PanCam::default())); let n = 20; let spacing = 50.; @@ -26,15 +22,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing - offset; let y = y as f32 * spacing - offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/limits.rs b/examples/limits.rs index dab0bbe..c8c82b9 100644 --- a/examples/limits.rs +++ b/examples/limits.rs @@ -4,14 +4,14 @@ use rand::prelude::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default())) + .add_plugins((DefaultPlugins, PanCamPlugin)) .add_systems(Startup, setup) .run(); } fn setup(mut commands: Commands) { commands.spawn(( - Camera2dBundle::default(), + Camera2d, PanCam { // Set max scale in order to prevent the camera from zooming too far out max_scale: 40., @@ -30,15 +30,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing - offset; let y = y as f32 * spacing - offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/simple.rs b/examples/simple.rs index 9e8f428..4c906a1 100644 --- a/examples/simple.rs +++ b/examples/simple.rs @@ -4,13 +4,13 @@ use rand::prelude::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default())) + .add_plugins((DefaultPlugins, PanCamPlugin)) .add_systems(Startup, setup) .run(); } fn setup(mut commands: Commands) { - commands.spawn((Camera2dBundle::default(), PanCam::default())); + commands.spawn((Camera2d, PanCam::default())); let n = 20; let spacing = 50.; @@ -21,15 +21,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing - offset; let y = y as f32 * spacing - offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/toggle.rs b/examples/toggle.rs index 1535c38..e6fe594 100644 --- a/examples/toggle.rs +++ b/examples/toggle.rs @@ -4,14 +4,14 @@ use rand::prelude::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default())) + .add_plugins((DefaultPlugins, PanCamPlugin)) .add_systems(Startup, setup) .add_systems(Update, toggle_key) .run(); } fn setup(mut commands: Commands) { - commands.spawn((Camera2dBundle::default(), PanCam::default())); + commands.spawn((Camera2d, PanCam::default())); let n = 20; let spacing = 50.; @@ -22,15 +22,14 @@ fn setup(mut commands: Commands) { let x = x as f32 * spacing - offset; let y = y as f32 * spacing - offset; let color = Color::hsl(240., random::() * 0.3, random::() * 0.3); - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color, custom_size, ..default() }, - transform: Transform::from_xyz(x, y, 0.), - ..default() - }); + Transform::from_xyz(x, y, 0.), + )); } } } diff --git a/examples/viewport.rs b/examples/viewport.rs index 67bc206..8237317 100644 --- a/examples/viewport.rs +++ b/examples/viewport.rs @@ -1,25 +1,22 @@ use bevy::{prelude::*, render::camera::Viewport}; use bevy_pancam::{PanCam, PanCamPlugin}; -use rand::prelude::random; fn main() { App::new() - .add_plugins((DefaultPlugins, PanCamPlugin::default())) + .add_plugins((DefaultPlugins, PanCamPlugin)) .add_systems(Startup, setup) .run(); } fn setup(mut commands: Commands) { commands.spawn(( - Camera2dBundle { - camera: Camera { - viewport: Some(Viewport { - physical_position: UVec2::new(100, 200), - physical_size: UVec2::new(600, 400), - depth: 0.0..1.0, - }), - ..Camera2dBundle::default().camera - }, + Camera2d, + Camera { + viewport: Some(Viewport { + physical_position: UVec2::new(100, 200), + physical_size: UVec2::new(600, 400), + depth: 0.0..1.0, + }), ..default() }, PanCam { @@ -32,24 +29,22 @@ fn setup(mut commands: Commands) { )); // background - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color: Color::srgb(0.3, 0.3, 0.3), custom_size: Some(Vec2::new(1000., 1000.)), ..default() }, - transform: Transform::from_xyz(0., 0., 0.), - ..default() - }); + Transform::from_xyz(0., 0., 0.), + )); // red square - commands.spawn(SpriteBundle { - sprite: Sprite { + commands.spawn(( + Sprite { color: Color::srgb(0.8, 0.3, 0.3), custom_size: Some(Vec2::new(100., 100.)), ..default() }, - transform: Transform::from_xyz(0., 0., 1.), - ..default() - }); + Transform::from_xyz(0., 0., 1.), + )); } diff --git a/src/lib.rs b/src/lib.rs index 6fd4af4..f36f906 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -310,7 +310,7 @@ fn do_camera_movement( let direction = pan_cam.move_keys.direction(&keyboard_buttons); let keyboard_delta = - time.delta_seconds() * direction.normalize_or_zero() * pan_cam.speed * projection.scale; + time.delta_secs() * direction.normalize_or_zero() * pan_cam.speed * projection.scale; let delta = mouse_delta - keyboard_delta; if delta == Vec2::ZERO { @@ -330,6 +330,7 @@ fn do_camera_movement( /// A component that adds panning camera controls to an orthographic camera #[derive(Component, Reflect)] #[reflect(Component)] +#[require(Camera2d)] pub struct PanCam { /// The mouse buttons that will be used to drag and pan the camera pub grab_buttons: Vec, @@ -437,7 +438,7 @@ mod tests { /// Simple mock function to construct a square projection from a window size fn mock_proj(window_size: Vec2) -> OrthographicProjection { - let mut proj = Camera2dBundle::default().projection; + let mut proj = OrthographicProjection::default_2d(); proj.update(window_size.x, window_size.y); proj }