From 82d11b7d3e15d8175accf7579db1fbe528fc6583 Mon Sep 17 00:00:00 2001 From: Arne Dußin Date: Wed, 16 Dec 2020 13:34:56 +0100 Subject: Add constant for default colours and selection tool --- src/map/rect_room.rs | 25 ++++++++++++++++++------- 1 file changed, 18 insertions(+), 7 deletions(-) (limited to 'src/map/rect_room.rs') diff --git a/src/map/rect_room.rs b/src/map/rect_room.rs index 07f201c..5008c63 100644 --- a/src/map/rect_room.rs +++ b/src/map/rect_room.rs @@ -1,9 +1,9 @@ +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 raylib::ffi::Color; use serde::Serialize; use std::ops::{Deref, DerefMut}; @@ -12,11 +12,15 @@ pub type RectRoomData = Rect; #[derive(Serialize)] pub struct RectRoom { data: RectRoomData, + selected: bool, } impl RectRoom { pub fn from_data(data: RectRoomData) -> Self { - RectRoom { data } + RectRoom { + data, + selected: false, + } } } @@ -24,15 +28,22 @@ impl Mappable for RectRoom { fn draw(&self, rld: &mut RaylibDrawHandle, transform: &Transform) { rld.draw_rectangle_rec( transform.rect_m_to_px(&self.data), - Color { - r: 180, - g: 180, - b: 180, - a: 255, + 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 { self.data.clone() } -- cgit v1.2.3-70-g09d2