SelectObject.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::FindAndGraspObjectGroup
19 * @author Valerij Wittenbeck ( valerij dot wittenbeck at student dot 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 "SelectObject.h"
26
27using namespace armarx;
28using namespace FindAndGraspObjectGroup;
29
30// DO NOT EDIT NEXT LINE
31SelectObject::SubClassRegistry SelectObject::Registry(SelectObject::GetName(),
33
38
39void
41{
43
44 memoryx::ChannelRefBaseSequence objectChannelRefs =
45 context->objectMemoryObserver->getObjectInstances(getInput<ChannelRef>("objectChannel"));
46 memoryx::ChannelRefBaseSequence markerChannelRefs =
47 context->objectMemoryObserver->getObjectInstances(getInput<ChannelRef>("markerChannel"));
48 ARMARX_DEBUG << "objectChannel available: " << objectChannelRefs.size() << "; "
49 << "markerChannel available: " << markerChannelRefs.size();
50
51 if (objectChannelRefs.size() == 0 || markerChannelRefs.size() == 0)
52 {
53 ARMARX_IMPORTANT << "object or marker channel ref not available (yet?)" << flush;
55 return;
56 }
57
58 setOutput("objectInstanceChannel", objectChannelRefs.front());
59 setOutput("markerInstanceChannel", markerChannelRefs.front());
60
61 ARMARX_DEBUG << "SelectObjectsState::onEnter(): objectChannelRefs.front(): "
62 << objectChannelRefs.front() << " (to: setOutput())" << flush;
63 ARMARX_DEBUG << "SelectObjectsState::onEnter(): markerChannelRefs.front(): "
64 << markerChannelRefs.front() << " (to: setOutput())" << flush;
66
67 ARMARX_VERBOSE << "Done SelectObject::onEnter()" << flush;
68}
69
70void
75
76// DO NOT EDIT NEXT FUNCTION
77std::string
79{
80 return "SelectObject";
81}
82
83// DO NOT EDIT NEXT FUNCTION
memoryx::ObjectMemoryObserverInterfacePrx objectMemoryObserver
SelectObject(XMLStateConstructorParams stateData)
void onEnter() override
Virtual function, in which the behaviour of state is defined, when it is entered. Can be overridden,...
void onExit() override
Virtual function, in which the behaviour of state is defined, when it is exited. Can be overridden,...
static XMLStateFactoryBasePtr CreateInstance(XMLStateConstructorParams stateData)
ContextType * getContext() const
Definition StateBase.h:71
void removeTimeoutEvent(const ActionEventIdentifier &id)
ActionEventIdentifier setTimeoutEvent(int timeoutDurationMs, const EventPtr &evt)
Utility function to start a timer on the systemObserver and register an event on the conditionHandler...
EventPtr createEvent()
Utility function to create a new Event.
Definition StateUtil.h:63
void sendEvent(const EventPtr event, StateBasePtr eventProcessor=nullptr)
Function to send an event to a specific state from an onEnter()-function. Must not be called anywhere...
Definition StateUtil.cpp:40
void setOutput(std::string const &key, const Variant &value)
setOuput() sets an output parameter of this state.
Definition State.cpp:482
std::enable_if_t< std::is_base_of_v< VariantDataClass, T >, IceInternal::Handle< T > > getInput(const std::string &key) const
getInput can be used to access a specific input parameter.
Definition State.h:620
XMLStateTemplate(const XMLStateConstructorParams &params)
Definition XMLState.h:149
#define ARMARX_IMPORTANT
The logging level for always important information, but expected behaviour (in contrast to ARMARX_WAR...
Definition Logging.h:190
#define ARMARX_DEBUG
The logging level for output that is only interesting while debugging.
Definition Logging.h:184
#define ARMARX_VERBOSE
The logging level for verbose information.
Definition Logging.h:187
This file offers overloads of toIce() and fromIce() functions for STL container types.
const LogSender::manipulator flush
Definition LogSender.h:251
IceInternal::Handle< XMLStateFactoryBase > XMLStateFactoryBasePtr
Definition XMLState.h:64