make sim handle speeds faster than framerate and change speed slider from 1-32 linear to 1-512 powers of two
This commit is contained in:
parent
dd63851606
commit
23ac416c7e
2 changed files with 31 additions and 17 deletions
|
@ -109,7 +109,7 @@ impl Editor {
|
||||||
input_text_selected: false,
|
input_text_selected: false,
|
||||||
new_blueprint_name: String::new(),
|
new_blueprint_name: String::new(),
|
||||||
blueprint_name_selected: false,
|
blueprint_name_selected: false,
|
||||||
sim_speed: 8,
|
sim_speed: 3,
|
||||||
time_since_step: 0.,
|
time_since_step: 0.,
|
||||||
tool_math: MathOp::Add,
|
tool_math: MathOp::Add,
|
||||||
tool_gate: GateType::Equal,
|
tool_gate: GateType::Equal,
|
||||||
|
@ -348,10 +348,18 @@ impl Editor {
|
||||||
}
|
}
|
||||||
if self.sim_state == SimState::Running {
|
if self.sim_state == SimState::Running {
|
||||||
self.time_since_step += rl.get_frame_time();
|
self.time_since_step += rl.get_frame_time();
|
||||||
if self.time_since_step > 1. / self.sim_speed as f32 {
|
let step_size = 1. / (1 << self.sim_speed) as f32;
|
||||||
self.time_since_step = 0.;
|
if self.time_since_step > step_size {
|
||||||
|
let step_count = (self.time_since_step / step_size) as u32;
|
||||||
|
for _ in 0..step_count {
|
||||||
|
if self.sim_state != SimState::Running {
|
||||||
|
// pause on level completion
|
||||||
|
break;
|
||||||
|
}
|
||||||
self.step();
|
self.step();
|
||||||
}
|
}
|
||||||
|
self.time_since_step -= step_count as f32 * step_size;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if rl.is_key_pressed(KeyboardKey::KEY_SPACE) {
|
if rl.is_key_pressed(KeyboardKey::KEY_SPACE) {
|
||||||
self.step_pressed()
|
self.step_pressed()
|
||||||
|
@ -371,9 +379,11 @@ impl Editor {
|
||||||
}
|
}
|
||||||
|
|
||||||
let mouse_pos = rl.get_mouse_position();
|
let mouse_pos = rl.get_mouse_position();
|
||||||
if self.active_tool != Tool::Blueprint
|
if (self.active_tool != Tool::Blueprint
|
||||||
|| self.sim_state != SimState::Editing
|
|| self.sim_state != SimState::Editing
|
||||||
|| mouse_pos.x > SIDEBAR_WIDTH as f32
|
|| mouse_pos.x > SIDEBAR_WIDTH as f32)
|
||||||
|
&& mouse_pos.y > HEADER_HEIGHT as f32
|
||||||
|
&& (mouse_pos.y as i32) < (rl.get_screen_height() - FOOTER_HEIGHT)
|
||||||
{
|
{
|
||||||
if rl.get_mouse_wheel_move() > 0. {
|
if rl.get_mouse_wheel_move() > 0. {
|
||||||
self.zoom_in(rl);
|
self.zoom_in(rl);
|
||||||
|
@ -611,9 +621,9 @@ impl Editor {
|
||||||
}
|
}
|
||||||
draw_scaled_texture(d, textures.get("step"), 332, 4, 2.);
|
draw_scaled_texture(d, textures.get("step"), 332, 4, 2.);
|
||||||
|
|
||||||
d.draw_text("speed", 368, 6, 10, Color::WHITE);
|
d.draw_text("spd", 368, 6, 10, Color::WHITE);
|
||||||
draw_usize(d, textures, self.sim_speed as usize, 398, 4, 2, 1);
|
draw_usize(d, textures, (1 << self.sim_speed) as usize, 388, 4, 3, 1);
|
||||||
slider(d, &mut self.sim_speed, 1, 33, 368, 24, 48, 12);
|
slider(d, &mut self.sim_speed, 0, 9, 368, 24, 48, 12);
|
||||||
|
|
||||||
draw_usize(d, textures, self.machine.step_count(), 420, 4, 5, 2);
|
draw_usize(d, textures, self.machine.step_count(), 420, 4, 5, 2);
|
||||||
|
|
||||||
|
|
14
src/util.rs
14
src/util.rs
|
@ -229,19 +229,23 @@ pub fn slider(
|
||||||
height: i32,
|
height: i32,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
// the +1 makes the lowest state look slightly filled and the max state fully filled
|
// the +1 makes the lowest state look slightly filled and the max state fully filled
|
||||||
let percent = (*value - min + 1) as f32 / (max - min) as f32;
|
let percent = (*value - min + 1) as f32 / (max - min + 1) as f32;
|
||||||
d.draw_rectangle(x, y, width, height, Color::DIMGRAY);
|
d.draw_rectangle(x, y, width, height, Color::DIMGRAY);
|
||||||
d.draw_rectangle(x, y, (width as f32 * percent) as i32, height, Color::CYAN);
|
d.draw_rectangle(x, y, (width as f32 * percent) as i32, height, Color::CYAN);
|
||||||
let mouse_pos = d.get_mouse_position();
|
let mouse_pos = d.get_mouse_position();
|
||||||
let bounds = Rectangle::new(x as f32, y as f32, width as f32, height as f32);
|
let bounds = Rectangle::new(x as f32, y as f32, width as f32, height as f32);
|
||||||
if d.is_mouse_button_down(MouseButton::MOUSE_BUTTON_LEFT)
|
if bounds.check_collision_point_rec(mouse_pos) {
|
||||||
&& bounds.check_collision_point_rec(mouse_pos)
|
if d.is_mouse_button_down(MouseButton::MOUSE_BUTTON_LEFT) {
|
||||||
{
|
|
||||||
let percent = (mouse_pos.x - bounds.x) / bounds.width;
|
let percent = (mouse_pos.x - bounds.x) / bounds.width;
|
||||||
let new_value = min + (percent * (max - min) as f32) as u8;
|
let new_value = min + (percent * (max - min + 1) as f32) as u8;
|
||||||
if *value != new_value {
|
if *value != new_value {
|
||||||
*value = new_value
|
*value = new_value
|
||||||
}
|
}
|
||||||
|
} else if d.get_mouse_wheel_move() > 0.5 && *value < max {
|
||||||
|
*value += 1;
|
||||||
|
} else if d.get_mouse_wheel_move() < -0.5 && *value > min {
|
||||||
|
*value -= 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue