Types.hh 4.62 KB
Newer Older
Jan Möbius's avatar
 
Jan Möbius committed
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
//=============================================================================
//
//                               OpenFlipper
//        Copyright (C) 2008 by Computer Graphics Group, RWTH Aachen
//                           www.openflipper.org
//
//-----------------------------------------------------------------------------
//
//                                License
//
//  OpenFlipper is free software: you can redistribute it and/or modify
//  it under the terms of the GNU Lesser General Public License as published by
//  the Free Software Foundation, either version 3 of the License, or
//  (at your option) any later version.
//
//  OpenFlipper is distributed in the hope that it will be useful,
//  but WITHOUT ANY WARRANTY; without even the implied warranty of
//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
//  GNU Lesser General Public License for more details.
//
//  You should have received a copy of the GNU Lesser General Public License
//  along with OpenFlipper.  If not, see <http://www.gnu.org/licenses/>.
//
//-----------------------------------------------------------------------------
//
//   $Revision$
//   $Author$
//   $Date$
//
//=============================================================================




//=============================================================================
//
//  Types
//
//=============================================================================

/**
 * \file Types.hh
 * This File contains the basic available datatypes in the Framework.
 */


#ifndef TYPES_HH
#define TYPES_HH

#include "GlobalDefines.hh"
51
#include <limits.h>
52
#include <QIcon>
Jan Möbius's avatar
 
Jan Möbius committed
53
54
55
56


//== Global Typedefs  =================================================================

57
/** \brief Predefined datatypes
Jan Möbius's avatar
 
Jan Möbius committed
58
 *
59
60
 * Here are several datatypes which have predefined ids. This might be changed to runtime added
 * datatypes in the futere.
Jan Möbius's avatar
 
Jan Möbius committed
61
 */
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100

/// None of the other Objects
const unsigned int DATA_NONE          = 0;

/// Items used for Grouping
const unsigned int DATA_GROUP         = 1;

/// Point based objects
const unsigned int DATA_POINTS        = 2;

/// PolyLine objects
const unsigned int DATA_POLY_LINE     = 4;

/// Triangle Mesh objects
const unsigned int DATA_TRIANGLE_MESH = 8;

/// Poly Mesh Objects
const unsigned int DATA_POLY_MESH     = 16;

/// BSpline objects
const unsigned int DATA_BSPLINE_CURVE = 32;

/// Volumetric objects
const unsigned int DATA_VOLUME        = 64;

/// BSpline Surface objects
const unsigned int DATA_BSPLINE_SURFACE = 128;

/// Skeletons
const unsigned int DATA_SKELETON       = 256;

/// Gis Data
const unsigned int DATA_GIS            = 512;


/// Identifier for all available objects
const unsigned int DATA_ALL           = UINT_MAX;

typedef unsigned int DataType;
Jan Möbius's avatar
Jan Möbius committed
101
102

// TODO: Make types runtime addable
Jan Möbius's avatar
 
Jan Möbius committed
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126

//== INCLUDES =================================================================

#include "BaseObject.hh"
#include "GroupObject.hh"
#include "BaseObjectData.hh"

//== TYPEDEFS =================================================================

/// Standard Type for 3d Vector used for scripting
typedef ACG::Vec3d Vector;
/// Standard Type for id Lists used for scripting
typedef std::vector< int > idList;
/// Standard Type for a 4x4 Matrix used for scripting
typedef ACG::Matrix4x4d Matrix4x4;

Q_DECLARE_METATYPE(idList);
Q_DECLARE_METATYPE(QVector< int >);
Q_DECLARE_METATYPE(Vector);
Q_DECLARE_METATYPE(Matrix4x4);

/// Vector Type containing the Data Objects
typedef std::vector<BaseObjectData*> DataContainer;

127
128
129
//== Functions for adding dataTypes =========================================================

/// Adds a datatype and returns the id for the new type
130
DLLEXPORT
131
132
133
DataType addDataType(QString _name);

/// Given a dataType Identifier string this function will return the id of the datatype
134
DLLEXPORT
135
DataType typeId(QString _name);
Jan Möbius's avatar
 
Jan Möbius committed
136

137
/// Get the name of a type with given id
138
DLLEXPORT
139
140
QString typeName(DataType _id);

141
142
143
144
145
146
//================================================================================================
/** @name Datatype Icons
* @{ */
//================================================================================================

/// Get an icon for a given DataType
147
DLLEXPORT
148
QString typeIcon(QString  _name);
149

150
/// Get an icon for a given DataType
151
DLLEXPORT
152
153
154
QString typeIcon(DataType _id);

/// Set an Icon for a given DataType
155
DLLEXPORT
156
void setTypeIcon( DataType _id   , QString _icon);
157

158
/// Set an Icon for a given DataType
159
DLLEXPORT
160
161
162
163
164
void setTypeIcon( QString  _name , QString _icon );

/** @} */


Jan Möbius's avatar
 
Jan Möbius committed
165
166
167
//=============================================================================
#endif // TYPES_HH defined
//=============================================================================