Compare commits

..

No commits in common. "ae42cd10a460c4bf4bbc9599b4a10dfd8ec3ed75" and "ad360ed96eb23a9fb89e7bb8b827c328d1ba0c40" have entirely different histories.

4 changed files with 14 additions and 88 deletions

View file

@ -5,14 +5,7 @@
"id": "output", "id": "output",
"name": "Zero", "name": "Zero",
"description": "learn how to output data", "description": "learn how to output data",
"init_board": { "init_board": "\n o \n\n I\n\n",
"comments": [
{ "text": "Welcome :3", "x": 3, "y": 0 },
{ "text": "< This is a marble,\n it will move down when you start the machine", "x": 3, "y": 2 },
{ "text": "< This is an input/output silo\n when a marble enters it, it disappears\n and the value it held is added to the level output", "x": 3, "y": 5 }
],
"grid": "\n\n o \n\n\n I\n\n\n"
},
"stages": [{ "stages": [{
"input": [], "input": [],
"output": [0] "output": [0]

View file

@ -1,24 +1,15 @@
use raylib::{
color::Color,
drawing::{RaylibDraw, RaylibDrawHandle},
math::Vector2,
};
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use crate::{ use crate::marble_engine::{
marble_engine::{ grid::{Grid, ResizeDeltas},
grid::{Grid, ResizeDeltas}, pos::Pos,
pos::Pos, tile::Tile,
tile::Tile,
},
theme::TILE_TEXTURE_SIZE,
}; };
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
pub struct Comment { pub struct Comment {
text: String, text: String,
x: i32, pos: Pos,
y: i32,
} }
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)] #[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
@ -71,33 +62,9 @@ impl Board {
} }
} }
pub fn draw_comments(&self, d: &mut RaylibDrawHandle, offset: Vector2, scale: f32) {
let tile_size = (TILE_TEXTURE_SIZE * scale) as i32;
let font_size = 10 * (scale as i32).max(1);
let line_space = 12 * (scale as i32).max(1);
for comment in &self.comments {
let x = comment.x * tile_size + offset.x as i32;
let y = comment.y * tile_size + offset.y as i32;
for (i, line) in comment.text.lines().enumerate() {
let y = y + line_space * i as i32;
d.draw_text(&line, x, y, font_size, Color::ORANGE);
}
}
}
pub fn get_rect(&self, pos: Pos, width: usize, height: usize) -> Self { pub fn get_rect(&self, pos: Pos, width: usize, height: usize) -> Self {
let comments = self // TODO filter for comments in the area
.comments let comments = self.comments.clone();
.iter()
.filter(|c| c.in_area(pos, width, height))
.map(|c| {
let mut c = c.clone();
c.x -= pos.x as i32;
c.y -= pos.y as i32;
c
})
.collect();
Self { Self {
grid: self.grid.get_rect(pos, width, height), grid: self.grid.get_rect(pos, width, height),
comments, comments,
@ -105,36 +72,19 @@ impl Board {
} }
pub fn paste_board(&mut self, pos: Pos, board: &Board) { pub fn paste_board(&mut self, pos: Pos, board: &Board) {
// TODO remove overlapping comments
self.grid.paste_grid(pos, &board.grid); self.grid.paste_grid(pos, &board.grid);
for c in &board.comments { self.comments.extend_from_slice(&board.comments);
let mut comment = c.clone();
comment.x += pos.x as i32;
comment.y += pos.y as i32;
self.add_comment(comment);
}
}
pub fn add_comment(&mut self, comment: Comment) {
if self.comments.iter().any(|c| c == &comment) {
return;
}
self.comments.push(comment);
} }
pub fn grow(&mut self, deltas: &ResizeDeltas) { pub fn grow(&mut self, deltas: &ResizeDeltas) {
self.grid.grow(deltas); self.grid.grow(deltas);
for c in &mut self.comments { // TODO adjust comments
c.x += deltas.x_neg as i32;
c.y += deltas.y_neg as i32;
}
} }
pub fn shrink(&mut self, deltas: &ResizeDeltas) { pub fn shrink(&mut self, deltas: &ResizeDeltas) {
self.grid.shrink(deltas); self.grid.shrink(deltas);
for c in &mut self.comments { // TODO adjust comments
c.x -= deltas.x_neg as i32;
c.y -= deltas.y_neg as i32;
}
} }
pub fn from_user_str(source: &str) -> Self { pub fn from_user_str(source: &str) -> Self {
@ -152,12 +102,3 @@ impl Board {
self.grid.height() self.grid.height()
} }
} }
impl Comment {
fn in_area(&self, pos: Pos, width: usize, height: usize) -> bool {
self.x >= pos.x as i32
&& self.y >= pos.y as i32
&& self.x < pos.x as i32 + width as i32
&& self.y < pos.y as i32 + height as i32
}
}

View file

@ -146,7 +146,7 @@ impl Editor {
machine, machine,
sim_state: SimState::Editing, sim_state: SimState::Editing,
view_offset: Vector2::zero(), view_offset: Vector2::zero(),
zoom: 2., zoom: 1.,
active_tool: Tool::None, active_tool: Tool::None,
output_as_text, output_as_text,
input_as_text, input_as_text,
@ -553,7 +553,7 @@ impl Editor {
self.pasting_board = Some(b); self.pasting_board = Some(b);
} }
} else if rl.is_key_pressed(KeyboardKey::KEY_Z) { } else if rl.is_key_pressed(KeyboardKey::KEY_Z) {
self.undo(); self.undo()
} else if rl.is_key_pressed(KeyboardKey::KEY_Y) { } else if rl.is_key_pressed(KeyboardKey::KEY_Y) {
self.redo(); self.redo();
} }
@ -584,10 +584,6 @@ impl Editor {
.draw_marble_values(d, textures, self.view_offset, self.zoom); .draw_marble_values(d, textures, self.view_offset, self.zoom);
} }
} }
if self.draw_overlay {
self.source_board
.draw_comments(d, self.view_offset, self.zoom);
}
} }
pub fn draw(&mut self, d: &mut RaylibDrawHandle, textures: &Textures) { pub fn draw(&mut self, d: &mut RaylibDrawHandle, textures: &Textures) {

View file

@ -529,10 +529,6 @@ impl Machine {
} }
#[cfg(debug_assertions)] #[cfg(debug_assertions)]
{ {
self.debug_subticks.push(DebugSubTick {
grid: self.grid.clone(),
pos: None,
});
self.subtick_index = self.debug_subticks.len() - 1; self.subtick_index = self.debug_subticks.len() - 1;
} }
} }