bevy_mod_yarn
bevy_mod_yarn copied to clipboard
Bevy_mod_yarn
data:image/s3,"s3://crabby-images/1f9f2/1f9f2ae84c9299d38f8ea1add58ab12505794ced" alt=""
Parser + interpreter/runner for the YarnSpinner dialogue file format for the Bevy Engine It allows you to create branching narrative / dialogues for games , ie , Rpgs, Visual novels, adventure games, etc in Bevy !
This project is still in the early stages, but it is already usable as it is for some basic Yarn scripts.
Since I am using it myself and will be relying on it heavilly for some of my projects (yeah for dogfooding :) ), I am aiming to be able to parse & support as much of the Yarn Syntax as possible.
Usage
Here's a minimal usage example:
# Cargo.toml
[dependencies]
bevy_mod_yarn = { git = "https://github.com/kaosat-dev/bevy_mod_yarn", branch = "main" }
use bevy::prelude::*;
use bevy_mod_yarn::prelude::*;
fn main() {
App::new()
.add_plugins(DefaultPlugins)
.add_plugin(YarnPlugin)
.init_resource::<State>() // only needed for manual loading
.add_startup_system(setup)
.add_system(dialogue_init)
.add_system(dialogue_navigation)
.run();
}
// only needed for manual loading, not when using tools like [bevy_asset_loader](https://github.com/NiklasEi/bevy_asset_loader)
#[derive(Resource, Default)]
struct State {
handle: Handle<YarnAsset>,
done: bool
}
fn setup(
mut state: ResMut<State>,
asset_server: Res<AssetServer>,
mut commands: bevy::prelude::Commands
) {
// load the yarn dialogue file
state.handle = asset_server.load("dialogues/single_node_simple.yarn");
}
fn dialogue_init(mut state: ResMut<State>, dialogues: Res<Assets<YarnAsset>>, mut commands: bevy::prelude::Commands) {
if let Some(dialogues)= dialogues.get(&state.handle) {
if !state.done {
commands.spawn(
DialogueRunner::new(dialogues.clone(), "Start")
);
state.done = true;
}
}
}
fn dialogue_navigation(
keys: Res<Input<KeyCode>>,
mut runners: Query<&mut DialogueRunner>,
) {
if let Ok(mut runner) = runners.get_single_mut() {
if keys.just_pressed(KeyCode::Return) {
runner.next_entry();
}
if keys.just_pressed(KeyCode::Down) {
runner.next_choice()
}
if keys.just_pressed(KeyCode::Up) {
runner.prev_choice()
}
}
}
this is taken from the 'basic' example
see the examples below for more details , how to display your dialogues etc
Examples
This crate provides different examples for different features/ways to use within Bevy
Basic
-
simplest possible usage
run it with
cargo run --example basic
Commands
-
using
Yarn
commands with Bevy systems to play audio files during the dialogue flowrun it with
cargo run --example commands
Portraits
-
a barebones "old school rpg dialogue with Character portraits" ie changing character portraits based on who is talking in your dialogue
run it with
cargo run --example portraits
Bubbles
-
a barebones "speech bubbles" (ok, just text, but still :) over characters heads in 3D
run it with
cargo run --example bubbles
Development status
- [x] basic nodes parsing (header + body)
- [x] dialogues: with or without character names
- [x] choices/ options: blank line to close a list of choices
- [x] choices/ options: nested/ indentation handling
- [x] commands: basic parsing & handling
- [x] tags parsing
- [ ] tags available inside statements
- [ ] expressions parsing
- [ ] conditional expressions
- [ ] dialogues: conditional branching with expressions
- [ ] dialogues: interpolated values
- [ ] dialogues: attributes
I will put it on crates.io once I feel it is useable enough.
What this tool does:
-
provide a parser (written with Nom). Not specific to Bevy, will likely be extracted into its own Crate down the line.
-
provide an asset loader for Bevy
-
provide a plugin for Bevy
-
some additional data structures and functions to deal with the Yarn Format inside bevy, in a minimalistic manner
What this tool does not:
- provide complex UI or predefined ways to interact with the dialogues inside Bevy, for a few reasons
- you will find some varied examples for use with Bevy to get you started
License
Dual-licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)
at your option.
Compatible Bevy versions
The main branch is compatible with the latest Bevy release (0.10.1), while the branch bevy_main
tries to track the main
branch of Bevy (not started yet, PRs updating the tracked commit are welcome).
Compatibility of bevy_mod_yarn
versions:
bevy_mod_yarn |
bevy |
---|---|
0.3 |
0.12 |
0.2 |
0.11 |
0.1 |
0.10 |
main |
latest |
bevy_main |
main |
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.