From f1a4d4c4090a21566f084905b86663a163dc8c12 Mon Sep 17 00:00:00 2001 From: Ian Jackson Date: Fri, 26 Jun 2020 17:58:46 +0100 Subject: [PATCH] more generation --- src/gamestate.rs | 14 ++++++++------ src/pieces.rs | 26 +++++++++++++++++++++++--- 2 files changed, 31 insertions(+), 9 deletions(-) diff --git a/src/gamestate.rs b/src/gamestate.rs index 6d2c3280..87fd743d 100644 --- a/src/gamestate.rs +++ b/src/gamestate.rs @@ -17,7 +17,7 @@ pub type VisiblePieceIdSvgIds = &'static [&'static str]; impl Display for VisiblePieceId { fn fmt(&self, f: &mut fmt::Formatter) -> Result<(), fmt::Error> { - write!(f, "{}-{}", self.0 >> 32, self.0 & 0xffffffff) + write!(f, "{}.{}", self.0 >> 32, self.0 & 0xffffffff) } } impl Debug for VisiblePieceId { @@ -27,14 +27,16 @@ impl Debug for VisiblePieceId { } impl PieceRenderInstructions { - pub fn id_piece(&self) -> String { format!("piece{:}", self.id) } - pub fn id_select(&self) -> String { format!("select{:}", self.id) } - pub fn id_other(&self, w : &str) -> String { format!("d{}-{}", self.id, w) } + pub fn id_piece(&self) -> String { format!("piece{}", self.id) } + pub fn id_select(&self) -> String { format!("select{}", self.id) } + pub fn id_x(&self, w : &str) -> String { format!("def.{}.{}", self.id, w) } } pub trait Piece : Send + Debug { - fn svg_other_ids(&self) -> VisiblePieceIdSvgIds; - fn svg_defs(&self, pri : &PieceRenderInstructions) -> String; + fn svg_piece(&self, pri : &PieceRenderInstructions) -> String; + fn svg_select(&self, pri : &PieceRenderInstructions) -> String; + fn svg_x_ids(&self) -> VisiblePieceIdSvgIds; + fn svg_x_defs(&self, pri : &PieceRenderInstructions) -> String; } #[derive(Debug)] diff --git a/src/pieces.rs b/src/pieces.rs index 5ba90784..35c5a7b9 100644 --- a/src/pieces.rs +++ b/src/pieces.rs @@ -11,10 +11,30 @@ struct SimpleShape { colours : IndexVec, } +const SELECT_SCALE : f64 = 1.1; + impl Piece for SimpleShape { - fn svg_other_ids(&self) -> VisiblePieceIdSvgIds { &["base"] } - fn svg_defs(&self, pri : &PieceRenderInstructions) -> String { - format!(r#"{}"#, pri.id_other("base"), self.shape) + fn svg_piece(&self, pri : &PieceRenderInstructions) -> String { + format!(r##" + + + + "##, + self.colours[pri.face], + pri.id_x("base")) + } + fn svg_select(&self, pri : &PieceRenderInstructions) -> String { + format!(r##" + + + + "##, + SELECT_SCALE, + pri.id_x("base")) + } + fn svg_x_ids(&self) -> VisiblePieceIdSvgIds { &["base"] } + fn svg_x_defs(&self, pri : &PieceRenderInstructions) -> String { + format!(r#"{}"#, pri.id_x("base"), self.shape) } } -- 2.30.2