diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/image.rs | 11 | ||||
-rw-r--r-- | src/main.rs | 22 |
2 files changed, 27 insertions, 6 deletions
diff --git a/src/image.rs b/src/image.rs index 177eff2..5b6cb33 100644 --- a/src/image.rs +++ b/src/image.rs @@ -73,11 +73,18 @@ impl Image { } pub fn rect(&mut self, pos: Vec2<u32>, dim: Vec2<u32>, clr: Color) { + if pos.x >= self.width || pos.y >= self.height { + // if we're fully over in one of these directions, we shouldn't go further. + return; + } + + // .min(..) so we only draw what we can see/what's within bounds let x_start = pos.x as usize; - let x_end = (pos.x + dim.x) as usize; + let x_end = (pos.x + dim.x).min(self.width - 1) as usize; + let y_end = (pos.y + dim.y).min(self.height - 1) as usize; for idx in x_start..x_end { - for idy in pos.y as usize..pos.y as usize + dim.y as usize { + for idy in pos.y as usize..y_end { let data_idx = idx + idy * self.width as usize; self.data[data_idx] = clr.into(); } diff --git a/src/main.rs b/src/main.rs index 59d004f..dc3989a 100644 --- a/src/main.rs +++ b/src/main.rs @@ -132,6 +132,20 @@ impl Etch { gif.save(path).unwrap(); } } + + pub fn keep_stylus_inbounds(&mut self) { + if self.stylus.x < 0.0 { + self.stylus.x = 0.0; + } else if self.stylus.x > self.img.width() as f32 - 1.0 { + self.stylus.x = self.img.width() as f32 - 1.0; + } + + if self.stylus.y < 0.0 { + self.stylus.y = 0.0 + } else if self.stylus.y > self.img.height() as f32 - 1.0 { + self.stylus.y = self.img.height() as f32 - 1.0; + } + } } // Why are my consts HERE of all places @@ -240,10 +254,8 @@ impl ApplicationHandler for Etch { let movement_x = left_delta / DIAL_SENSITIVITY; let movement_y = right_delta / DIAL_SENSITIVITY; - self.stylus.x = - (self.stylus.x + movement_x).clamp(0.0, self.img.width() as f32); - self.stylus.y = - (self.stylus.y - movement_y).clamp(0.0, self.img.height() as f32); + self.stylus.x = self.stylus.x + movement_x; + self.stylus.y = self.stylus.y - movement_y; self.next_check = Instant::now(); } @@ -280,6 +292,8 @@ impl ApplicationHandler for Etch { } } + self.keep_stylus_inbounds(); + // If the stylus moved, we should draw if stylus_prev != self.stylus { self.img.line( |