forked from RobotLocomotion/drake
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgeometry_version.h
66 lines (53 loc) · 2.31 KB
/
geometry_version.h
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
#pragma once
#include "drake/common/drake_copyable.h"
#include "drake/common/identifier.h"
#include "drake/geometry/geometry_roles.h"
namespace drake {
namespace geometry {
/**
A version numbering class that reports revisions of SceneGraph's geometric data.
Other Systems can use this version number to perform updates when they detect
changes to the geometric data they consume. The version of the geometry data is
made available through SceneGraphInspector.
The geometry data is partitioned by geometric role and have independent role
version values. Some of SceneGraph's API (as variously documented) will cause
one or more role versions to change. This class provides the API `IsSameAs`
that takes another GeometryVersion as well as a Role to help detect whether the
provided role of the geometries may have changed. For example:
@code
// Downstream system holds an instance of GeometryVersion `old_version` as a
// reference to compare against.
// Get the version under test from SceneGraphInspector.
const GeometryVersion& test_version = scene_graph_inspector.geometry_version();
// Determine if two versions have the same proximity data.
bool same_proximity = old_version.IsSameAs(test_version, Role::kProximity);
@endcode
*/
class GeometryVersion {
public:
DRAKE_DEFAULT_COPY_AND_MOVE_AND_ASSIGN(GeometryVersion);
/** Constructs a default-initialized instance; guaranteed to be different
from every other instance. */
GeometryVersion();
/** Returns true if `this` GeometryVersion has the same `role`
version as the `other` GeometryVersion. */
bool IsSameAs(const GeometryVersion& other, Role role) const;
private:
using RoleVersionId = Identifier<class RoleVersionTag>;
/* Only GeometryState can update the role versions and construct
GeometryVersion from scratch. Downstream systems should obtain a reference
through the API provided by SceneGraphInspector if they want the version.
They then may choose to retain a copy if needed. */
template <typename T>
friend class GeometryState;
/* Facilitates testing. */
friend class GeometryVersionTest;
void modify_proximity();
void modify_perception();
void modify_illustration();
RoleVersionId proximity_version_id_;
RoleVersionId perception_version_id_;
RoleVersionId illustration_version_id_;
};
} // namespace geometry
} // namespace drake