Directory: | ./ |
---|---|
File: | src/node.cpp |
Date: | 2024-12-20 15:53:58 |
Exec | Total | Coverage | |
---|---|---|---|
Lines: | 242 | 457 | 53.0% |
Branches: | 223 | 650 | 34.3% |
Line | Branch | Exec | Source |
---|---|---|---|
1 | // | ||
2 | // node.cpp | ||
3 | // gepetto-viewer | ||
4 | // | ||
5 | // Created by Justin Carpentier, Mathieu Geisert in November 2014. | ||
6 | // Copyright (c) 2014 LAAS-CNRS. All rights reserved. | ||
7 | // | ||
8 | |||
9 | #include <gepetto/viewer/node-visitor.h> | ||
10 | #include <gepetto/viewer/node.h> | ||
11 | #include <gepetto/viewer/window-manager.h> | ||
12 | |||
13 | #include <climits> | ||
14 | #include <osg/LineWidth> | ||
15 | #include <osg/Material> | ||
16 | #include <osgFX/Outline> | ||
17 | #include <osgFX/Scribe> | ||
18 | |||
19 | #include "log.hh" | ||
20 | |||
21 | namespace gepetto { | ||
22 | namespace viewer { | ||
23 | namespace { | ||
24 | ✗ | const osg::StateSetRefPtr& getVisibleStateSet(const LightingMode& mode) { | |
25 | ✗ | static osg::StateSetRefPtr ssOn, ssOff; | |
26 | ✗ | switch (mode) { | |
27 | ✗ | case LIGHT_INFLUENCE_ON: | |
28 | if (false && !ssOn) { // Disable because this is the default. | ||
29 | ssOn = osg::StateSetRefPtr(new osg::StateSet()); | ||
30 | ssOn->setRenderBinToInherit(); | ||
31 | ssOn->setMode(GL_DEPTH_TEST, ::osg::StateAttribute::ON | | ||
32 | ::osg::StateAttribute::PROTECTED); | ||
33 | ssOn->setMode(GL_CULL_FACE, ::osg::StateAttribute::OFF | | ||
34 | ::osg::StateAttribute::PROTECTED); | ||
35 | ssOn->setMode(GL_LIGHTING, ::osg::StateAttribute::ON | | ||
36 | ::osg::StateAttribute::PROTECTED); | ||
37 | } | ||
38 | ✗ | return ssOn; | |
39 | ✗ | case LIGHT_INFLUENCE_OFF: | |
40 | ✗ | if (!ssOff) { | |
41 | ✗ | ssOff = osg::StateSetRefPtr(new osg::StateSet()); | |
42 | ✗ | ssOff->setRenderBinToInherit(); | |
43 | ✗ | ssOff->setMode(GL_DEPTH_TEST, ::osg::StateAttribute::ON | | |
44 | ::osg::StateAttribute::PROTECTED); | ||
45 | ✗ | ssOff->setMode(GL_CULL_FACE, ::osg::StateAttribute::OFF | | |
46 | ::osg::StateAttribute::PROTECTED); | ||
47 | ✗ | ssOff->setMode(GL_LIGHTING, ::osg::StateAttribute::OFF | | |
48 | ::osg::StateAttribute::PROTECTED); | ||
49 | } | ||
50 | ✗ | return ssOff; | |
51 | ✗ | default: | |
52 | ✗ | ASSERT(false, "LightingMode is not well defined"); | |
53 | break; | ||
54 | }; | ||
55 | } | ||
56 | |||
57 | ✗ | const osg::StateSetRefPtr& getAlwaysOnTopStateSet(const LightingMode& mode) { | |
58 | ✗ | static osg::StateSetRefPtr ssOn, ssOff; | |
59 | ✗ | switch (mode) { | |
60 | ✗ | case LIGHT_INFLUENCE_ON: | |
61 | ✗ | if (!ssOn) { // Disable because this is the default. | |
62 | ✗ | ssOn = osg::StateSetRefPtr(new osg::StateSet()); | |
63 | ✗ | ssOn->setRenderBinDetails(INT_MAX, "DepthSortedBin"); | |
64 | ✗ | ssOn->setMode(GL_DEPTH_TEST, ::osg::StateAttribute::OFF | | |
65 | ::osg::StateAttribute::PROTECTED); | ||
66 | ✗ | ssOn->setMode(GL_CULL_FACE, ::osg::StateAttribute::ON | | |
67 | ::osg::StateAttribute::PROTECTED); | ||
68 | ✗ | ssOn->setMode(GL_LIGHTING, ::osg::StateAttribute::ON | | |
69 | ::osg::StateAttribute::PROTECTED); | ||
70 | } | ||
71 | ✗ | return ssOn; | |
72 | ✗ | case LIGHT_INFLUENCE_OFF: | |
73 | ✗ | if (!ssOff) { | |
74 | ✗ | ssOff = osg::StateSetRefPtr(new osg::StateSet()); | |
75 | ✗ | ssOff->setRenderBinDetails(INT_MAX, "DepthSortedBin"); | |
76 | ✗ | ssOff->setMode(GL_DEPTH_TEST, ::osg::StateAttribute::OFF | | |
77 | ::osg::StateAttribute::PROTECTED); | ||
78 | ✗ | ssOff->setMode(GL_CULL_FACE, ::osg::StateAttribute::ON | | |
79 | ::osg::StateAttribute::PROTECTED); | ||
80 | ✗ | ssOff->setMode(GL_LIGHTING, ::osg::StateAttribute::OFF | | |
81 | ::osg::StateAttribute::PROTECTED); | ||
82 | } | ||
83 | ✗ | return ssOff; | |
84 | ✗ | default: | |
85 | ✗ | ASSERT(false, "LightingMode is not well defined"); | |
86 | break; | ||
87 | }; | ||
88 | } | ||
89 | |||
90 | 1 | const osg::StateSetRefPtr& getWireframeStateSet() { | |
91 |
2/4✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | static osg::StateSetRefPtr ss; |
92 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | if (!ss) { |
93 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | ss = osg::StateSetRefPtr(new osg::StateSet()); |
94 | |||
95 | /* Allowing wireframe mode */ | ||
96 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | osg::PolygonModeRefPtr polygon_mode_ptr = new ::osg::PolygonMode; |
97 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | polygon_mode_ptr->setMode(::osg::PolygonMode::FRONT_AND_BACK, |
98 | ::osg::PolygonMode::LINE); | ||
99 | 1 | polygon_mode_ptr->setDataVariance(osg::Object::STATIC); | |
100 | |||
101 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ::osg::MaterialRefPtr material_wireframe_ptr = new osg::Material; |
102 | 1 | material_wireframe_ptr->setColorMode(osg::Material::DIFFUSE); | |
103 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_wireframe_ptr->setDiffuse(osg::Material::FRONT_AND_BACK, |
104 | 1 | osgVector4(1., 1., 1., 1.)); | |
105 | 1 | material_wireframe_ptr->setDataVariance(osg::Object::STATIC); | |
106 | |||
107 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | ss->setMode( |
108 | GL_BLEND, | ||
109 | ::osg::StateAttribute::OFF | | ||
110 | ::osg::StateAttribute::PROTECTED); // PROTECTED attribut allows | ||
111 | // wireframe node to not be | ||
112 | // influenced by alpha | ||
113 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | ss->setAttributeAndModes( |
114 | polygon_mode_ptr, | ||
115 | ::osg::StateAttribute::PROTECTED | ::osg::StateAttribute::ON); | ||
116 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | ss->setAttributeAndModes( |
117 | material_wireframe_ptr, | ||
118 | ::osg::StateAttribute::ON | ::osg::StateAttribute::PROTECTED); | ||
119 | 1 | } | |
120 | 1 | return ss; | |
121 | } | ||
122 | |||
123 | template <unsigned int state> | ||
124 | 12 | const osg::StateSetRefPtr& getHighlightStateSet() { | |
125 |
2/4✓ Branch 0 taken 6 times.
✗ Branch 1 not taken.
✓ Branch 3 taken 6 times.
✗ Branch 4 not taken.
|
12 | static osg::StateSetRefPtr ss; |
126 | if (state == 0) return ss; | ||
127 |
1/2✓ Branch 1 taken 6 times.
✗ Branch 2 not taken.
|
12 | if (!ss) { |
128 |
3/6✓ Branch 1 taken 6 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 6 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 6 times.
✗ Branch 9 not taken.
|
12 | ss = osg::StateSetRefPtr(new osg::StateSet()); |
129 |
2/4✓ Branch 1 taken 6 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 6 times.
✗ Branch 5 not taken.
|
12 | ::osg::MaterialRefPtr material_switch_ptr = new osg::Material; |
130 | 12 | int glModeValue = ::osg::StateAttribute::INHERIT; | |
131 | /// Some color codes are taken from | ||
132 | /// http://devernay.free.fr/cours/opengl/materials.html | ||
133 | switch (state) { | ||
134 | case 1: /// collision | ||
135 | 2 | glModeValue = | |
136 | ::osg::StateAttribute::ON | ::osg::StateAttribute::OVERRIDE; | ||
137 | 2 | material_switch_ptr->setColorMode(osg::Material::AMBIENT); | |
138 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setDiffuse(osg::Material::FRONT_AND_BACK, |
139 | 2 | osgVector4(1.0f, 0.f, 0.f, 1.f)); | |
140 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_switch_ptr->setTransparency(osg::Material::FRONT_AND_BACK, |
141 | 0.5f); | ||
142 | 2 | break; | |
143 | case 2: /// selection | ||
144 | 2 | glModeValue = ::osg::StateAttribute::ON | | |
145 | ::osg::StateAttribute::OVERRIDE | | ||
146 | ::osg::StateAttribute::PROTECTED; | ||
147 | /// Blue | ||
148 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setAmbient(osg::Material::FRONT_AND_BACK, |
149 | 2 | osgVector4(0.f, 0.f, 0.f, 1.f)); | |
150 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setDiffuse(osg::Material::FRONT_AND_BACK, |
151 | 2 | osgVector4(0.f, 0.f, 1.f, 1.f)); | |
152 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setSpecular(osg::Material::FRONT_AND_BACK, |
153 | 2 | osgVector4(0.6f, 0.6f, 0.7f, 1.f)); | |
154 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_switch_ptr->setShininess(osg::Material::FRONT_AND_BACK, 128.f); |
155 | 2 | break; | |
156 | case 3: /// selection | ||
157 | 2 | glModeValue = ::osg::StateAttribute::ON | | |
158 | ::osg::StateAttribute::OVERRIDE | | ||
159 | ::osg::StateAttribute::PROTECTED; | ||
160 | /// Red | ||
161 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setAmbient(osg::Material::FRONT_AND_BACK, |
162 | 2 | osgVector4(0.f, 0.f, 0.f, 1.f)); | |
163 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setDiffuse(osg::Material::FRONT_AND_BACK, |
164 | 2 | osgVector4(1.0f, 0.f, 0.f, 1.f)); | |
165 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setSpecular(osg::Material::FRONT_AND_BACK, |
166 | 2 | osgVector4(0.7f, 0.6f, 0.6f, 1.f)); | |
167 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_switch_ptr->setShininess(osg::Material::FRONT_AND_BACK, 96.f); |
168 | 2 | break; | |
169 | case 4: /// selection | ||
170 | 2 | glModeValue = ::osg::StateAttribute::ON | | |
171 | ::osg::StateAttribute::OVERRIDE | | ||
172 | ::osg::StateAttribute::PROTECTED; | ||
173 | /// Red plastic | ||
174 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setAmbient(osg::Material::FRONT_AND_BACK, |
175 | 2 | osgVector4(0.f, 0.f, 0.f, 1.f)); | |
176 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setDiffuse(osg::Material::FRONT_AND_BACK, |
177 | 2 | osgVector4(0.5f, 0.f, 0.f, 1.f)); | |
178 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setSpecular(osg::Material::FRONT_AND_BACK, |
179 | 2 | osgVector4(0.7f, 0.6f, 0.6f, 1.f)); | |
180 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_switch_ptr->setShininess(osg::Material::FRONT_AND_BACK, 32.f); |
181 | 2 | break; | |
182 | case 5: /// selection | ||
183 | 2 | glModeValue = ::osg::StateAttribute::ON | | |
184 | ::osg::StateAttribute::OVERRIDE | | ||
185 | ::osg::StateAttribute::PROTECTED; | ||
186 | /// Bronze | ||
187 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setAmbient( |
188 | osg::Material::FRONT_AND_BACK, | ||
189 | 2 | osgVector4(0.2125f, 0.1275f, 0.054f, 1.f)); | |
190 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setDiffuse( |
191 | osg::Material::FRONT_AND_BACK, | ||
192 | 2 | osgVector4(0.714f, 0.4284f, 0.18144f, 1.f)); | |
193 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setSpecular( |
194 | osg::Material::FRONT_AND_BACK, | ||
195 | 2 | osgVector4(0.393548f, 0.271906f, 0.166721f, 1.f)); | |
196 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_switch_ptr->setShininess(osg::Material::FRONT_AND_BACK, 26.f); |
197 | 2 | break; | |
198 | case 6: /// selection | ||
199 | 2 | glModeValue = ::osg::StateAttribute::ON | | |
200 | ::osg::StateAttribute::OVERRIDE | | ||
201 | ::osg::StateAttribute::PROTECTED; | ||
202 | /// Red rubber | ||
203 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setAmbient(osg::Material::FRONT_AND_BACK, |
204 | 2 | osgVector4(0.05f, 0.f, 0.f, 1.f)); | |
205 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setDiffuse(osg::Material::FRONT_AND_BACK, |
206 | 2 | osgVector4(0.5f, 0.5f, 0.4f, 1.f)); | |
207 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
4 | material_switch_ptr->setSpecular(osg::Material::FRONT_AND_BACK, |
208 | 2 | osgVector4(0.7f, 0.04f, 0.04f, 1.f)); | |
209 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
2 | material_switch_ptr->setShininess(osg::Material::FRONT_AND_BACK, 10.f); |
210 | 2 | break; | |
211 | default: | ||
212 | ASSERT(false, "HighlightState is not well defined"); | ||
213 | break; | ||
214 | } | ||
215 | 12 | material_switch_ptr->setDataVariance(osg::Object::STATIC); | |
216 |
1/2✓ Branch 2 taken 6 times.
✗ Branch 3 not taken.
|
12 | ss->setAttributeAndModes(material_switch_ptr, glModeValue); |
217 | 12 | } | |
218 | 12 | return ss; | |
219 | } | ||
220 | |||
221 | ✗ | int getNodeVisibilityMode(Node* node) { return node->getVisibilityMode(); } | |
222 | ✗ | void setNodeVisibilityMode(Node* node, const int& v) { | |
223 | ✗ | node->setVisibilityMode((VisibilityMode)v); | |
224 | } | ||
225 | |||
226 | ✗ | int getNodeWireFrameMode(Node* node) { return node->getWireFrameMode(); } | |
227 | ✗ | void setNodeWireFrameMode(Node* node, const int& v) { | |
228 | ✗ | node->setWireFrameMode((WireFrameMode)v); | |
229 | } | ||
230 | |||
231 | ✗ | int getNodeLightingMode(Node* node) { return node->getLightingMode(); } | |
232 | ✗ | void setNodeLightingMode(Node* node, const int& v) { | |
233 | ✗ | node->setLightingMode((LightingMode)v); | |
234 | } | ||
235 | |||
236 | ✗ | void setNodeLandmark(Node* node, bool enable) { | |
237 | ✗ | if (enable) | |
238 | ✗ | node->addLandmark(0.05f); | |
239 | else | ||
240 | ✗ | node->deleteLandmark(); | |
241 | } | ||
242 | |||
243 | ✗ | int getNodeHighlightState(Node* node) { return (int)node->getHighlightState(); } | |
244 | ✗ | void setNodeHighlightState(Node* node, const int& v) { | |
245 | ✗ | node->setHighlightState(v); | |
246 | } | ||
247 | |||
248 | ✗ | void setFlag(::osg::Node* node, osg::Node::NodeMask bit, bool on) { | |
249 | ✗ | if (on) | |
250 | ✗ | node->setNodeMask(node->getNodeMask() | bit); | |
251 | else | ||
252 | ✗ | node->setNodeMask(node->getNodeMask() & ~bit); | |
253 | } | ||
254 | |||
255 | 1 | MetaEnum* highlightStateEnum() { | |
256 |
2/4✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | static MetaEnum hs; |
257 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | if (hs.type.size() == 0) { |
258 | 1 | hs.type = "HighlightState"; | |
259 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("None"); |
260 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(0); |
261 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("1"); |
262 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(1); |
263 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("2"); |
264 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(2); |
265 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("3"); |
266 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(3); |
267 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("4"); |
268 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(4); |
269 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("5"); |
270 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(5); |
271 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("6"); |
272 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(6); |
273 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("7"); |
274 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(7); |
275 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
1 | hs.names.push_back("8"); |
276 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | hs.values.push_back(8); |
277 | } | ||
278 | 1 | return &hs; | |
279 | } | ||
280 | } // namespace | ||
281 | using ::osg::Matrix; | ||
282 | |||
283 | const float Node::TransparencyRenderingBinThreshold = 0.99f; | ||
284 | |||
285 | /* Declaration of private function members */ | ||
286 | 1 | void Node::init() { | |
287 | /* Build local conformation | ||
288 | <- wireframe_node_ptr_ | ||
289 | connected to the parent <- switch_node_ptr_ <- | ||
290 | auto_transform_ptr_ <- connection of children here | ||
291 | <- normal_node_ptr_ | ||
292 | */ | ||
293 | 1 | scale_.value = osgVector3(1, 1, 1); | |
294 | 1 | scale_.min = 0.f; | |
295 | 1 | scale_.step = 0.1f; | |
296 | 1 | scale_.adaptiveDecimal = true; | |
297 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
1 | scale_.callback(boost::bind(&Node::updateTransform, this)); |
298 | |||
299 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | M_.callback(scale_.callback()); |
300 | |||
301 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
1 | switch_node_ptr_ = new ::osg::Group; |
302 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
1 | hl_switch_node_ptr_ = new ::osg::Group; |
303 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
1 | transform_ptr_ = new ::osg::MatrixTransform; |
304 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | transform_ptr_->setName("positionInParentNode"); |
305 | |||
306 | 1 | switch_node_ptr_->setNodeMask(VisibilityBit | NodeBit | IntersectionBit); | |
307 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | switch_node_ptr_->setName(id_name_); |
308 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | wireframe_modes_.resize(2); |
309 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | wireframe_modes_[FILL] = new ::osg::Group; |
310 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | wireframe_modes_[FILL]->setName("wireframe: FILL"); |
311 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | wireframe_modes_[WIREFRAME] = new ::osg::Group; |
312 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | wireframe_modes_[WIREFRAME]->setName("wireframe: WIREFRAME"); |
313 | |||
314 | /* Building hierarchie */ | ||
315 | 1 | selected_wireframe_ = FILL; | |
316 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | switch_node_ptr_->addChild(wireframe_modes_[FILL]); |
317 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | wireframe_modes_[FILL]->addChild(hl_switch_node_ptr_); |
318 | 1 | wireframe_modes_[FILL]->setDataVariance(osg::Object::STATIC); | |
319 | |||
320 | // Setup highlight states | ||
321 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | highlight_nodes_.resize(9); |
322 | 1 | selected_highlight_ = 0; | |
323 | 1 | highlight_enabled_ = true; | |
324 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | highlight_nodes_[0] = transform_ptr_; |
325 |
2/2✓ Branch 0 taken 8 times.
✓ Branch 1 taken 1 times.
|
9 | for (unsigned int i = 1; i < 9; ++i) { |
326 |
2/4✓ Branch 1 taken 8 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 8 times.
✗ Branch 6 not taken.
|
8 | highlight_nodes_[i] = setupHighlightState(i); |
327 |
1/2✓ Branch 3 taken 8 times.
✗ Branch 4 not taken.
|
8 | highlight_nodes_[i]->addChild(transform_ptr_); |
328 | } | ||
329 | // setHighlightState(0); | ||
330 |
1/2✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
|
1 | hl_switch_node_ptr_->addChild(highlight_nodes_[selected_highlight_]); |
331 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | hl_switch_node_ptr_->setName("highlight switch"); |
332 | |||
333 |
2/4✓ Branch 3 taken 1 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1 times.
✗ Branch 7 not taken.
|
1 | wireframe_modes_[WIREFRAME]->setStateSet(getWireframeStateSet()); |
334 | 1 | wireframe_modes_[WIREFRAME]->setDataVariance(osg::Object::STATIC); | |
335 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | geode_ptr_ = NULL; |
336 | 1 | alpha_ = 1.; | |
337 | |||
338 | 1 | visibilityMode_ = VISIBILITY_ON; | |
339 | 1 | lightingMode_ = LIGHT_INFLUENCE_ON; | |
340 | |||
341 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | addProperty(EnumProperty::create( |
342 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | "Highlight/State", highlightStateEnum(), |
343 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Getter_t(boost::bind(getNodeHighlightState, this)), |
344 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Setter_t(boost::bind(setNodeHighlightState, this, _1)))); |
345 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
1 | addProperty(BoolProperty::create("Highlight/Enable", this, |
346 | &Node::getHighlightEnabled, | ||
347 | &Node::setHighlightEnabled)); | ||
348 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | addProperty(EnumProperty::create( |
349 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | "Visibility", visibilityModeEnum(), |
350 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Getter_t(boost::bind(getNodeVisibilityMode, this)), |
351 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Setter_t(boost::bind(setNodeVisibilityMode, this, _1)))); |
352 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | addProperty(EnumProperty::create( |
353 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | "WireframeMode", wireFrameModeEnum(), |
354 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Getter_t(boost::bind(getNodeWireFrameMode, this)), |
355 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Setter_t(boost::bind(setNodeWireFrameMode, this, _1)))); |
356 |
3/6✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 1 times.
✗ Branch 9 not taken.
|
1 | addProperty(EnumProperty::create( |
357 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | "LightingMode", lightingModeEnum(), |
358 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Getter_t(boost::bind(getNodeLightingMode, this)), |
359 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | EnumProperty::Setter_t(boost::bind(setNodeLightingMode, this, _1)))); |
360 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
1 | addProperty(BoolProperty::create( |
361 | "Landmark", | ||
362 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
2 | BoolProperty::getterFromMemberFunction(this, &Node::hasLandmark), |
363 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
2 | BoolProperty::Setter_t(boost::bind(setNodeLandmark, this, _1)))); |
364 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
1 | addProperty(BoolProperty::create("Selectable", this, &Node::isSelectable, |
365 | &Node::setSelectable)); | ||
366 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
1 | addProperty(StringProperty::createRO("Name", this, &Node::getID)); |
367 |
3/6✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
✓ Branch 9 taken 1 times.
✗ Branch 10 not taken.
|
1 | addProperty(Vector4Property::createWO("Color", this, &Node::setColor)); |
368 | |||
369 | RangedFloatProperty::Ptr_t alphaProp = RangedFloatProperty::create( | ||
370 |
2/4✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1 times.
✗ Branch 6 not taken.
|
2 | "Alpha", this, &Node::getAlpha, &Node::setAlpha); |
371 | 1 | alphaProp->setRange(0.f, 1.f, 0.1f); | |
372 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | addProperty(alphaProp); |
373 | |||
374 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | addProperty(&scale_); |
375 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | addProperty(&M_); |
376 | 1 | } | |
377 | |||
378 | 1 | Node::Node(const std::string& name) | |
379 |
6/12✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 15 taken 1 times.
✗ Branch 16 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 1 times.
✗ Branch 23 not taken.
|
1 | : id_name_(name), dirty_(true), scale_("Scale"), M_("Transform") { |
380 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | init(); |
381 | 1 | } | |
382 | |||
383 | ✗ | Node::Node(const Node& other) | |
384 | ✗ | : id_name_(other.getID()), dirty_(true), scale_("Scale"), M_("Transform") { | |
385 | ✗ | init(); | |
386 | } | ||
387 | |||
388 | ✗ | void Node::setSelectable(bool selectable) { | |
389 | ✗ | setFlag(transform_ptr_.get(), IntersectionBit, selectable); | |
390 | } | ||
391 | |||
392 | 5 | void Node::updateTransform() { | |
393 |
1/2✓ Branch 1 taken 5 times.
✗ Branch 2 not taken.
|
5 | osg::Matrixf M; |
394 |
1/2✓ Branch 1 taken 5 times.
✗ Branch 2 not taken.
|
5 | M.setRotate(M_.value.quat); |
395 |
1/2✓ Branch 1 taken 5 times.
✗ Branch 2 not taken.
|
5 | M.setTrans(M_.value.position); |
396 | |||
397 |
6/12✓ Branch 2 taken 5 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 5 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 5 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 5 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 5 times.
✗ Branch 15 not taken.
✓ Branch 17 taken 5 times.
✗ Branch 18 not taken.
|
5 | transform_ptr_->setMatrix(::osg::Matrix::scale(scale_.value) * Ms_ * M); |
398 | 5 | dirty_ = true; | |
399 | 5 | } | |
400 | |||
401 | 2 | void Node::setStaticTransform(const osgVector3& position, const osgQuat& quat) { | |
402 | 2 | Ms_.setRotate(quat); | |
403 | 2 | Ms_.setTrans(position); | |
404 | |||
405 | 2 | updateTransform(); | |
406 | 2 | } | |
407 | |||
408 | 2 | osgQuat Node::getStaticRotation() const { | |
409 | 2 | osgQuat q, so; | |
410 | 2 | osgVector3 t, s; | |
411 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | Ms_.decompose(t, q, s, so); |
412 | 4 | return q; | |
413 | } | ||
414 | |||
415 | 2 | osgVector3 Node::getStaticPosition() const { | |
416 | 2 | osgQuat q, so; | |
417 | 2 | osgVector3 t, s; | |
418 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | Ms_.decompose(t, q, s, so); |
419 | 2 | return t; | |
420 | } | ||
421 | |||
422 | ✗ | void Node::setVisibilityMode(const VisibilityMode& mode) { | |
423 | ✗ | if (visibilityMode_ == mode) return; | |
424 | ✗ | visibilityMode_ = mode; | |
425 | ✗ | switch (mode) { | |
426 | ✗ | case VISIBILITY_ON: | |
427 | ✗ | setFlag(transform_ptr_.get(), VisibilityBit, true); | |
428 | ✗ | transform_ptr_->setStateSet(getVisibleStateSet(lightingMode_)); | |
429 | ✗ | break; | |
430 | ✗ | case VISIBILITY_OFF: | |
431 | ✗ | setFlag(transform_ptr_.get(), VisibilityBit, false); | |
432 | ✗ | transform_ptr_->setStateSet(getVisibleStateSet(lightingMode_)); | |
433 | ✗ | break; | |
434 | ✗ | case ALWAYS_ON_TOP: | |
435 | ✗ | setFlag(transform_ptr_.get(), VisibilityBit, true); | |
436 | ✗ | transform_ptr_->setStateSet(getAlwaysOnTopStateSet(lightingMode_)); | |
437 | ✗ | break; | |
438 | |||
439 | ✗ | default: | |
440 | ✗ | ASSERT(false, "mode is not well defined"); | |
441 | break; | ||
442 | } | ||
443 | ✗ | dirty_ = true; | |
444 | } | ||
445 | |||
446 | ✗ | void Node::setLightingMode(const LightingMode& mode) { | |
447 | ✗ | if (mode == lightingMode_) return; | |
448 | ✗ | lightingMode_ = mode; | |
449 | ✗ | switch (visibilityMode_) { | |
450 | ✗ | case VISIBILITY_ON: | |
451 | case VISIBILITY_OFF: | ||
452 | ✗ | transform_ptr_->setStateSet(getVisibleStateSet(lightingMode_)); | |
453 | ✗ | break; | |
454 | ✗ | case ALWAYS_ON_TOP: | |
455 | ✗ | transform_ptr_->setStateSet(getAlwaysOnTopStateSet(lightingMode_)); | |
456 | ✗ | break; | |
457 | ✗ | default: | |
458 | ✗ | ASSERT(false, "mode is not well defined"); | |
459 | break; | ||
460 | } | ||
461 | ✗ | dirty_ = true; | |
462 | } | ||
463 | |||
464 | ✗ | LightingMode Node::getLightingMode() const { return lightingMode_; } | |
465 | |||
466 | ✗ | void Node::setWireFrameMode(const WireFrameMode& mode) { | |
467 | ✗ | if (mode == selected_wireframe_) return; | |
468 | ✗ | bool fillSelected = (selected_wireframe_ == FILL) || | |
469 | ✗ | (selected_wireframe_ == FILL_AND_WIREFRAME); | |
470 | ✗ | bool wireSelected = (selected_wireframe_ == WIREFRAME) || | |
471 | ✗ | (selected_wireframe_ == FILL_AND_WIREFRAME); | |
472 | // 0: keep as it is | ||
473 | // 1: select | ||
474 | // 2: deselect | ||
475 | ✗ | int selectFill = 0, selectWire = 0; | |
476 | ✗ | switch (mode) { | |
477 | ✗ | case FILL: | |
478 | ✗ | if (wireSelected) selectWire = 2; | |
479 | ✗ | if (!fillSelected) selectFill = 1; | |
480 | ✗ | break; | |
481 | ✗ | case WIREFRAME: | |
482 | ✗ | if (!wireSelected) selectWire = 1; | |
483 | ✗ | if (fillSelected) selectFill = 2; | |
484 | ✗ | break; | |
485 | ✗ | case FILL_AND_WIREFRAME: | |
486 | ✗ | if (!wireSelected) selectWire = 1; | |
487 | ✗ | if (!fillSelected) selectFill = 1; | |
488 | ✗ | break; | |
489 | ✗ | default: | |
490 | ✗ | ASSERT(false, "WireFrameMode set with bad option"); | |
491 | break; | ||
492 | } | ||
493 | ✗ | switch (selectFill) { | |
494 | ✗ | case 0: | |
495 | ✗ | break; | |
496 | ✗ | case 1: | |
497 | ✗ | wireframe_modes_[FILL]->addChild(hl_switch_node_ptr_); | |
498 | ✗ | switch_node_ptr_->addChild(wireframe_modes_[FILL]); | |
499 | ✗ | break; | |
500 | ✗ | case 2: | |
501 | ✗ | wireframe_modes_[FILL]->removeChild(hl_switch_node_ptr_); | |
502 | ✗ | switch_node_ptr_->removeChild(wireframe_modes_[FILL]); | |
503 | ✗ | break; | |
504 | ✗ | default: | |
505 | ✗ | assert(false && "Wrong action"); | |
506 | }; | ||
507 | ✗ | switch (selectWire) { | |
508 | ✗ | case 0: | |
509 | ✗ | break; | |
510 | ✗ | case 1: | |
511 | ✗ | wireframe_modes_[WIREFRAME]->addChild(hl_switch_node_ptr_); | |
512 | ✗ | switch_node_ptr_->addChild(wireframe_modes_[WIREFRAME]); | |
513 | ✗ | break; | |
514 | ✗ | case 2: | |
515 | ✗ | wireframe_modes_[WIREFRAME]->removeChild(hl_switch_node_ptr_); | |
516 | ✗ | switch_node_ptr_->removeChild(wireframe_modes_[WIREFRAME]); | |
517 | ✗ | break; | |
518 | ✗ | default: | |
519 | ✗ | assert(false && "Wrong action"); | |
520 | }; | ||
521 | ✗ | selected_wireframe_ = mode; | |
522 | ✗ | dirty_ = true; | |
523 | } | ||
524 | |||
525 | ✗ | void Node::addLandmark(const float& size) { | |
526 | ✗ | ::osg::GeometryRefPtr geom_ptr = new ::osg::Geometry(); | |
527 | |||
528 | /* Define points of the beam */ | ||
529 | ✗ | ::osg::Vec3ArrayRefPtr points_ptr = new ::osg::Vec3Array(6); | |
530 | ✗ | points_ptr->at(0) = osgVector3(0., 0., 0.); | |
531 | ✗ | points_ptr->at(1) = osgVector3(size, 0., 0.); | |
532 | ✗ | points_ptr->at(2) = osgVector3(0., 0., 0.); | |
533 | ✗ | points_ptr->at(3) = osgVector3(0., size, 0.); | |
534 | ✗ | points_ptr->at(4) = osgVector3(0., 0., 0.); | |
535 | ✗ | points_ptr->at(5) = osgVector3(0., 0., size); | |
536 | |||
537 | /* Define the color */ | ||
538 | ✗ | ::osg::Vec4ArrayRefPtr color_ptr = new ::osg::Vec4Array(3); | |
539 | ✗ | color_ptr->at(0) = osgVector4(1., 0., 0., 1.); | |
540 | ✗ | color_ptr->at(1) = osgVector4(0., 1., 0., 1.); | |
541 | ✗ | color_ptr->at(2) = osgVector4(0., 0., 1., 1.); | |
542 | |||
543 | ✗ | geom_ptr->setVertexArray(points_ptr.get()); | |
544 | ✗ | geom_ptr->setColorArray(color_ptr.get()); | |
545 | ✗ | geom_ptr->setColorBinding(::osg::Geometry::BIND_PER_PRIMITIVE_SET); | |
546 | ✗ | geom_ptr->addPrimitiveSet(new osg::DrawArrays(GL_LINES, 0, 2)); | |
547 | ✗ | geom_ptr->addPrimitiveSet(new osg::DrawArrays(GL_LINES, 2, 2)); | |
548 | ✗ | geom_ptr->addPrimitiveSet(new osg::DrawArrays(GL_LINES, 4, 2)); | |
549 | |||
550 | ✗ | transform_ptr_->removeChild(landmark_geode_ptr_); | |
551 | ✗ | landmark_geode_ptr_ = new osg::Geode(); | |
552 | ✗ | landmark_geode_ptr_->addDrawable(geom_ptr); | |
553 | |||
554 | // set Landmark as ALWAYS ON TOP | ||
555 | ✗ | setFlag(landmark_geode_ptr_.get(), VisibilityBit, true); | |
556 | ✗ | landmark_geode_ptr_->setStateSet(getAlwaysOnTopStateSet(LIGHT_INFLUENCE_OFF)); | |
557 | |||
558 | ✗ | transform_ptr_->addChild(landmark_geode_ptr_); | |
559 | ✗ | dirty_ = true; | |
560 | } | ||
561 | |||
562 | ✗ | bool Node::hasLandmark() const { return landmark_geode_ptr_; } | |
563 | |||
564 | ✗ | void Node::deleteLandmark() { | |
565 | ✗ | if (landmark_geode_ptr_) { | |
566 | ✗ | transform_ptr_->removeChild(landmark_geode_ptr_); | |
567 | ✗ | landmark_geode_ptr_.release(); | |
568 | ✗ | dirty_ = true; | |
569 | } | ||
570 | } | ||
571 | |||
572 | 8 | ::osg::Group* Node::setupHighlightState(unsigned int state) { | |
573 | 8 | osg::StateSetRefPtr ss; | |
574 |
8/9✓ Branch 0 taken 1 times.
✓ Branch 1 taken 1 times.
✓ Branch 2 taken 1 times.
✓ Branch 3 taken 1 times.
✓ Branch 4 taken 1 times.
✓ Branch 5 taken 1 times.
✓ Branch 6 taken 1 times.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
|
8 | switch (state) { |
575 | 1 | case 1: /// collision | |
576 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ss = getHighlightStateSet<1>(); |
577 | 1 | break; | |
578 | 1 | case 2: /// selection | |
579 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ss = getHighlightStateSet<2>(); |
580 | 1 | break; | |
581 | 1 | case 3: /// selection | |
582 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ss = getHighlightStateSet<3>(); |
583 | 1 | break; | |
584 | 1 | case 4: /// selection | |
585 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ss = getHighlightStateSet<4>(); |
586 | 1 | break; | |
587 | 1 | case 5: /// selection | |
588 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ss = getHighlightStateSet<5>(); |
589 | 1 | break; | |
590 | 1 | case 6: /// selection | |
591 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | ss = getHighlightStateSet<6>(); |
592 | 1 | break; | |
593 | 1 | case 7: /// Selection through osgFX::Outline | |
594 | { | ||
595 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | osgFX::Outline* outline = new osgFX::Outline; |
596 | |||
597 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | outline->setWidth(8); |
598 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | outline->setColor(osg::Vec4(1, 1, 0, 1)); |
599 | 1 | outline->setDataVariance(osg::Object::STATIC); | |
600 | 1 | return outline; | |
601 | } break; | ||
602 | 1 | case 8: /// Selection through osgFX::Outline | |
603 | { | ||
604 |
2/4✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
|
1 | osgFX::Scribe* scribe = new osgFX::Scribe; |
605 | |||
606 |
1/2✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
|
1 | scribe->setWireframeLineWidth(1); |
607 |
1/2✓ Branch 2 taken 1 times.
✗ Branch 3 not taken.
|
1 | scribe->setWireframeColor(osg::Vec4(1, 1, 0, 1)); |
608 | 1 | scribe->setDataVariance(osg::Object::STATIC); | |
609 | 1 | return scribe; | |
610 | } break; | ||
611 | ✗ | case 0: | |
612 | default: | ||
613 | ✗ | break; | |
614 | } | ||
615 |
2/4✓ Branch 1 taken 6 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 6 times.
✗ Branch 5 not taken.
|
6 | osg::Group* node = new ::osg::Group; |
616 |
1/2✓ Branch 1 taken 6 times.
✗ Branch 2 not taken.
|
6 | node->setStateSet(ss); |
617 | 6 | node->setDataVariance(osg::Object::STATIC); | |
618 | 6 | return node; | |
619 | 8 | } | |
620 | |||
621 | ✗ | void Node::setHighlightState(unsigned int state) { | |
622 | ✗ | if (!highlight_enabled_) return; | |
623 | ✗ | if (state != selected_highlight_ && state < highlight_nodes_.size()) { | |
624 | ✗ | hl_switch_node_ptr_->replaceChild(highlight_nodes_[selected_highlight_], | |
625 | ✗ | highlight_nodes_[state]); | |
626 | // Update the child | ||
627 | ✗ | selected_highlight_ = state; | |
628 | ✗ | dirty_ = true; | |
629 | } | ||
630 | } | ||
631 | |||
632 | ✗ | void Node::setAlpha(const float& alpha) { | |
633 | ✗ | if (geode_ptr_.get() == NULL) { | |
634 | ✗ | log() << "You must initialize a Geode on " << id_name_ << " to use Alpha" | |
635 | ✗ | << std::endl; | |
636 | ✗ | return; | |
637 | } | ||
638 | ✗ | osg::StateSet* ss = geode_ptr_.get()->getStateSet(); | |
639 | ✗ | if (ss) { | |
640 | ✗ | alpha_ = alpha; | |
641 | osg::Material* mat; | ||
642 | ✗ | if (ss->getAttribute(osg::StateAttribute::MATERIAL)) | |
643 | ✗ | mat = dynamic_cast<osg::Material*>( | |
644 | ✗ | ss->getAttribute(osg::StateAttribute::MATERIAL)); | |
645 | else { | ||
646 | ✗ | mat = new osg::Material; | |
647 | ✗ | ss->setAttribute(mat, osg::StateAttribute::OFF); | |
648 | } | ||
649 | ✗ | mat->setAlpha(osg::Material::FRONT_AND_BACK, alpha); | |
650 | ✗ | setTransparentRenderingBin(alpha_ < TransparencyRenderingBinThreshold); | |
651 | ✗ | dirty_ = true; | |
652 | } | ||
653 | } | ||
654 | |||
655 | ✗ | float Node::getAlpha() const { return alpha_; } | |
656 | |||
657 | ✗ | void Node::setTransparency(const float& transparency) { | |
658 | ✗ | setAlpha(1.f - transparency); | |
659 | } | ||
660 | |||
661 | ✗ | float Node::getTransparency() const { return 1.f - getAlpha(); } | |
662 | |||
663 | 1 | void Node::setTransparentRenderingBin(bool transparent, osg::StateSet* ss) { | |
664 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
1 | if (ss == NULL) { |
665 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 1 times.
|
1 | if (geode_ptr_.get() == NULL) { |
666 | ✗ | log() << "You must initialize a Geode on " << id_name_ << " to use Alpha" | |
667 | ✗ | << std::endl; | |
668 | ✗ | return; | |
669 | } | ||
670 | 1 | ss = geode_ptr_.get()->getStateSet(); | |
671 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 1 times.
|
1 | if (ss == NULL) return; |
672 | } | ||
673 | bool isTransparent = | ||
674 | 1 | (ss->getRenderingHint() == osg::StateSet::TRANSPARENT_BIN); | |
675 |
1/2✓ Branch 0 taken 1 times.
✗ Branch 1 not taken.
|
1 | if (transparent == isTransparent) return; |
676 | ✗ | if (transparent) | |
677 | ✗ | ss->setRenderingHint(osg::StateSet::TRANSPARENT_BIN); | |
678 | else | ||
679 | ✗ | ss->setRenderingHint(osg::StateSet::DEFAULT_BIN); | |
680 | ✗ | dirty_ = true; | |
681 | } | ||
682 | |||
683 | 2 | Node::~Node() { | |
684 | /* Proper deletion */ | ||
685 | /* deleting the top most node (switch_node_ptr_) will delete everything else. | ||
686 | * Loop over the parents of switch_node_ptr_ and remove references to it. | ||
687 | */ | ||
688 | typedef ::osg::Node::ParentList PL_t; | ||
689 | 2 | PL_t parents = switch_node_ptr_->getParents(); | |
690 |
1/2✗ Branch 5 not taken.
✓ Branch 6 taken 1 times.
|
2 | for (PL_t::const_iterator _p = parents.begin(); _p != parents.end(); ++_p) |
691 | ✗ | (*_p)->removeChild(switch_node_ptr_); | |
692 | } | ||
693 | |||
694 | 2 | const Configuration& Node::getGlobalTransform() const { return M_.value; } | |
695 | |||
696 | ✗ | void Node::traverse(NodeVisitor& /*visitor*/) {} | |
697 | |||
698 | ✗ | osg::ref_ptr<osg::Node> Node::getOsgNode() const { return geode_ptr_.get(); } | |
699 | |||
700 | /* End of declaration of public function members */ | ||
701 | |||
702 | } /* namespace viewer */ | ||
703 | |||
704 | } /* namespace gepetto */ | ||
705 |