Fri, 27 Aug 2021 00:55:32 +0300
Show concave polygons as red while drawing
19 | 1 | /* |
2 | * LDForge: LDraw parts authoring CAD | |
3 | * Copyright (C) 2013 - 2018 Teemu Piippo | |
4 | * | |
5 | * This program is free software: you can redistribute it and/or modify | |
6 | * it under the terms of the GNU General Public License as published by | |
7 | * the Free Software Foundation, either version 3 of the License, or | |
8 | * (at your option) any later version. | |
9 | * | |
10 | * This program is distributed in the hope that it will be useful, | |
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
13 | * GNU General Public License for more details. | |
14 | * | |
15 | * You should have received a copy of the GNU General Public License | |
16 | * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
17 | */ | |
18 | ||
19 | #pragma once | |
100 | 20 | #include <QWidget> |
19 | 21 | #include <QColor> |
53 | 22 | #include <QOpenGLBuffer> |
19 | 23 | #include <QOpenGLFunctions> |
53 | 24 | #include <QOpenGLShader> |
25 | #include <QOpenGLShaderProgram> | |
26 | #include <QOpenGLVertexArrayObject> | |
27 | #include <glm/gtc/type_ptr.hpp> | |
19 | 28 | #include "basics.h" |
29 | #include "colors.h" | |
30 | ||
31 | namespace gl | |
32 | { | |
33 | struct Polygon; | |
53 | 34 | class ShaderProgram; |
35 | ||
36 | void buildShaders( | |
37 | QOpenGLShaderProgram* shaderProgram, | |
38 | const char* vertexShaderSource, | |
39 | const char* fragmentShaderSource); | |
40 | void checkForGLErrors(QWidget* parent); | |
55 | 41 | inline glm::vec3 colorToVector3(const QColor& color) |
42 | { | |
43 | return {toFloat(color.redF()), toFloat(color.greenF()), toFloat(color.blueF())}; | |
44 | } | |
45 | inline glm::vec4 colorToVector4(const QColor& color) | |
46 | { | |
47 | return {gl::colorToVector3(color), toFloat(color.alphaF())}; | |
48 | } | |
19 | 49 | } |
50 | ||
53 | 51 | class gl::ShaderProgram : public QOpenGLShaderProgram |
52 | { | |
53 | public: | |
54 | using QOpenGLShaderProgram::QOpenGLShaderProgram; | |
55 | // for some reason I cannot overload setUniformValue properly with this template thing | |
56 | template<typename Float, glm::qualifier Prec> | |
57 | void setUniformMatrix(const char* uniformName, const glm::mat<4, 4, Float, Prec>& value) | |
58 | { | |
59 | const float (*array)[4][4] = reinterpret_cast<const float(*)[4][4]>(glm::value_ptr(value)); | |
60 | this->setUniformValue(uniformName, *array); | |
61 | } | |
55 | 62 | template<typename Float, glm::qualifier Prec> |
63 | void setUniformVector(const char* uniformName, const glm::vec<4, Float, Prec>& value) | |
53 | 64 | { |
55 | 65 | this->setUniformValue(uniformName, value.x, value.y, value.z, value.w); |
53 | 66 | } |
67 | }; | |
68 | ||
19 | 69 | struct gl::Polygon |
70 | { | |
71 | enum Type : qint8 | |
72 | { | |
73 | EdgeLine, | |
74 | Triangle, | |
75 | Quadrilateral, | |
76 | ConditionalEdge | |
80 | 77 | } type; |
33
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
78 | glm::vec3 vertices[4]; |
35
98906a94732f
renamed the linetypes namespace to ldraw namespace and added more structures to it
Teemu Piippo <teemu@hecknology.net>
parents:
34
diff
changeset
|
79 | ldraw::Color color; |
73
97df974b5ed5
ldraw::Id is now templated for extra type safety
Teemu Piippo <teemu@hecknology.net>
parents:
55
diff
changeset
|
80 | ldraw::id_t id; |
19 | 81 | |
82 | /** | |
83 | * @return amount of vertices used for geometry | |
84 | */ | |
22
6da867fa5429
commit work on GL rendering
Teemu Piippo <teemu@hecknology.net>
parents:
21
diff
changeset
|
85 | inline unsigned int numPolygonVertices() const |
19 | 86 | { |
87 | if (type == Type::ConditionalEdge) | |
88 | return 2; | |
89 | else | |
90 | return numVertices(); | |
91 | } | |
92 | ||
93 | /** | |
94 | * @return amount of vertices | |
95 | */ | |
22
6da867fa5429
commit work on GL rendering
Teemu Piippo <teemu@hecknology.net>
parents:
21
diff
changeset
|
96 | inline unsigned int numVertices() const |
19 | 97 | { |
98 | switch (type) | |
99 | { | |
100 | case Type::EdgeLine: | |
101 | return 2; | |
102 | case Type::Triangle: | |
103 | return 3; | |
104 | case Type::ConditionalEdge: | |
105 | case Type::Quadrilateral: | |
106 | return 4; | |
107 | } | |
22
6da867fa5429
commit work on GL rendering
Teemu Piippo <teemu@hecknology.net>
parents:
21
diff
changeset
|
108 | return 0; |
19 | 109 | } |
110 | }; | |
111 | ||
112 | Q_DECLARE_METATYPE(gl::Polygon) | |
113 | ||
114 | namespace gl | |
115 | { | |
80 | 116 | constexpr Polygon::Type POLYGON_TYPES[] = |
117 | { | |
118 | Polygon::Type::EdgeLine, | |
119 | Polygon::Type::Triangle, | |
120 | Polygon::Type::Quadrilateral, | |
121 | Polygon::Type::ConditionalEdge | |
122 | }; | |
123 | ||
124 | constexpr int NUM_POLYGON_TYPES = countof(POLYGON_TYPES); | |
125 | ||
73
97df974b5ed5
ldraw::Id is now templated for extra type safety
Teemu Piippo <teemu@hecknology.net>
parents:
55
diff
changeset
|
126 | inline Polygon edgeLine(const glm::vec3& v_1, const glm::vec3& v_2, ldraw::Color color, ldraw::id_t id) |
19 | 127 | { |
21 | 128 | return {Polygon::EdgeLine, {v_1, v_2}, color, id}; |
19 | 129 | } |
130 | ||
21 | 131 | inline Polygon triangle( |
33
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
132 | const glm::vec3& v_1, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
133 | const glm::vec3& v_2, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
134 | const glm::vec3& v_3, |
35
98906a94732f
renamed the linetypes namespace to ldraw namespace and added more structures to it
Teemu Piippo <teemu@hecknology.net>
parents:
34
diff
changeset
|
135 | ldraw::Color color, |
73
97df974b5ed5
ldraw::Id is now templated for extra type safety
Teemu Piippo <teemu@hecknology.net>
parents:
55
diff
changeset
|
136 | ldraw::id_t id) |
19 | 137 | { |
21 | 138 | return {Polygon::Triangle, {v_1, v_2, v_3}, color, id}; |
19 | 139 | } |
140 | ||
141 | inline Polygon quadrilateral( | |
33
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
142 | const glm::vec3& v_1, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
143 | const glm::vec3& v_2, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
144 | const glm::vec3& v_3, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
145 | const glm::vec3& v_4, |
35
98906a94732f
renamed the linetypes namespace to ldraw namespace and added more structures to it
Teemu Piippo <teemu@hecknology.net>
parents:
34
diff
changeset
|
146 | ldraw::Color color, |
73
97df974b5ed5
ldraw::Id is now templated for extra type safety
Teemu Piippo <teemu@hecknology.net>
parents:
55
diff
changeset
|
147 | ldraw::id_t id) |
19 | 148 | { |
21 | 149 | return {Polygon::Quadrilateral, {v_1, v_2, v_3, v_4}, color, id}; |
19 | 150 | } |
151 | ||
152 | inline Polygon conditionalEdge( | |
33
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
153 | const glm::vec3& v_1, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
154 | const glm::vec3& v_2, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
155 | const glm::vec3& control_1, |
4c41bfe2ec6e
replaced matrix and vertex classes with glm
Teemu Piippo <teemu@hecknology.net>
parents:
26
diff
changeset
|
156 | const glm::vec3& control_2, |
35
98906a94732f
renamed the linetypes namespace to ldraw namespace and added more structures to it
Teemu Piippo <teemu@hecknology.net>
parents:
34
diff
changeset
|
157 | ldraw::Color color, |
73
97df974b5ed5
ldraw::Id is now templated for extra type safety
Teemu Piippo <teemu@hecknology.net>
parents:
55
diff
changeset
|
158 | ldraw::id_t id) |
19 | 159 | { |
21 | 160 | return {Polygon::ConditionalEdge, {v_1, v_2, control_1, control_2}, color, id}; |
19 | 161 | } |
162 | ||
163 | // Vbo names | |
26 | 164 | enum class ArrayClass : std::uint8_t |
19 | 165 | { |
166 | Lines, | |
167 | Triangles, | |
168 | Quads, | |
169 | ConditionalLines | |
170 | }; | |
35
98906a94732f
renamed the linetypes namespace to ldraw namespace and added more structures to it
Teemu Piippo <teemu@hecknology.net>
parents:
34
diff
changeset
|
171 | |
115 | 172 | constexpr ArrayClass ARRAY_CLASSES[] = { |
173 | ArrayClass::Lines, | |
174 | ArrayClass::Triangles, | |
175 | ArrayClass::Quads, | |
176 | ArrayClass::ConditionalLines, | |
177 | }; | |
26 | 178 | constexpr int NUM_ARRAY_CLASSES = countof(ARRAY_CLASSES); |
19 | 179 | |
91 | 180 | // Different ways to render the scene |
19 | 181 | enum class RenderStyle |
182 | { | |
91 | 183 | // Normal rendering style |
19 | 184 | Normal, |
91 | 185 | // Render all polygons as lines |
19 | 186 | Wireframe, |
91 | 187 | // Use green colour for front faces and red colour for back faces |
19 | 188 | BfcRedGreen, |
91 | 189 | // Use a different colour for each object |
46 | 190 | RandomColors, |
91 | 191 | // Render so that the colour of an object has an one to one correspondence with its id |
119 | 192 | PickScene, |
193 | // Render a scene where vertices can be picked | |
194 | VertexPickScene, | |
19 | 195 | }; |
91 | 196 | |
197 | // Different ways to render fragments. | |
37 | 198 | // These are also defined in shaders |
199 | enum class FragmentStyle | |
200 | { | |
91 | 201 | // Use normal colours |
37 | 202 | Normal = 0, |
91 | 203 | // Use a distinctive green colour for BFC red/green view |
37 | 204 | BfcGreen = 1, |
91 | 205 | // Use a distinctive red colour for BFC red/green view |
37 | 206 | BfcRed = 2, |
91 | 207 | // Use a colour based on the object to distinguish objects |
37 | 208 | RandomColors = 3, |
91 | 209 | // Use a colour that codes the object's id |
46 | 210 | Id = 4, |
119 | 211 | // Render everything black |
212 | Black = 5, | |
37 | 213 | }; |
39
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
214 | |
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
215 | // User options for rendering |
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
216 | struct RenderPreferences |
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
217 | { |
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
218 | gl::RenderStyle style = gl::RenderStyle::Normal; |
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
219 | QColor mainColor{255, 255, 64}; |
40
30cb5e836736
added configurable background color
Teemu Piippo <teemu@hecknology.net>
parents:
39
diff
changeset
|
220 | QColor backgroundColor{48, 48, 48}; |
48
3c10f0e2fbe0
added selection highlighting
Teemu Piippo <teemu@hecknology.net>
parents:
46
diff
changeset
|
221 | QColor selectedColor{32, 32, 255}; |
44
c6114b3af3a6
added configurable line thickness
Teemu Piippo <teemu@hecknology.net>
parents:
41
diff
changeset
|
222 | GLfloat lineThickness = 2.0f; |
45
272c84c7c87e
added configurable line anti-aliasing
Teemu Piippo <teemu@hecknology.net>
parents:
44
diff
changeset
|
223 | bool lineAntiAliasing = true; |
39
caac957e9834
Main color is now configurable
Teemu Piippo <teemu@hecknology.net>
parents:
37
diff
changeset
|
224 | }; |
19 | 225 | } |