diff options
| author | Arne Dußin | 2020-12-21 21:12:01 +0100 |
|---|---|---|
| committer | GitHub | 2020-12-21 21:12:01 +0100 |
| commit | c435f278eddcada279fdc424120e4a1448843c20 (patch) | |
| tree | be9a5601e99608966d4ccd146c3bfb3a70c7fc02 /src/map/rect_room.rs | |
| parent | 3bc690803fb59493ea8180fd630d65b3e26642d0 (diff) | |
| parent | 82d11b7d3e15d8175accf7579db1fbe528fc6583 (diff) | |
| download | graf_karto-c435f278eddcada279fdc424120e4a1448843c20.tar.gz graf_karto-c435f278eddcada279fdc424120e4a1448843c20.zip | |
Merge pull request #24 from LordSentox/refactor
Refactor to make interaction between tools easier
Diffstat (limited to 'src/map/rect_room.rs')
| -rw-r--r-- | src/map/rect_room.rs | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/src/map/rect_room.rs b/src/map/rect_room.rs new file mode 100644 index 0000000..5008c63 --- /dev/null +++ b/src/map/rect_room.rs @@ -0,0 +1,79 @@ +use crate::colours::DEFAULT_COLOURS; +use crate::map::Mappable; +use crate::math::{Rect, Vec2}; +use crate::scaleable::Scaleable; +use crate::transform::Transform; +use raylib::drawing::{RaylibDraw, RaylibDrawHandle}; +use serde::Serialize; +use std::ops::{Deref, DerefMut}; + +pub type RectRoomData = Rect<f64>; + +#[derive(Serialize)] +pub struct RectRoom { + data: RectRoomData, + selected: bool, +} + +impl RectRoom { + pub fn from_data(data: RectRoomData) -> Self { + RectRoom { + data, + selected: false, + } + } +} + +impl Mappable for RectRoom { + fn draw(&self, rld: &mut RaylibDrawHandle, transform: &Transform) { + rld.draw_rectangle_rec( + transform.rect_m_to_px(&self.data), + if self.selected() { + DEFAULT_COLOURS.room_selected + } else { + DEFAULT_COLOURS.room_normal + }, + ); + } + + fn set_selected(&mut self, selected: bool) { + self.selected = selected; + } + + fn selected(&self) -> bool { + self.selected + } + + fn bounding_rect(&self) -> Rect<f64> { + self.data.clone() + } + + fn as_scaleable(&self) -> Option<&dyn Scaleable> { + Some(self as &dyn Scaleable) + } +} + +impl Scaleable for RectRoom { + fn scale(&mut self, by: &Vec2<f64>) { + if by.x < 0. || by.y < 0. { + panic!("Cannot set dimensions with negative size"); + } + + self.data.x *= by.x; + self.data.y *= by.y; + } +} + +impl Deref for RectRoom { + type Target = RectRoomData; + + fn deref(&self) -> &Self::Target { + &self.data + } +} + +impl DerefMut for RectRoom { + fn deref_mut(&mut self) -> &mut Self::Target { + &mut self.data + } +} |
