Image Component Library (ICL)
SixDOFConstraint.h
Go to the documentation of this file.
1 /********************************************************************
2 ** Image Component Library (ICL) **
3 ** **
4 ** Copyright (C) 2006-2014 CITEC, University of Bielefeld **
5 ** Neuroinformatics Group **
6 ** Website: www.iclcv.org and **
7 ** http://opensource.cit-ec.de/projects/icl **
8 ** **
9 ** File : ICLPhysics/src/ICLPhysics/SixDOFConstraint.h **
10 ** Module : ICLPhysics **
11 ** Author : Christof Elbrechter, Matthias Esau **
12 ** **
13 ** **
14 ** GNU LESSER GENERAL PUBLIC LICENSE **
15 ** This file may be used under the terms of the GNU Lesser General **
16 ** Public License version 3.0 as published by the **
17 ** **
18 ** Free Software Foundation and appearing in the file LICENSE.LGPL **
19 ** included in the packaging of this file. Please review the **
20 ** following information to ensure the license requirements will **
21 ** be met: http://www.gnu.org/licenses/lgpl-3.0.txt **
22 ** **
23 ** The development of this software was supported by the **
24 ** Excellence Cluster EXC 277 Cognitive Interaction Technology. **
25 ** The Excellence Cluster EXC 277 is a grant of the Deutsche **
26 ** Forschungsgemeinschaft (DFG) in the context of the German **
27 ** Excellence Initiative. **
28 ** **
29 ********************************************************************/
30 #pragma once
31 
32 #include <ICLPhysics/Constraint.h>
33 #include <ICLGeom/GeomDefs.h>
34 
35 namespace icl {
36  namespace physics{
37  class RigidObject;
38 
41  void init(RigidObject* a, RigidObject* b, const geom::Mat &frameInA, const geom::Mat &frameInB, const bool useLinearReferenceFrameA);
42  public:
44  SixDOFConstraint(RigidObject* a, RigidObject* b, const geom::Mat &frameInA, const geom::Mat &frameInB, const bool useLinearReferenceFrameA = true);
45  SixDOFConstraint(RigidObject* a, RigidObject* b, const geom::Vec &pivotInA, const geom::Vec &pivotInB,bool useLinearReferenceFrameA = true);
47  SixDOFConstraint(RigidObject* a, RigidObject* b, const bool useLinearReferenceFrameA = true);
49  void setFrames(const geom::Mat &frameA, const geom::Mat &frameB);
50  void setPivot(const geom::Vec &pivotInA, const geom::Vec &pivotInB);
51 
52  /* Set lower linear limits of the constraint pivot.
53  * Setting the lower limit to higher than the upper limit unlocks the axis.
54  */
55  void setLinearLowerLimit(const geom::Vec &lower);
56 
57  /* Set upper linear limits of the constraint pivot.
58  * Setting the lower limit to higher than the upper limit unlocks the axis.
59  */
60  void setLinearUpperLimit(const geom::Vec &upper);
61 
63  geom::Vec getLinearLowerLimit();
64 
66  geom::Vec getLinearUpperLimit();
67 
68  float getAngle(int index);
69 
70  /* Set lower angular limits of the constraint pivot.
71  * Setting the lower limit to higher than the upper limit unlocks the axis.
72  */
73  void setAngularLowerLimit(const geom::Vec &lower);
74 
75  /* Set upper linear limits of the constraint pivot.
76  * Setting the lower limit to higher than the upper limit unlocks the axis.
77  */
78  void setAngularUpperLimit(const geom::Vec &upper);
79 
81  geom::Vec getAngularLowerLimit();
82 
84  geom::Vec getAngularUpperLimit();
85 
87  void setLinearMotor(int index, bool enableMotor, float targetVelocity, float maxMotorForce, bool force_activation = false);
88 
90  void setAngularMotor(int index, bool enableMotor, float targetVelocity, float maxMotorForce, bool force_activation = false);
91  };
92  }
93 }
undocument this line if you encounter any issues!
Definition: Any.h:37
This is a generic constraint that allows to free configuration of the limits on all 6 degrees of free...
Definition: SixDOFConstraint.h:40
#define ICLPhysics_API
Definition: CompatMacros.h:181
This class combines a movable but rigid physics object and it's graphical representation in ICL.
Definition: RigidObject.h:46
Base Class for constraints.
Definition: Constraint.h:41