-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy patheulerconvention.h
More file actions
45 lines (30 loc) · 1.04 KB
/
eulerconvention.h
File metadata and controls
45 lines (30 loc) · 1.04 KB
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
#ifndef _EulerConvention_H
#define _EulerConvention_H
#include <QString>
#include <QVector3D>
class EulerConvention
{
public:
enum RotationName { Roll=0, Pitch=1, Yaw=2 } ;
public:
EulerConvention(const QVector3D& roll_axis =QVector3D(1,0,0),
const QVector3D& pitch_axis =QVector3D(0,1,0),
const QVector3D& yaw_axis =QVector3D(0,0,1));
~EulerConvention(){};
QVector3D roll_axis() const;
QVector3D pitch_axis() const;
QVector3D yaw_axis() const;
void set_axes(const QVector3D& roll_axis,
const QVector3D& pitch_axis,
const QVector3D& yaw_axis);
QVector3D to_axis(const QString& str) const;
static QString to_string(RotationName name);
private:
QVector3D _roll_axis;
QVector3D _pitch_axis;
QVector3D _yaw_axis;
bool _is_convention_proper(const QVector3D& roll_axis,
const QVector3D& pitch_axis,
const QVector3D& yaw_axis);
};
#endif // _EulerConvention_H