13 releases (4 breaking)

new 0.4.0 Dec 3, 2024
0.3.1 Oct 7, 2024
0.3.0 Aug 7, 2024
0.2.0 Jul 23, 2024
0.0.4 Jun 16, 2024

#631 in Game dev

Download history 2/week @ 2024-08-16 6/week @ 2024-09-20 5/week @ 2024-09-27 197/week @ 2024-10-04 33/week @ 2024-10-11 4/week @ 2024-10-18 7/week @ 2024-11-01 7/week @ 2024-11-08 128/week @ 2024-11-29

137 downloads per month

MIT/Apache

39KB
271 lines

bevy_text_edit

crates.io docs.rs dependency status pipeline status

Quickstart

Plugin

Add plugin TextEditPlugin to the app and define which states it will run in:

#[derive(Clone, Debug, Default, Eq, PartialEq, Hash, States)]
enum GameState {
    #[default]
    Menu,
}

fn main() {
    App::new()
        .add_plugins(DefaultPlugins)
        // Add the plugin
        .add_plugins(TextEditPlugin::new(vec![GameState::Menu]))
        .run;
}

If you don't care to game state and want to always run input text, use TextEditPluginNoState:

fn main() {
    App::new()
        .add_plugins(DefaultPlugins)
        // Add the plugin
        .add_plugins(TextEditPluginNoState)
        .add_systems(Startup, setup)
        .run();
}

Component

Insert component TextEditable into any text entity that needs to be editable:

commands.spawn((
    TextEditable::default(), // Mark text is editable
    Text::new("Input Text 1"),
));

Only text that is focused by clicking gets keyboard input.

It is also possible to limit which characters are allowed to enter through filter_in and filter_out attribute. Regex is supported:

commands.spawn((
    TextEditable {
        filter_in: vec!["[0-9]".into(), " ".into()], // Only allow number and space
        filter_out: vec!["5".into()],                // Ignore number 5
    },
    Text::new("Input Text 1"),
));

License

Please see LICENSE.

Compatible Bevy Versions

bevy bevy_text_edit
0.15 0.4, branch master
0.14 0.1-0.3
0.13 0.0.1-0.0.5

Dependencies

~54–86MB
~1.5M SLoC