HandGroupStatechartContext.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::HandGroup
19 * @author Simon Ottenhaus ( simon dot ottenhaus 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
26
27#include <SimoxUtility/algorithm/string/string_tools.h>
28
32
35
36using namespace armarx;
37
38namespace armarx::HandGroup
39{
40 void
42 {
43 // Register dependencies
44 // usingProxy(getProperty<std::string>("KinematicUnitName").getValue());
45 // usingProxy(getProperty<std::string>("KinematicUnitObserverName").getValue());
46 usingProxy(getProperty<std::string>("RobotStateComponentName").getValue());
47 // usingProxy(getProperty<std::string>("TCPControlUnitName").getValue());
48
49 const std::string handUnitNamesStr = getProperty<std::string>("HandUnitNames").getValue();
50 handUnitNames = simox::alg::split(handUnitNamesStr, ",");
51
52 for (std::string handUnitName : handUnitNames)
53 {
54 usingProxy(handUnitName);
55 }
56 }
57
58 void
60 {
61
62 // retrieve proxies
64 getProperty<std::string>("RobotStateComponentName").getValue());
65 // kinematicUnitPrx = getProxy<KinematicUnitInterfacePrx>(getProperty<std::string>("KinematicUnitName").getValue());
66 // kinematicUnitObserverPrx = getProxy<KinematicUnitObserverInterfacePrx>(getProperty<std::string>("KinematicUnitObserverName").getValue());
67 // tcpControlPrx = getProxy<TCPControlUnitInterfacePrx>(getProperty<std::string>("TCPControlUnitName").getValue());
68
69 // initialize remote robot
70 remoteRobot.reset(new RemoteRobot(robotStateComponent->getSynchronizedRobot()));
71
72 for (std::string handUnitName : handUnitNames)
73 {
74 HandUnitInterfacePrx prx = getProxy<HandUnitInterfacePrx>(handUnitName);
75 handUnits.insert(std::make_pair(prx->getHandName(), prx));
76 }
77 }
78
80 HandGroupStatechartContext::createPropertyDefinitions()
81 {
84 }
85} // namespace armarx::HandGroup
std::string getConfigIdentifier()
Retrieve config identifier for this component as set in constructor.
Definition Component.cpp:90
Property< PropertyType > getProperty(const std::string &name)
void onInitStatechartContext() override
onInitStatechartonInitStatechartContext can be implemented by subclasses
void onConnectStatechartContext() override
onConnectStatechartContext can be implemented by subclasses
bool usingProxy(const std::string &name, const std::string &endpoints="")
Registers a proxy for retrieval after initialization and adds it to the dependency list.
Ice::ObjectPrx getProxy(long timeoutMs=0, bool waitForScheduler=true) const
Returns the proxy of this object (optionally it waits for the proxy)
Mimics the behaviour of the VirtualRobot::Robot class while redirecting everything to an Ice proxy.
This file offers overloads of toIce() and fromIce() functions for STL container types.
IceUtil::Handle< class PropertyDefinitionContainer > PropertyDefinitionsPtr
PropertyDefinitions smart pointer type.