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
99
100
101
102
|
#include "cWiremesh.h"
cWiremesh::cWiremesh()
{
position = {0,0,0};
}
cWiremesh::~cWiremesh()
{
}
void cWiremesh::addVector(sCoord3d _origin, sCoord3d _vector, char _char, WORD _color)
{
vectors.push_back(sVector{_origin, _vector, _char, _color});
}
void cWiremesh::rotate(sCoord3d _val)
{
angle = angle + _val;
}
void cWiremesh::reset()
{
vectors.clear();
}
void cWiremesh::write(cRender *_render)
{
if(!_render)
return;
sPos porigin = _render->getSize();
sCoord3d origin = {porigin.x / 2, porigin.y / 2, 0};
for(long unsigned int i = 0; i < vectors.size(); i++)
{
_render->drawLine(vectors[i].c,
translate(vectors[i].origin + position, origin),
translate(vectors[i].origin + vectors[i].direction + position, origin),
true, vectors[i].color);
}
}
sPos cWiremesh::translate(sCoord3d _coord, sCoord3d _origin)
{
sPos ret;
ret.x = (int)((float)_coord.x - ((float)_coord.z / (float)_DEPTH * (float)(_coord.x - _origin.x)));
ret.y = (int)((float)_coord.y - ((float)_coord.z / (float)_DEPTH * (float)(_coord.y - _origin.y)));
return ret;
}
sCoord3d cWiremesh::getPosition()
{
return position;
}
void cWiremesh::setPosition(int _x, int _y, int _z)
{
position = {_x, _y, _z};
}
void cWiremesh::setPosition(sCoord3d _pos)
{
position = _pos;
}
void cWiremesh::scale(float _scalar)
{
for(unsigned long int i = 0; i < vectors.size(); i++)
{
vectors[i].origin.x = (int)((float)vectors[i].origin.x * _scalar);
vectors[i].origin.y = (int)((float)vectors[i].origin.y * _scalar);
vectors[i].origin.z = (int)((float)vectors[i].origin.z * _scalar);
vectors[i].direction.x = (int)((float)vectors[i].direction.x * _scalar);
vectors[i].direction.y = (int)((float)vectors[i].direction.y * _scalar);
vectors[i].direction.z = (int)((float)vectors[i].direction.z * _scalar);
}
}
sCoord3d applyRotation(sCoord3d _vector, sCoord3d _angle)
{
sCoord3d ret = _vector;
if(_angle.x)
{
}
if(_angle.y)
{
}
if(_angle.z)
{
}
return ret;
}
|