-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathObject4D.cpp
113 lines (102 loc) · 3.9 KB
/
Object4D.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
//
// Created by Jackson Hall on 4/27/2020.
//
#include "Object4D.h"
#include <utility>
/** ========== Constructors ========== */
Object4D::Object4D() :
Object4D(
std::vector<std::shared_ptr<point4d>>(),
std::vector<std::shared_ptr<edge4d>>()
){
}
Object4D::Object4D(const std::vector<point4d>& vertices,
const std::vector<edge4d>& edges){
// Put all items into new vector of smart pointers
std::vector<std::shared_ptr<point4d>> tempVertices;
tempVertices.reserve(vertices.size());
for (auto & vertex : vertices){
tempVertices.push_back(std::make_shared<point4d>(vertex));
}
this->vertices = tempVertices;
std::vector<std::shared_ptr<edge4d>> tempEdges;
tempEdges.reserve(edges.size());
for (auto & edge : edges){
tempEdges.push_back(std::make_shared<edge4d>(edge));
}
this->edges = tempEdges;
}
Object4D::Object4D(std::vector<std::shared_ptr<point4d>> vertices,
std::vector<std::shared_ptr<edge4d>> edges){
this->vertices = std::move(vertices);
this->edges = std::move(edges);
}
/** ========== Getters ========== */
const std::vector<std::shared_ptr<point4d>> &Object4D::getVertices() const {
return vertices;
}
const std::vector<std::shared_ptr<edge4d>> &Object4D::getEdges() const {
return edges;
}
/** ========== Other Methods ========== */
/**
* Takes the current set of vertices and extrudes them into the given direction,
* creating edges between the appropriate points. Given `direction` vector
* can be of size <= 4 with elements interpreted in XYZA order.
*/
/// TODO These methods segfault
//void Object4D::extrude(const std::vector<double> &direction) {
// if (direction.size() <= 4){
// // Pad empty dimensions in given vector with 0s
// std::vector<double> temp = direction;
// while (temp.size() < 4){
// temp.push_back(0.0);
// }
//
// // For every edge, extrude both points in the given direction
// // and add 3 new edges to this object:
// // 1. Between the 2 extruded points
// // 2. Between the first point and the extruded first point
// // 3. Between the second point and the extruded second point
// for (auto & edge : edges){
// point4d extrudedP1(*edge->p1);
// extrudedP1.move(direction);
// point4d extrudedP2(*edge->p2);
// extrudedP2.move(direction);
//
// // Add new points
// vertices.push_back(std::make_shared<point4d>(extrudedP1));
// vertices.push_back(std::make_shared<point4d>(extrudedP2));
//
// // Add new edges
// edges.push_back(std::make_shared<edge4d>(extrudedP1, extrudedP2));
// edges.push_back(std::make_shared<edge4d>(*edge->p1, extrudedP1));
// edges.push_back(std::make_shared<edge4d>(*edge->p2, extrudedP2));
// }
//
// } else {
// std::cout << "Warning: Invalid input to:"
// "\n\tvoid extrude(const std::vector<double>& direction)"
// "\n\t(Object4D.cpp)" << std::endl;
// }
//}
//void Object4D::extrude(const spatialVector &direction){
// extrude(direction.components);
//}
/**
* Draw this object on the screen by projecting them through the given
* camera(s).
*/
void Object4D::draw(const Camera3D& camera3d, const Camera4D& camera4d) const {
// Get drawable (x', y') coordinates for all vertices (x, y, z) in object
std::vector<edge2d> drawableEdges;
for (auto & edge : edges){
// First get the location of the 4d point cast to 3-space
edge3d tempEdge3d(
*camera4d.projectPoint(*edge->p1), *camera4d.projectPoint(*edge->p2)
);
// Draw a line on the screen between the vertices of the projected edge
edge2d(*camera3d.projectPoint(*tempEdge3d.p1),
*camera3d.projectPoint(*tempEdge3d.p2)).draw();
}
}