Commit | Line | Data |
---|---|---|
e68f847b PG |
1 | /* |
2 | * Copyright (C) 2008 Patrik Gornicz, Gornicz_P (at) hotmail (dot) com. | |
3 | * | |
4 | * This program is free software: you can redistribute it and/or modify | |
5 | * it under the terms of the GNU General Public License as published by | |
6 | * the Free Software Foundation, either version 3 of the License, or | |
7 | * (at your option) any later version. | |
8 | * | |
9 | * This program is distributed in the hope that it will be useful, | |
10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 | * GNU General Public License for more details. | |
13 | * | |
14 | * You should have received a copy of the GNU General Public License | |
15 | * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
16 | */ | |
17 | ||
ad9f1fb6 | 18 | #include "Polygon.h" |
617dcc71 | 19 | |
5e0713e5 PG |
20 | #include <bear/debug.h> |
21 | #include <bear/Vector2.h> | |
22 | using namespace bear; | |
ad9f1fb6 | 23 | |
4a76d2e2 PG |
24 | #include "graphics/graphics.h" |
25 | ||
617dcc71 PG |
26 | |
27 | /// ***** Constructors/Destructors ***** | |
28 | ||
30a93c39 PG |
29 | Polygon::Polygon(const vector<Vector2>& points, const float* color) |
30 | : PhysicsEntity(Vector2(0,0)), points(points), color(color) | |
ad9f1fb6 | 31 | { |
4a76d2e2 PG |
32 | DASSERT(0 < points.size()); |
33 | ||
617dcc71 | 34 | createBindingBox(); |
aa2791cf | 35 | centerPosition(); |
ad9f1fb6 PG |
36 | } |
37 | Polygon::~Polygon() | |
38 | { | |
39 | ||
40 | } | |
41 | ||
617dcc71 PG |
42 | /// ***** Public Class Methods ***** |
43 | ||
ad9f1fb6 PG |
44 | void Polygon::draw() const |
45 | { | |
30a93c39 | 46 | graphics::drawPolygon(points, color); |
ad9f1fb6 PG |
47 | } |
48 | ||
49 | /// ***** Private Class Methods ***** | |
617dcc71 | 50 | void Polygon::createBindingBox() |
ad9f1fb6 | 51 | { |
aa2791cf PG |
52 | DASSERT(0 < points.size()); |
53 | ||
54 | maxP = points.at(0); | |
55 | minP = points.at(0); | |
56 | ||
57 | for(unsigned int i=1; i<points.size(); i++) | |
58 | { | |
9d6dea5f PG |
59 | if(points[i].m_fX < minP.m_fX) minP.m_fX = points[i].m_fX; |
60 | else if(points[i].m_fX > maxP.m_fX) maxP.m_fX = points[i].m_fX; | |
aa2791cf | 61 | |
9d6dea5f PG |
62 | if(points[i].m_fY < minP.m_fY) minP.m_fY = points[i].m_fY; |
63 | else if(points[i].m_fY > maxP.m_fY) maxP.m_fY = points[i].m_fY; | |
aa2791cf PG |
64 | } |
65 | } | |
66 | ||
67 | void Polygon::centerPosition() | |
68 | { | |
ad9f1fb6 PG |
69 | // TODO |
70 | } |