opensurgsim
AabbTreeIntersectionVisitor.h
1 // This file is a part of the OpenSurgSim project.
2 // Copyright 2013, SimQuest Solutions Inc.
3 //
4 // Licensed under the Apache License, Version 2.0 (the "License");
5 // you may not use this file except in compliance with the License.
6 // You may obtain a copy of the License at
7 //
8 // http://www.apache.org/licenses/LICENSE-2.0
9 //
10 // Unless required by applicable law or agreed to in writing, software
11 // distributed under the License is distributed on an "AS IS" BASIS,
12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 // See the License for the specific language governing permissions and
14 // limitations under the License.
15 
16 #ifndef SURGSIM_DATASTRUCTURES_AABBTREEINTERSECTIONVISITOR_H
17 #define SURGSIM_DATASTRUCTURES_AABBTREEINTERSECTIONVISITOR_H
18 
19 #include "SurgSim/DataStructures/TreeVisitor.h"
20 #include "SurgSim/Math/Aabb.h"
21 
22 #include <list>
23 #include <vector>
24 
25 namespace SurgSim
26 {
27 namespace DataStructures
28 {
29 
32 {
33 public:
34 
37 
40  explicit AabbTreeIntersectionVisitor(const SurgSim::Math::Aabbd& aabb);
41 
44 
45  bool handle(TreeNode* node) override;
46 
47  bool handle(AabbTreeNode* node) override;
48 
50  bool hasIntersections() const;
51 
53  void reset();
54 
56  SurgSim::Math::Aabbd getAabb() const;
57 
60  void setAabb(const SurgSim::Math::Aabbd& aabb);
61 
63  const std::vector<size_t>& getIntersections() const;
64 
65 private:
66 
68  std::vector<size_t> m_intersections;
69 
71  SurgSim::Math::Aabbd m_aabb;
72 };
73 
74 }
75 }
76 
77 #endif
Wraps glewInit() to separate the glew opengl definitions from the osg opengl definitions only imgui n...
Definition: AddRandomSphereBehavior.cpp:36
void reset()
Resets the data in the tree.
Definition: AabbTreeIntersectionVisitor.cpp:67
Abstract Class for visitors, this needs to be extended for other tree nodes when necessary return fal...
Definition: TreeVisitor.h:31
Basic tree node structure.
Definition: TreeNode.h:36
void setAabb(const SurgSim::Math::Aabbd &aabb)
Sets a new bounding box, will also call reset()
Definition: AabbTreeIntersectionVisitor.cpp:78
SurgSim::Math::Aabbd getAabb() const
Definition: AabbTreeIntersectionVisitor.cpp:72
const std::vector< size_t > & getIntersections() const
Definition: AabbTreeIntersectionVisitor.cpp:85
AabbTreeIntersectionVisitor()
Constructor.
Definition: AabbTreeIntersectionVisitor.cpp:26
bool hasIntersections() const
Definition: AabbTreeIntersectionVisitor.cpp:90
Visitor class to collect the items that intersect with a given bounding box.
Definition: AabbTreeIntersectionVisitor.h:31
bool handle(TreeNode *node) override
Handle TreeNode basic type.
Definition: AabbTreeIntersectionVisitor.cpp:42
virtual ~AabbTreeIntersectionVisitor()
Destructor.
Definition: AabbTreeIntersectionVisitor.cpp:37
Node class for the AabbTree, this handles groups of items and subdivision if the number of items gets...
Definition: AabbTreeNode.h:30