-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathreadEllipse.cpp
73 lines (67 loc) · 1.18 KB
/
readEllipse.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
#include "readEllipse.h"
void readEllipse(ifstream& file, vector<Shape*>& container) {
int code;
string id;
int layer = 0;
string subclass = "";
float thickness = 0.0;
float m_x = 0.0, m_y = 0.0, m_z = 0.0;
float end_x = 0.0, end_y = 0.0, end_z = 0.0;
float ratio = 0.0;
float begin = 0.0, end = 0.0;
float ext_x = 0.0, ext_y = 0.0, ext_z = 1.0;
do {
file >> code;
switch (code) {
case 5:
file >> id;
break;
case 8:
file >> layer;
break;
case 100:
file >> subclass;
break;
case 39:
file >> thickness;
break;
case 10:
file >> m_x;
break;
case 11:
file >> end_x;
break;
case 20:
file >> m_y;
break;
case 21:
file >> end_y;
break;
case 30:
file >> m_z;
break;
case 31:
file >> end_z;
break;
case 40:
file >> ratio;
break;
case 41:
file >> begin;
break;
case 42:
file >> end;
break;
case 210:
file >> ext_x;
break;
case 220:
file >> ext_y;
break;
case 230:
file >> ext_z;
}
} while (code != 0);
container.push_back(new Ellipse(id, layer, subclass, thickness, m_x, m_y, m_z, end_x, end_y, end_z, ratio, begin, end, ext_x, ext_y, ext_z));
file.seekg(-1, ios::cur);
}