Compare commits

...

2 commits

Author SHA1 Message Date
74d142191c cleanup 2024-12-24 23:32:25 +01:00
f35ca28c02 cleanup 2024-12-24 23:30:02 +01:00
2 changed files with 16 additions and 26 deletions

View file

@ -884,15 +884,11 @@ impl Editor {
self.tooltip.add(368, 4, 48, 32, "Speed"); self.tooltip.add(368, 4, 48, 32, "Speed");
draw_usize(d, textures, 1 << self.sim_speed, (368, 4), SPEED_DIGITS, 1); draw_usize(d, textures, 1 << self.sim_speed, (368, 4), SPEED_DIGITS, 1);
slider( slider(
d, (d, &self.mouse),
&self.mouse, rect(368, 24, 48, 12),
&mut self.sim_speed, &mut self.sim_speed,
0, 0,
MAX_SPEED_POWER, MAX_SPEED_POWER,
368,
24,
48,
12,
); );
self.tooltip.add(420, 4, 180, 32, "Steps"); self.tooltip.add(420, 4, 180, 32, "Steps");
@ -1028,8 +1024,7 @@ impl Editor {
|(row, col): (i32, i32), texture: &str, tooltip: &'static str, tool_option: Tool| { |(row, col): (i32, i32), texture: &str, tooltip: &'static str, tool_option: Tool| {
let border = 4.; let border = 4.;
let gap = 2.; let gap = 2.;
let tex_size = 32.; let button_size = 32. + border * 2.;
let button_size = tex_size + border * 2.;
let grid_size = button_size + gap * 2.; let grid_size = button_size + gap * 2.;
let pos = Vector2 { let pos = Vector2 {
x: 100. + col as f32 * grid_size - if col < 0 { 10. } else { 0. }, x: 100. + col as f32 * grid_size - if col < 0 { 10. } else { 0. },
@ -1040,13 +1035,11 @@ impl Editor {
tooltip, tooltip,
); );
scrollable_texture_option_button( scrollable_texture_option_button(
d, (d, &self.mouse),
&self.mouse,
pos, pos,
textures.get(texture), textures.get(texture),
tool_option, tool_option,
&mut self.active_tool, &mut self.active_tool,
tex_size,
border, border,
) )
}; };

View file

@ -299,13 +299,11 @@ pub fn text_input(
} }
pub fn scrollable_texture_option_button<T>( pub fn scrollable_texture_option_button<T>(
d: &mut RaylibDrawHandle, (d, mouse): (&mut RaylibDrawHandle, &MouseInput),
mouse: &MouseInput,
pos: Vector2, pos: Vector2,
texture: &Texture2D, texture: &Texture2D,
option: T, option: T,
current: &mut T, current: &mut T,
tex_size: f32,
border: f32, border: f32,
) -> Option<Scroll> ) -> Option<Scroll>
where where
@ -314,8 +312,8 @@ where
let bounds = Rectangle { let bounds = Rectangle {
x: pos.x, x: pos.x,
y: pos.y, y: pos.y,
width: tex_size + border * 2., width: 32. + border * 2.,
height: tex_size + border * 2., height: 32. + border * 2.,
}; };
d.draw_rectangle_rec( d.draw_rectangle_rec(
bounds, bounds,
@ -329,7 +327,7 @@ where
texture, texture,
pos + Vector2::new(border, border), pos + Vector2::new(border, border),
0., 0.,
tex_size / texture.width as f32, 32. / texture.width as f32,
Color::WHITE, Color::WHITE,
); );
if mouse.is_over(bounds) { if mouse.is_over(bounds) {
@ -388,21 +386,20 @@ pub fn draw_usize_small(
} }
pub fn slider( pub fn slider(
d: &mut RaylibDrawHandle, (d, mouse): (&mut RaylibDrawHandle, &MouseInput),
mouse: &MouseInput, bounds: Rectangle,
value: &mut u8, value: &mut u8,
min: u8, min: u8,
max: u8, max: u8,
x: i32,
y: i32,
width: i32,
height: i32,
) -> bool { ) -> bool {
// draw state
// 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 + 1) as f32; let percent = (*value - min + 1) as f32 / (max - min + 1) as f32;
d.draw_rectangle(x, y, width, height, BG_WIDGET); d.draw_rectangle_rec(bounds, BG_WIDGET);
d.draw_rectangle(x, y, (width as f32 * percent) as i32, height, Color::CYAN); let mut filled_bounds = bounds;
let bounds = Rectangle::new(x as f32, y as f32, width as f32, height as f32); filled_bounds.width *= percent;
d.draw_rectangle_rec(filled_bounds, Color::CYAN);
// interaction
if mouse.is_over(bounds) { if mouse.is_over(bounds) {
if mouse.left_hold() { if mouse.left_hold() {
let percent = (mouse.pos().x - bounds.x) / bounds.width; let percent = (mouse.pos().x - bounds.x) / bounds.width;