bevy_pancam icon indicating copy to clipboard operation
bevy_pancam copied to clipboard

A bevy plugin for panning orthographic cameras

bevy_pancam

crates.io MIT/Apache 2.0 crates.io docs.rs

A 2d-camera plugin for bevy that works with orthographic cameras.

The motivation is that this could be used for something like a map editor for a 2d game.

Controls

Behaves similarly to common online map applications:

  • Click and drag to move the camera
  • Scroll to zoom

Usage

Add the plugin to your app

App::build()
    .add_plugins(DefaultPlugins)
    .add_plugin(PanCamPlugin::default());

Add the component to an orthographic camera:

commands.spawn_bundle(Camera2dBundle::default())
    .insert(PanCam::default());

This is enough to get going with sensible defaults.

Alternatively, set the fields of the PanCam component to customize behavior:

commands.spawn_bundle(Camera2dBundle::default())
    .insert(PanCam {
        grab_buttons: vec![MouseButton::Left, MouseButton::Middle], // which buttons should drag the camera
        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
    });

See the simple and toggle examples.

Cargo features

  • bevy_egui makes pancam cameras not react when the mouse or keyboard focus is on widgets created with bevy_egui
  • bevy-inspector-egui makes pancam cameras be inspectable by bevy-inspector-egui

Bevy Version Support

The main branch targets the latest bevy release.

I intend to support the main branch of Bevy in the bevy-main branch.

bevy bevy_pancam
0.8 0.5, 0.6, main
0.7 0.3, 0.4
0.6 0.2
0.5 0.1

License

MIT or Apache-2.0

Contributions

PRs welcome!