1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
use crate::text::TextSize;
use graphics_shapes::coord::Coord;
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
pub enum TextPos {
Px(isize, isize),
ColRow(usize, usize),
}
impl TextPos {
pub fn to_coord(&self, size: TextSize) -> (isize, isize) {
match self {
TextPos::Px(x, y) => (*x, *y),
TextPos::ColRow(col, row) => (
(col * (size.get_size().0 + size.get_spacing())) as isize,
(row * (size.get_size().1 + size.get_spacing())) as isize,
),
}
}
pub fn px<P: Into<Coord>>(coord: P) -> TextPos {
let coord = coord.into();
TextPos::Px(coord.x, coord.y)
}
}
pub trait CoordIntoTextPos {
fn textpos(self) -> TextPos;
}
impl CoordIntoTextPos for Coord {
fn textpos(self) -> TextPos {
TextPos::px(self)
}
}
pub trait NewTextPos<T> {
fn cr(xy: (T, T)) -> TextPos;
fn px(xy: (T, T)) -> TextPos;
}
macro_rules! impl_to_px {
($num_type: ty) => {
impl NewTextPos<$num_type> for TextPos {
fn cr((x, y): ($num_type, $num_type)) -> Self {
TextPos::ColRow(((x as isize).abs()) as usize, ((y as isize).abs()) as usize)
}
fn px((x, y): ($num_type, $num_type)) -> Self {
TextPos::Px(x as isize, y as isize)
}
}
};
}
impl_to_px!(isize);
impl_to_px!(i8);
impl_to_px!(i16);
impl_to_px!(i32);
impl_to_px!(i64);
impl_to_px!(i128);
impl_to_px!(usize);
impl_to_px!(u8);
impl_to_px!(u16);
impl_to_px!(u32);
impl_to_px!(u64);
impl_to_px!(u128);
impl_to_px!(f32);
impl_to_px!(f64);
#[cfg(test)]
mod test {
use crate::text::pos::{CoordIntoTextPos, TextPos};
use graphics_shapes::coord::Coord;
#[test]
fn coord_textpos() {
let coord = Coord::new(0, 0);
let test = coord.textpos();
assert_eq!(test, TextPos::Px(0, 0))
}
}