added usages of trim to lists
[physics.git] / src / Entities / Polygon.cpp
CommitLineData
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>
22using namespace bear;
ad9f1fb6 23
4a76d2e2
PG
24#include "graphics/graphics.h"
25
617dcc71
PG
26
27/// ***** Constructors/Destructors *****
28
30a93c39
PG
29Polygon::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}
37Polygon::~Polygon()
38{
39
40}
41
617dcc71
PG
42/// ***** Public Class Methods *****
43
ad9f1fb6
PG
44void Polygon::draw() const
45{
30a93c39 46 graphics::drawPolygon(points, color);
ad9f1fb6
PG
47}
48
49/// ***** Private Class Methods *****
617dcc71 50void 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
67void Polygon::centerPosition()
68{
ad9f1fb6
PG
69 // TODO
70}