RotateInDegrees.cpp
Go to the documentation of this file.
1 /*
2  * This file is part of ArmarX.
3  *
4  * ArmarX is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 as
6  * published by the Free Software Foundation.
7  *
8  * ArmarX is distributed in the hope that it will be useful, but
9  * WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program. If not, see <http://www.gnu.org/licenses/>.
15  *
16  * @package RobotSkillTemplates::PlatformGroup
17  * @author Pascal Weiner ( pascal dot weiner at kit dot edu )
18  * @date 2018
19  * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
20  * GNU General Public License
21  */
22 
23 #include "RotateInDegrees.h"
24 
25 //#include <ArmarXCore/core/time/TimeUtil.h>
26 //#include <ArmarXCore/observers/variant/DatafieldRef.h>
27 
28 using namespace armarx;
29 using namespace PlatformGroup;
30 
31 // DO NOT EDIT NEXT LINE
32 RotateInDegrees::SubClassRegistry RotateInDegrees::Registry(RotateInDegrees::GetName(), &RotateInDegrees::CreateInstance);
33 
35 {
36  //calc degree to radian
37  float radian = ((float)in.getDegrees()) / 180.0 * M_PI;
38  if (in.getDirection() == "right")
39  {
40  radian = -radian;
41  }
42  else if (!(in.getDirection() == "left"))
43  {
44  ARMARX_WARNING << in.getDirection() << " is not a valid direction. Valid directions are: left, right";
45  return;
46  }
47  Vector3 rotation(0.0f, 0.0f, radian);
48  local.setRotation(rotation);
49 }
50 
51 //void RotateInDegrees::run()
52 //{
53 // // put your user code for the execution-phase here
54 // // runs in seperate thread, thus can do complex operations
55 // // should check constantly whether isRunningTaskStopped() returns true
56 //
57 //// uncomment this if you need a continous run function. Make sure to use sleep or use blocking wait to reduce cpu load.
58 // while (!isRunningTaskStopped()) // stop run function if returning true
59 // {
60 // // do your calculations
61 // }
62 //}
63 
64 //void RotateInDegrees::onBreak()
65 //{
66 // // put your user code for the breaking point here
67 // // execution time should be short (<100ms)
68 //}
69 
71 {
72  // put your user code for the exit point here
73  // execution time should be short (<100ms)
74 }
75 
76 
77 // DO NOT EDIT NEXT FUNCTION
79 {
80  return XMLStateFactoryBasePtr(new RotateInDegrees(stateData));
81 }
82 
RotateInDegrees.h
armarx::PlatformGroup::RotateInDegrees::RotateInDegrees
RotateInDegrees(const XMLStateConstructorParams &stateData)
Definition: RotateInDegrees.h:34
armarx::XMLStateConstructorParams
Definition: XMLState.h:50
armarx::PlatformGroup::RotateInDegrees::onEnter
void onEnter() override
Definition: RotateInDegrees.cpp:34
armarx::PlatformGroup::RotateInDegrees::Registry
static SubClassRegistry Registry
Definition: RotateInDegrees.h:47
IceInternal::Handle
Definition: forward_declarations.h:8
armarx::PlatformGroup::RotateInDegrees::onExit
void onExit() override
Definition: RotateInDegrees.cpp:70
M_PI
#define M_PI
Definition: MathTools.h:17
armarx::PlatformGroup::RotateInDegrees::CreateInstance
static XMLStateFactoryBasePtr CreateInstance(XMLStateConstructorParams stateData)
Definition: RotateInDegrees.cpp:78
armarx::Vector3
The Vector3 class.
Definition: Pose.h:112
armarx::XMLStateFactoryBasePtr
IceInternal::Handle< XMLStateFactoryBase > XMLStateFactoryBasePtr
Definition: XMLState.h:65
float
#define float
Definition: 16_Level.h:22
ARMARX_WARNING
#define ARMARX_WARNING
Definition: Logging.h:186
armarx
This file offers overloads of toIce() and fromIce() functions for STL container types.
Definition: ArmarXTimeserver.cpp:28