mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
b499cf2c58
Included in the initial implementation is an entity browser which lists all entities in the client ECS, an entity component viewer which shows select components belonging to the selected entity including character state information, and a simple frame time graph. This MR also includes an extraction of the animation hot reloading code which has been reused for egui to allow for hot-reloading of the egui interface to allow rapid development of the UI with realtime feedback upon save as is the case with aninmations. This is feature-gated behind the `hot-egui` feature which is not enabled by default due to the extra startup time that it adds.
88 lines
3.4 KiB
Rust
88 lines
3.4 KiB
Rust
use crate::{two_col_row, SelectedEntityInfo};
|
|
use common::{
|
|
comp::CharacterState,
|
|
states::{charged_melee, combo_melee, dash_melee, leap_melee},
|
|
};
|
|
use egui::{Grid, Ui};
|
|
|
|
pub fn draw_char_state_group(
|
|
ui: &mut Ui,
|
|
_selected_entity_info: &SelectedEntityInfo,
|
|
character_state: &CharacterState,
|
|
) {
|
|
ui.horizontal(|ui| {
|
|
ui.label("Current State: ");
|
|
ui.label(character_state.to_string());
|
|
});
|
|
match character_state {
|
|
CharacterState::ComboMelee(data) => {
|
|
combo_melee_grid(ui, data);
|
|
},
|
|
CharacterState::DashMelee(data) => dash_melee_grid(ui, data),
|
|
CharacterState::ChargedMelee(data) => charged_melee_grid(ui, data),
|
|
// Character states with no associated data to display
|
|
CharacterState::Dance
|
|
| CharacterState::Idle
|
|
| CharacterState::Sit
|
|
| CharacterState::GlideWield
|
|
| CharacterState::Sneak
|
|
| CharacterState::Talk
|
|
| CharacterState::Wielding => {},
|
|
CharacterState::LeapMelee(data) => leap_melee_grid(ui, data),
|
|
_ => {
|
|
ui.label("<Rendering not yet implemented for this state>");
|
|
},
|
|
};
|
|
}
|
|
|
|
fn charged_melee_grid(ui: &mut Ui, data: &charged_melee::Data) {
|
|
Grid::new("selected_entity_charged_melee_grid")
|
|
.spacing([40.0, 4.0])
|
|
.max_col_width(100.0)
|
|
.striped(true)
|
|
.show(ui, |ui| #[rustfmt::skip] {
|
|
two_col_row(ui, "Stage Section", data.stage_section.to_string());
|
|
two_col_row(ui, "Timer", format!("{}ms", data.timer.as_millis()));
|
|
two_col_row(ui, "Charge Amount", format!("{:.1}", data.charge_amount));
|
|
two_col_row(ui, "Exhausted", if data.exhausted { "True" } else { "False" });
|
|
});
|
|
}
|
|
|
|
fn combo_melee_grid(ui: &mut Ui, data: &combo_melee::Data) {
|
|
Grid::new("selected_entity_combo_melee_grid")
|
|
.spacing([40.0, 4.0])
|
|
.max_col_width(100.0)
|
|
.striped(true)
|
|
.show(ui, |ui| #[rustfmt::skip] {
|
|
two_col_row(ui, "Stage", data.stage.to_string());
|
|
two_col_row(ui, "Timer", format!("{}ms", data.timer.as_millis()));
|
|
two_col_row(ui, "num_stages", data.static_data.num_stages.to_string());
|
|
});
|
|
}
|
|
|
|
fn dash_melee_grid(ui: &mut Ui, data: &dash_melee::Data) {
|
|
Grid::new("selected_entity_dash_melee_grid")
|
|
.spacing([40.0, 4.0])
|
|
.max_col_width(100.0)
|
|
.striped(true)
|
|
.show(ui, |ui| #[rustfmt::skip] {
|
|
two_col_row(ui, "Auto Charge", if data.auto_charge { "True" } else { "False " });
|
|
two_col_row(ui, "Timer", format!("{}ms", data.timer.as_millis()));
|
|
two_col_row(ui, "Stage Section", data.stage_section.to_string());
|
|
two_col_row(ui, "Exhausted", if data.exhausted { "True" } else { "False " });
|
|
two_col_row(ui, "Charge End Timer", format!("{}ms", data.charge_end_timer.as_millis()));
|
|
});
|
|
}
|
|
|
|
fn leap_melee_grid(ui: &mut Ui, data: &leap_melee::Data) {
|
|
Grid::new("selected_entity_leap_melee_grid")
|
|
.spacing([40.0, 4.0])
|
|
.max_col_width(100.0)
|
|
.striped(true)
|
|
.show(ui, |ui| #[rustfmt::skip] {
|
|
two_col_row(ui, "Stage Section", data.stage_section.to_string());
|
|
two_col_row(ui, "Timer", format!("{}ms", data.timer.as_millis()));
|
|
two_col_row(ui, "Exhausted", if data.exhausted { "True" } else { "False " });
|
|
});
|
|
}
|