-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpolygon.cpp
78 lines (69 loc) · 1.99 KB
/
polygon.cpp
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
#include "polygon.h"
Polygon::Polygon() {
type = POLYGON;
drawMethod = 0;
//0 for DDA, 1 for Bresenham
}
Polygon::Polygon(QVector<QPoint> v) {
type = POLYGON;
drawMethod = 0;
for(int i = 0; i < v.size(); i++)
points.push_back(v[i]);
set_LTRB();
}
void Polygon::set_LTRB() {
int minY, maxY, minX, maxX;
minY = points[0].y();
maxY = points[0].y();
minX = points[0].x();
maxX = points[0].x();
for(int i = 0; i < points.size(); i++) {
if(points[i].x() < minX)
minX = points[i].x();
if(points[i].x() > maxX)
maxX = points[i].x();
if(points[i].y() < minY)
minY = points[i].y();
if(points[i].y() > maxY)
maxY = points[i].y();
}
LTPoint.setX(minX);
LTPoint.setY(minY);
RBPoint.setX(maxX);
RBPoint.setY(maxY);
transformCenter.setX((minX + maxX) / 2);
transformCenter.setY((minY + maxY) / 2);
}
void Polygon::setDrawMethod(int m) {
drawMethod = m;
}
void Polygon::draw(QPen &pen, QPixmap &pix) {
for(int i = 0; i < points.size() - 1; i++) {
Line *newLine = new Line(points[i], points[i + 1]);
newLine->setDrawMethod(drawMethod);
newLine->draw(pen, pix);
delete newLine;
}
Line *newLine = new Line(points[points.size() - 1], points[0]);
newLine->setDrawMethod(drawMethod);
newLine->draw(pen, pix);
delete newLine;
}
Polygon::~Polygon() {
points.clear();
}
void Polygon::translate(int dx, int dy) {
for(int i = 0; i < points.size(); i++)
points[i] = translate_Point(dx, dy, points[i]);
set_LTRB();
}
void Polygon::rotate(int x, int y, int r) {
for(int i = 0; i < points.size(); i++)
points[i] = rotate_Point(x, y, r, points[i]);
set_LTRB();
}
void Polygon::scale(int x, int y, float s) {
for(int i = 0; i < points.size(); i++)
points[i] = scale_Point(x, y, s, points[i]);
set_LTRB();
}