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
87
88
89
90
91
92
93
use types::Color;
use {types, triangulation, Graphics, DrawState};
use math::{Matrix2d, Scalar};
#[derive(Copy, Clone)]
pub struct Polygon {
pub color: Color,
}
impl Polygon {
pub fn new(color: Color) -> Polygon {
Polygon { color: color }
}
pub fn color(mut self, color: Color) -> Self {
self.color = color;
self
}
#[inline(always)]
pub fn draw<G>(&self,
polygon: types::Polygon,
draw_state: &DrawState,
transform: Matrix2d,
g: &mut G)
where G: Graphics
{
g.polygon(self, polygon, draw_state, transform);
}
pub fn draw_tri<G>(&self,
polygon: types::Polygon,
draw_state: &DrawState,
transform: Matrix2d,
g: &mut G)
where G: Graphics
{
g.tri_list(draw_state, &self.color, |f| {
triangulation::with_polygon_tri_list(transform, polygon, |vertices| f(vertices))
});
}
#[inline(always)]
pub fn draw_tween_lerp<G>(&self,
polygons: types::Polygons,
tween_factor: Scalar,
draw_state: &DrawState,
transform: Matrix2d,
g: &mut G)
where G: Graphics
{
g.polygon_tween_lerp(self, polygons, tween_factor, draw_state, transform);
}
pub fn draw_tween_lerp_tri<G>(&self,
polygons: types::Polygons,
tween_factor: Scalar,
draw_state: &DrawState,
transform: Matrix2d,
g: &mut G)
where G: Graphics
{
if self.color[3] == 0.0 {
return;
}
g.tri_list(draw_state, &self.color, |f| {
triangulation::with_lerp_polygons_tri_list(transform,
polygons,
tween_factor,
|vertices| f(vertices))
});
}
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn test_polygon() {
let _polygon = Polygon::new([1.0; 4]).color([0.0; 4]);
}
}