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
94
95
96
97
98
|
#ifndef ROOM_H_
#define ROOM_H_
#include "Polygon.h"
#include "SharedPtr.h"
#include "LevelObject.h"
#include "VertexProvider.h"
#include "EdgeProvider.h"
#include <string>
class Room : public LevelObject, private VertexProvider, private EdgeProvider {
private:
Polygon polygon;
std::string name;
float height;
std::vector<Edge> edges;
public:
Room() {height = 10;}
Room(std::string name) {this->name = name; height = 10;}
Room(const Room &room) : name(room.name), height(room.height) {
for(Polygon::const_iterator v = room.polygon.begin(); v != room.polygon.end(); v++)
addVertex(*v);
}
const Room& operator=(const Room &room);
std::string &getName() {return name;}
const std::string &getName() const {return name;}
void setName(const std::string &name) {this->name = name;}
float getHeight() const {return height;}
void setHeight(float height) {this->height = height;}
void addVertex(Vertex v);
const Polygon& getPolygon() const {return polygon;}
virtual bool hit(const Vertex &v) const {return polygon.contains(v);}
virtual int getPriority() const {return 0;}
virtual std::vector<SharedPtr<LevelObject> > getChildren();
virtual const char* getType() const {
return "Room";
}
virtual bool canMove() const {return true;}
virtual void move(float x, float y) {
Vertex m(x, y);
for(Polygon::iterator v = polygon.begin(); v != polygon.end(); v++)
*v += m;
}
virtual bool canRotate() const {return true;}
virtual void rotate(Vertex m, float a);
virtual const Vertex* getVertex(size_t id) const {
return &polygon[id];
}
virtual size_t getVertexCount() const {
return polygon.size();
}
virtual void moveVertex(size_t id, float x, float y) {
polygon[id] += Vertex(x, y);
}
virtual void rotateVertex(size_t id, Vertex m, float a) {
rotate(m, a);
}
virtual const Edge* getEdge(size_t id) const {
return &edges[id];
}
virtual size_t getEdgeCount() const {
return edges.size();
}
virtual void moveEdge(size_t id, float x, float y) {
moveVertex(id, x, y);
moveVertex((id+1)%polygon.size(), x, y);
}
virtual void rotateEdge(size_t id, Vertex m, float a) {
rotate(m, a);
}
};
#endif /*ROOM_H_*/
|