SelectNextLocation.cpp
Go to the documentation of this file.
1 /*
2  * This file is part of ArmarX.
3  *
4  * Copyright (C) 2014-2016, High Performance Humanoid Technologies (H2T), Karlsruhe Institute of Technology (KIT), all rights reserved.
5  *
6  * ArmarX is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  *
10  * ArmarX is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  *
18  * @package RobotSkillTemplates::ScanLocationGroup
19  * @author Manfred Kroehnert ( Manfred dot Kroehnert at kit dot edu )
20  * @date 2014
21  * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
22  * GNU General Public License
23  */
24 
25 #include "SelectNextLocation.h"
26 
27 using namespace armarx;
28 using namespace ScanLocationGroup;
29 
30 // DO NOT EDIT NEXT LINE
31 SelectNextLocation::SubClassRegistry
32  SelectNextLocation::Registry(SelectNextLocation::GetName(),
34 
37  SelectNextLocationGeneratedBase<SelectNextLocation>(stateData)
38 {
39 }
40 
41 void
43 {
44  ChannelRefPtr counterId = in.getLocationCounterId();
45  std::vector<armarx::FramedPositionPtr> locationList = in.getLocationList();
46 
47  int nextLocationIndex = counterId->getDataField("value")->getInt();
48  getSystemObserver()->incrementCounter(counterId);
49 
50  if (nextLocationIndex < (int)locationList.size())
51  {
52  out.setnextLocation(locationList.at(nextLocationIndex));
53  emitNextLocation();
54 
55  {
56  objpose::SignalHeadMovementInput input;
57  input.action = objpose::HeadMovementAction_Starting;
58  input.discardUpdatesIntervalMilliSeconds =
59  in.getObjectPoseStorageDiscardUpdatesIntervalMS();
60  getObjectPoseStorage()->signalHeadMovement(input);
61  }
62  }
63  else
64  {
65  out.setnextLocation(locationList.back());
66  emitNoLocation();
67  }
68 }
69 
70 void
72 {
73  // put your user code for the breaking point here
74  // execution time should be short (<100ms)
75 }
76 
77 void
79 {
80  // put your user code for the exit point here
81  // execution time should be short (<100ms)
82 }
83 
84 // DO NOT EDIT NEXT FUNCTION
87 {
88  return XMLStateFactoryBasePtr(new SelectNextLocation(stateData));
89 }
armarx::ScanLocationGroup::SelectNextLocation::Registry
static SubClassRegistry Registry
Definition: SelectNextLocation.h:43
armarx::XMLStateConstructorParams
Definition: XMLState.h:49
armarx::XMLStateFactoryBasePtr
IceInternal::Handle< XMLStateFactoryBase > XMLStateFactoryBasePtr
Definition: XMLState.h:64
IceInternal::Handle< ChannelRef >
armarx::ScanLocationGroup::SelectNextLocation::onBreak
void onBreak() override
Definition: SelectNextLocation.cpp:71
armarx::XMLStateTemplate
Class for legacy to stay compatible with old statecharts.
Definition: XMLState.h:146
armarx::aron::input
ReaderT::InputType & input
Definition: rw.h:12
SelectNextLocation.h
armarx::ScanLocationGroup::SelectNextLocation
Definition: SelectNextLocation.h:31
armarx::ScanLocationGroup::SelectNextLocation::CreateInstance
static XMLStateFactoryBasePtr CreateInstance(XMLStateConstructorParams stateData)
Definition: SelectNextLocation.cpp:86
armarx::ScanLocationGroup::SelectNextLocation::onExit
void onExit() override
Definition: SelectNextLocation.cpp:78
armarx::ScanLocationGroup::SelectNextLocation::SelectNextLocation
SelectNextLocation(XMLStateConstructorParams stateData)
Definition: SelectNextLocation.cpp:35
armarx::ScanLocationGroup::SelectNextLocation::onEnter
void onEnter() override
Definition: SelectNextLocation.cpp:42
armarx
This file offers overloads of toIce() and fromIce() functions for STL container types.
Definition: ArmarXTimeserver.cpp:27