Open3D (C++ API)
Geometry.h
Go to the documentation of this file.
1 // ----------------------------------------------------------------------------
2 // - Open3D: www.open3d.org -
3 // ----------------------------------------------------------------------------
4 // The MIT License (MIT)
5 //
6 // Copyright (c) 2018 www.open3d.org
7 //
8 // Permission is hereby granted, free of charge, to any person obtaining a copy
9 // of this software and associated documentation files (the "Software"), to deal
10 // in the Software without restriction, including without limitation the rights
11 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 // copies of the Software, and to permit persons to whom the Software is
13 // furnished to do so, subject to the following conditions:
14 //
15 // The above copyright notice and this permission notice shall be included in
16 // all copies or substantial portions of the Software.
17 //
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
24 // IN THE SOFTWARE.
25 // ----------------------------------------------------------------------------
26 
27 #pragma once
28 
29 #include <string>
30 
31 namespace open3d {
32 namespace geometry {
33 
37 class Geometry {
38 public:
42  enum class GeometryType {
44  Unspecified = 0,
46  PointCloud = 1,
48  VoxelGrid = 2,
50  Octree = 3,
52  LineSet = 4,
54  MeshBase = 5,
56  TriangleMesh = 6,
60  Image = 8,
62  RGBDImage = 9,
64  TetraMesh = 10,
69  };
70 
71 public:
72  virtual ~Geometry() {}
73 
74 protected:
79  Geometry(GeometryType type, int dimension)
80  : geometry_type_(type), dimension_(dimension) {}
81 
82 public:
84  virtual Geometry& Clear() = 0;
86  virtual bool IsEmpty() const = 0;
88  GeometryType GetGeometryType() const { return geometry_type_; }
90  int Dimension() const { return dimension_; }
91 
92  std::string GetName() const { return name_; }
93  void SetName(const std::string& name) { name_ = name; }
94 
95 private:
97  GeometryType geometry_type_ = GeometryType::Unspecified;
99  int dimension_ = 3;
100  std::string name_;
101 };
102 
103 } // namespace geometry
104 } // namespace open3d
int Dimension() const
Returns whether the geometry is 2D or 3D.
Definition: Geometry.h:90
The base geometry class.
Definition: Geometry.h:37
GeometryType GetGeometryType() const
Returns one of registered geometry types.
Definition: Geometry.h:88
A bounding box that is aligned along the coordinate axes.
Definition: BoundingVolume.h:164
Geometry(GeometryType type, int dimension)
Parameterized Constructor.
Definition: Geometry.h:79
HalfEdgeTriangleMesh inherits TriangleMesh class with the addition of HalfEdge data structure for eac...
Definition: HalfEdgeTriangleMesh.h:43
MeshBash Class.
Definition: MeshBase.h:51
A bounding box oriented along an arbitrary frame of reference.
Definition: BoundingVolume.h:44
A point cloud consists of point coordinates, and optionally point colors and point normals...
Definition: PointCloud.h:54
RGBDImage is for a pair of registered color and depth images,.
Definition: RGBDImage.h:46
std::string GetName() const
Definition: Geometry.h:92
virtual bool IsEmpty() const =0
Returns true iff the geometry is empty.
Tetra mesh contains vertices and tetrahedra represented by the indices to the vertices.
Definition: TetraMesh.h:48
virtual ~Geometry()
Definition: Geometry.h:72
char type
Definition: FilePCD.cpp:58
Definition: Open3DViewer.h:29
std::string name
Definition: FilePCD.cpp:56
VoxelGrid is a collection of voxels which are aligned in grid.
Definition: VoxelGrid.h:81
GeometryType
Specifies possible geometry types.
Definition: Geometry.h:42
virtual Geometry & Clear()=0
Clear all elements in the geometry.
Octree datastructure.
Definition: Octree.h:181
Triangle mesh contains vertices and triangles represented by the indices to the vertices.
Definition: TriangleMesh.h:54
LineSet define a sets of lines in 3D. A typical application is to display the point cloud corresponde...
Definition: LineSet.h:48
void SetName(const std::string &name)
Definition: Geometry.h:93
The Image class stores image with customizable width, height, num of channels and bytes per channel...
Definition: Image.h:53