point_click_publisher_plugin.cpp
Go to the documentation of this file.
1 // *****************************************************************************
2 //
3 // Copyright (c) 2014, Southwest Research Institute® (SwRI®)
4 // All rights reserved.
5 //
6 // Redistribution and use in source and binary forms, with or without
7 // modification, are permitted provided that the following conditions are met:
8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // * Neither the name of Southwest Research Institute® (SwRI®) nor the
14 // names of its contributors may be used to endorse or promote products
15 // derived from this software without specific prior written permission.
16 //
17 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 // ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
21 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
26 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 //
28 // *****************************************************************************
29 
31 #include <geometry_msgs/PointStamped.h>
34 
35 #include <boost/shared_ptr.hpp>
36 
37 // Declare plugin
40 
41 namespace mapviz_plugins
42 {
43  PointClickPublisherPlugin::PointClickPublisherPlugin() :
44  config_widget_(new QWidget()),
45  canvas_(NULL)
46  {
47  ui_.setupUi(config_widget_);
48 
49  connect(&click_filter_, SIGNAL(pointClicked(const QPointF&)),
50  this, SLOT(pointClicked(const QPointF&)));
51  connect(ui_.topic, SIGNAL(textEdited(const QString&)),
52  this, SLOT(topicChanged(const QString&)));
53 
54  frame_timer_.start(1000);
55  connect(&frame_timer_, SIGNAL(timeout()), this, SLOT(updateFrames()));
56  }
57 
59  {
60  if (canvas_)
61  {
62  canvas_->removeEventFilter(&click_filter_);
63  }
64  }
65 
66  bool PointClickPublisherPlugin::Initialize(QGLWidget* canvas)
67  {
68  canvas_ = static_cast<mapviz::MapCanvas*>(canvas);
69  canvas_->installEventFilter(&click_filter_);
70 
71  PrintInfo("Ready.");
72 
73  return true;
74  }
75 
76  void PointClickPublisherPlugin::Draw(double x, double y, double scale)
77  {
78  }
79 
80  void PointClickPublisherPlugin::LoadConfig(const YAML::Node& node, const std::string& path)
81  {
82  std::string tmp;
83  if (swri_yaml_util::FindValue(node, "topic"))
84  {
85  node["topic"] >> tmp;
86  ui_.topic->setText(QString(tmp.c_str()));
87  topicChanged(ui_.topic->text());
88  }
89 
90  if (swri_yaml_util::FindValue(node, "output_frame"))
91  {
92  node["output_frame"] >> tmp;
93  ui_.outputframe->addItem(QString(tmp.c_str()));
94  }
95  }
96 
97  void PointClickPublisherPlugin::SaveConfig(YAML::Emitter& emitter, const std::string& path)
98  {
99  emitter << YAML::Key << "topic" << YAML::Value << ui_.topic->text().toStdString();
100  emitter << YAML::Key << "output_frame" << YAML::Value << ui_.outputframe->currentText().toStdString();
101  }
102 
104  {
105  config_widget_->setParent(parent);
106 
107  return config_widget_;
108  }
109 
110 
111  void PointClickPublisherPlugin::pointClicked(const QPointF& point)
112  {
113  QPointF transformed = canvas_->MapGlCoordToFixedFrame(point);
114 
115  std::string output_frame = ui_.outputframe->currentText().toStdString();
116 
117  if (target_frame_ != output_frame)
118  {
120  tf::Point tfPoint(transformed.x(), transformed.y(), 0.0);
121  if (tf_manager_.GetTransform(output_frame, target_frame_, tf))
122  {
123  tfPoint = tf * tfPoint;
124  }
125  else
126  {
127  std::stringstream error;
128  error << "Unable to find transform from " << target_frame_ << " to " << output_frame << ".";
129  PrintError(error.str());
130  return;
131  }
132  transformed.setX(tfPoint.x());
133  transformed.setY(tfPoint.y());
134  }
135 
136  std::stringstream ss;
137  ss << "Point in " << output_frame.c_str() << ": " << transformed.x() << "," << transformed.y();
138  PrintInfo(ss.str());
139 
140  boost::shared_ptr<geometry_msgs::PointStamped> stamped = boost::make_shared<geometry_msgs::PointStamped>();
141  stamped->header.frame_id = output_frame;
142  stamped->header.stamp = ros::Time::now();
143  stamped->point.x = transformed.x();
144  stamped->point.y = transformed.y();
145  stamped->point.z = 0.0;
146 
147  point_publisher_.publish(stamped);
148  }
149 
151  {
153 
154  // We override this method so that we can initialize our publisher after
155  // our node has been set, ensuring that it's in mapviz's namespace.
156  topicChanged(ui_.topic->text());
157  }
158 
159  void PointClickPublisherPlugin::PrintError(const std::string& message)
160  {
161  PrintErrorHelper(ui_.status, message);
162  }
163 
164  void PointClickPublisherPlugin::PrintInfo(const std::string& message)
165  {
166  PrintInfoHelper(ui_.status, message);
167  }
168 
169  void PointClickPublisherPlugin::PrintWarning(const std::string& message)
170  {
171  PrintWarningHelper(ui_.status, message);
172  }
173 
174 
175  void PointClickPublisherPlugin::topicChanged(const QString& topic)
176  {
177  std::stringstream ss;
178  ss << "Publishing points to topic: " << topic.toStdString().c_str();
179  PrintInfo(ss.str());
180 
181  if (!topic.isEmpty())
182  {
183  point_publisher_ = node_.advertise<geometry_msgs::PointStamped>(topic.toStdString(), 1000);
184  }
185  }
186 
188  {
189  std::vector<std::string> frames;
190  tf_->getFrameStrings(frames);
191 
192  bool supports_wgs84 = tf_manager_.SupportsTransform(
195 
196  if (supports_wgs84)
197  {
198  frames.push_back(swri_transform_util::_wgs84_frame);
199  }
200 
201  if (ui_.outputframe->count() >= 0 &&
202  static_cast<size_t>(ui_.outputframe->count()) == frames.size())
203  {
204  bool changed = false;
205  for (size_t i = 0; i < frames.size(); i++)
206  {
207  if (frames[i] != ui_.outputframe->itemText(static_cast<int>(i)).toStdString())
208  {
209  changed = true;
210  }
211  }
212 
213  if (!changed)
214  return;
215  }
216 
217  std::string current_output = ui_.outputframe->currentText().toStdString();
218 
219  ui_.outputframe->clear();
220  for (size_t i = 0; i < frames.size(); i++)
221  {
222  ui_.outputframe->addItem(frames[i].c_str());
223  }
224 
225  if (current_output != "")
226  {
227  int index = ui_.outputframe->findText(current_output.c_str());
228  if (index < 0)
229  {
230  ui_.outputframe->addItem(current_output.c_str());
231  }
232 
233  index = ui_.outputframe->findText(current_output.c_str());
234  ui_.outputframe->setCurrentIndex(index);
235  }
236  }
237 }
void SaveConfig(YAML::Emitter &emitter, const std::string &path)
#define NULL
QPointF MapGlCoordToFixedFrame(const QPointF &point)
swri_transform_util::TransformManager tf_manager_
static const std::string _wgs84_frame
virtual void SetNode(const ros::NodeHandle &node)
ros::NodeHandle node_
void publish(const boost::shared_ptr< M > &message) const
virtual void SetNode(const ros::NodeHandle &node)
static void PrintWarningHelper(QLabel *status_label, const std::string &message, double throttle=0.0)
static void PrintErrorHelper(QLabel *status_label, const std::string &message, double throttle=0.0)
std::string target_frame_
static void PrintInfoHelper(QLabel *status_label, const std::string &message, double throttle=0.0)
void Draw(double x, double y, double scale)
void LoadConfig(const YAML::Node &node, const std::string &path)
static const std::string _local_xy_frame
TFSIMD_FORCE_INLINE const tfScalar & x() const
bool SupportsTransform(const std::string &target_frame, const std::string &source_frame) const
bool FindValue(const YAML::Node &node, const std::string &name)
TFSIMD_FORCE_INLINE const tfScalar & y() const
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
virtual void PrintError(const std::string &message)
virtual void PrintInfo(const std::string &message)
bool GetTransform(const std::string &target_frame, const std::string &source_frame, const ros::Time &time, Transform &transform) const
virtual void PrintWarning(const std::string &message)
static Time now()
boost::shared_ptr< tf::TransformListener > tf_
#define PLUGINLIB_EXPORT_CLASS(class_type, base_class_type)


mapviz_plugins
Author(s): Marc Alban
autogenerated on Thu Jun 6 2019 19:25:16