overlay_image_display.cpp
Go to the documentation of this file.
1 // -*- mode: c++; -*-
2 /*********************************************************************
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2014, JSK Lab
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * * Neither the name of the JSK Lab nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *********************************************************************/
35 
36 #include "overlay_image_display.h"
37 
38 #include <OGRE/OgreMaterialManager.h>
39 #include <OGRE/OgreTextureManager.h>
40 #include <OGRE/OgreTexture.h>
41 #include <OGRE/OgreHardwarePixelBuffer.h>
42 #include <OGRE/OgreTechnique.h>
43 
45 #include <cv_bridge/cv_bridge.h>
47 
48 namespace jsk_rviz_plugins
49 {
50 
52  : Display(), width_(128), height_(128), left_(128), top_(128), alpha_(0.8),
53  is_msg_available_(false), require_update_(false), overwrite_alpha_(false)
54  {
55  // setup properties
56  update_topic_property_ = new rviz::RosTopicProperty(
57  "Topic", "",
58  ros::message_traits::datatype<sensor_msgs::Image>(),
59  "sensor_msgs::Image topic to subscribe to.",
60  this, SLOT( updateTopic() ));
61  transport_hint_property_ = new ImageTransportHintsProperty("transport hint",
62  "transport hint to subscribe topic",
63  this, SLOT(updateTopic()));
64  keep_aspect_ratio_property_ = new rviz::BoolProperty("keep aspect ratio", false,
65  "keep aspect ratio of original image",
66  this, SLOT(updateKeepAspectRatio()));
67  width_property_ = new rviz::IntProperty("width", 128,
68  "width of the image window",
69  this, SLOT(updateWidth()));
70  height_property_ = new rviz::IntProperty("height", 128,
71  "height of the image window",
72  this, SLOT(updateHeight()));
73  left_property_ = new rviz::IntProperty("left", 128,
74  "left of the image window",
75  this, SLOT(updateLeft()));
76  top_property_ = new rviz::IntProperty("top", 128,
77  "top of the image window",
78  this, SLOT(updateTop()));
79  alpha_property_ = new rviz::FloatProperty("alpha", 0.8,
80  "alpha belnding value",
81  this, SLOT(updateAlpha()));
82  overwrite_alpha_property_ = new rviz::BoolProperty("overwrite alpha value", false,
83  "overwrite alpha value by alpha property "
84  "and ignore alpha channel of the image",
85  this, SLOT(updateOverwriteAlpha()));
86  }
87 
89  {
94  delete width_property_;
95  delete height_property_;
96  delete left_property_;
97  delete top_property_;
98  delete alpha_property_;
99  }
100 
102  {
103  ros::NodeHandle nh;
104 #if ROS_VERSION_MINIMUM(1,12,0)
105  it_ = std::shared_ptr<image_transport::ImageTransport>(new image_transport::ImageTransport(nh));
106 #else
108 #endif
109 
110  updateWidth();
111  updateHeight();
114  updateTop();
115  updateLeft();
116  updateAlpha();
117  updateTopic();
118  }
119 
121  {
122  if (overlay_) {
123  overlay_->show();
124  }
125  subscribe();
126  }
128  {
129  if (overlay_) {
130  overlay_->hide();
131  }
132  unsubscribe();
133  }
134 
136  {
137  sub_.shutdown();
138  // clear clear clear...
139  }
140 
142  {
143  if (isEnabled()) {
144  std::string topic_name = update_topic_property_->getTopicStd();
145 
146  if (topic_name.length() > 0 && topic_name != "/") {
147  const image_transport::TransportHints transport_hint =
149  sub_ = it_->subscribe(topic_name, 1, &OverlayImageDisplay::processMessage, this,
150  transport_hint);
151  }
152  }
153  }
154 
156  const sensor_msgs::Image::ConstPtr& msg)
157  {
158  msg_ = msg;
160  require_update_ = true;
161  if ((width_property_->getInt() < 0) || (height_property_->getInt() < 0) || keep_aspect_ratio_) {
162  // automatically setup display size
163  updateWidth();
164  updateHeight();
165  }
166  }
167 
168 
169  void OverlayImageDisplay::update(float wall_dt, float ros_dt)
170  {
171  if (!isEnabled()) {
172  return;
173  }
174 
176  if (!overlay_) {
177  static int count = 0;
179  ss << "OverlayImageDisplayObject" << count++;
180  overlay_.reset(new OverlayObject(ss.str()));
181  overlay_->show();
182  }
183  overlay_->updateTextureSize(msg_->width, msg_->height);
184  // When aspect_ratio being kept, the size is specified by width;
186  setImageSize();
188  require_update_ = false;
189  }
190  if (overlay_) {
191  overlay_->setDimensions(width_, height_);
192  overlay_->setPosition(left_, top_);
193  }
194  }
195 
197  {
198  try
199  {
200  if (msg_->width == 0 || msg_->height == 0) {
201  // image width/height and texture width/height should be same
202  // but they are not when input image width/height is 0
203  return;
204  }
205  else {
206  cv::Mat mat; // mat should be BGRA8 image
207 
208  if ((msg_->encoding == sensor_msgs::image_encodings::BGRA8 ||
210  !overwrite_alpha_) {
213  cv_ptr->image.copyTo(mat);
214  } else {
215  // If the image does not have alpha channel, use alpha_ value.
216  const cv_bridge::CvImagePtr cv_ptr =
218  const cv::Mat bgr_image = cv_ptr->image;
219  std::vector<cv::Mat> channels;
220  // Split BGR image to each channel because cv::merge requires 4 images to create
221  // B-G-R-A image. The each 4 image represents each channel.
222  cv::split(bgr_image, channels);
223  // Create single alpha channel image
224  const cv::Mat alpha(bgr_image.rows, bgr_image.cols, CV_8UC1,
225  cv::Scalar(alpha_ * 255.0));
226  channels.push_back(alpha);
227  cv::merge(channels, mat);
228  }
229 
230  ScopedPixelBuffer buffer = overlay_->getBuffer();
231  QImage Hud = buffer.getQImage(*overlay_);
232  // QImage created from ScopedPixelBuffer has no padding between each line.
233  memcpy(Hud.scanLine(0), mat.data, mat.cols * mat.rows * mat.elemSize());
234  }
235  }
236  catch (cv_bridge::Exception& e)
237  {
238  ROS_ERROR("cv_bridge exception: %s", e.what());
239  }
240  }
241 
243  {
244  unsubscribe();
245  subscribe();
246  }
247 
249  {
250  if (width_ == -1) {
251  if (is_msg_available_) {
252  width_ = msg_->width;
253  }
254  else {
255  width_ = 128;
256  }
257  }
258 
259  if (height_ == -1) {
260  if (is_msg_available_) {
261  height_ = msg_->height;
262  }
263  else {
264  height_ = 128;
265  }
266  }
267 
269  // When aspect_ratio being kept, the size is specified by width;
270  double aspect_ratio = msg_->height / (double)msg_->width;
271  int height_from_width = std::ceil(width_ * aspect_ratio);
272  height_ = height_from_width;
273  }
274 
275  }
276 
278  {
279  boost::mutex::scoped_lock lock(mutex_);
281  require_update_ = true;
282  }
283 
285  {
286  boost::mutex::scoped_lock lock(mutex_);
288  require_update_ = true;
289  }
290 
292  {
293  boost::mutex::scoped_lock lock(mutex_);
295  }
296 
298  {
299  boost::mutex::scoped_lock lock(mutex_);
301  }
302 
304  {
305  boost::mutex::scoped_lock lock(mutex_);
307  }
308 
310  {
311  boost::mutex::scoped_lock lock(mutex_);
313  require_update_ = true;
314  }
315 
317  {
318  boost::mutex::scoped_lock lock(mutex_);
320  require_update_ = true;
321  }
322 
324  {
325  return (top_ < y && top_ + height_ > y &&
326  left_ < x && left_ + width_ > x);
327  }
328 
330  {
331  top_ = y;
332  left_ = x;
333  }
334 
336  {
339  }
340 
341 }
342 
jsk_rviz_plugins::OverlayImageDisplay::~OverlayImageDisplay
virtual ~OverlayImageDisplay()
Definition: overlay_image_display.cpp:120
jsk_rviz_plugins::OverlayImageDisplay::setPosition
virtual void setPosition(int x, int y)
Definition: overlay_image_display.cpp:367
rviz::BoolProperty::getBool
virtual bool getBool() const
rviz::Display::isEnabled
bool isEnabled() const
rviz::RosTopicProperty
overlay_image_display.h
rviz::Property::setHidden
virtual void setHidden(bool hidden)
msg
msg
jsk_rviz_plugins::OverlayDiagnosticDisplay::left_property_
rviz::IntProperty * left_property_
Definition: overlay_diagnostic_display.h:204
image_encodings.h
jsk_rviz_plugins::OverlayImageDisplay::updateWidth
void updateWidth()
Definition: overlay_image_display.cpp:309
image_transport::ImageTransport
jsk_rviz_plugins::OverlayDiagnosticDisplay::top_property_
rviz::IntProperty * top_property_
Definition: overlay_diagnostic_display.h:203
jsk_rviz_plugins::ImageTransportHintsProperty::getTransportHints
image_transport::TransportHints getTransportHints()
Definition: image_transport_hints_property.cpp:17
boost::shared_ptr< image_transport::ImageTransport >
jsk_rviz_plugins::OverlayImageDisplay::setImageSize
virtual void setImageSize()
Definition: overlay_image_display.cpp:280
jsk_rviz_plugins::OverlayImageDisplay::width_
int width_
Definition: overlay_image_display.h:151
jsk_rviz_plugins::ScopedPixelBuffer
Definition: overlay_utils.h:101
rviz_mouse_point_to_tablet.lock
lock
Definition: rviz_mouse_point_to_tablet.py:11
rviz::BoolProperty
jsk_rviz_plugins::OverlayImageDisplay::msg_
sensor_msgs::Image::ConstPtr msg_
Definition: overlay_image_display.h:159
sensor_msgs::image_encodings::RGBA8
const std::string RGBA8
jsk_rviz_plugins::OverlayImageDisplay::redraw
virtual void redraw()
Definition: overlay_image_display.cpp:228
jsk_rviz_plugins::OverlayImageDisplay::transport_hint_property_
ImageTransportHintsProperty * transport_hint_property_
Definition: overlay_image_display.h:143
jsk_rviz_plugins::OverlayImageDisplay::updateTopic
void updateTopic()
Definition: overlay_image_display.cpp:274
jsk_rviz_plugins::OverlayImageDisplay::subscribe
virtual void subscribe()
Definition: overlay_image_display.cpp:173
jsk_rviz_plugins::OverlayImageDisplay::updateOverwriteAlpha
void updateOverwriteAlpha()
Definition: overlay_image_display.cpp:348
jsk_rviz_plugins::OverlayImageDisplay::alpha_
double alpha_
Definition: overlay_image_display.h:152
rviz::UniformStringStream
cv_bridge::Exception
jsk_rviz_plugins::OverlayImageDisplay::alpha_property_
rviz::FloatProperty * alpha_property_
Definition: overlay_image_display.h:149
jsk_rviz_plugins::OverlayImageDisplay::updateAlpha
void updateAlpha()
Definition: overlay_image_display.cpp:335
jsk_rviz_plugins::OverlayImageDisplay
Definition: overlay_image_display.h:93
jsk_rviz_plugins::OverlayImageDisplay::updateKeepAspectRatio
void updateKeepAspectRatio()
Definition: overlay_image_display.cpp:341
rviz::Display
jsk_rviz_plugins::OverlayImageDisplay::require_update_
bool require_update_
Definition: overlay_image_display.h:161
rviz::FloatProperty
rviz::IntProperty::setValue
bool setValue(const QVariant &new_value) override
class_list_macros.h
jsk_rviz_plugins::OverlayImageDisplay::height_property_
rviz::IntProperty * height_property_
Definition: overlay_image_display.h:146
jsk_rviz_plugins::OverlayImageDisplay::updateLeft
void updateLeft()
Definition: overlay_image_display.cpp:329
jsk_rviz_plugins::OverlayImageDisplay::is_msg_available_
bool is_msg_available_
Definition: overlay_image_display.h:160
jsk_rviz_plugins::OverlayImageDisplay::unsubscribe
virtual void unsubscribe()
Definition: overlay_image_display.cpp:167
rviz::FloatProperty::getFloat
virtual float getFloat() const
cv_bridge::toCvCopy
CvImagePtr toCvCopy(const sensor_msgs::CompressedImage &source, const std::string &encoding=std::string())
jsk_rviz_plugins::OverlayImageDisplay::height_
int height_
Definition: overlay_image_display.h:151
jsk_rviz_plugins::OverlayImageDisplay::left_property_
rviz::IntProperty * left_property_
Definition: overlay_image_display.h:147
jsk_rviz_plugins::OverlayImageDisplay::width_property_
rviz::IntProperty * width_property_
Definition: overlay_image_display.h:145
jsk_rviz_plugins::OverlayImageDisplay::processMessage
virtual void processMessage(const sensor_msgs::Image::ConstPtr &msg)
Definition: overlay_image_display.cpp:187
bounding_box_sample.x
x
Definition: bounding_box_sample.py:26
jsk_rviz_plugins::OverlayImageDisplay::movePosition
virtual void movePosition(int x, int y)
Definition: overlay_image_display.cpp:361
jsk_rviz_plugins::OverlayDiagnosticDisplay::alpha_property_
rviz::FloatProperty * alpha_property_
Definition: overlay_diagnostic_display.h:205
jsk_rviz_plugins::OverlayImageDisplay::overlay_
OverlayObject::Ptr overlay_
Definition: overlay_image_display.h:141
jsk_rviz_plugins::OverlayImageDisplay::it_
boost::shared_ptr< image_transport::ImageTransport > it_
Definition: overlay_image_display.h:156
contact_state_marker.alpha
alpha
Definition: contact_state_marker.py:90
jsk_rviz_plugins::OverlayImageDisplay::updateHeight
void updateHeight()
Definition: overlay_image_display.cpp:316
jsk_rviz_plugins::OverlayImageDisplay::keep_aspect_ratio_
bool keep_aspect_ratio_
Definition: overlay_image_display.h:162
bounding_box_sample.y
y
Definition: bounding_box_sample.py:27
jsk_rviz_plugins::OverlayDiagnosticDisplay::updateAlpha
virtual void updateAlpha()
Definition: overlay_diagnostic_display.cpp:699
jsk_rviz_plugins::OverlayImageDisplay::update
virtual void update(float wall_dt, float ros_dt)
Definition: overlay_image_display.cpp:201
jsk_rviz_plugins::OverlayImageDisplay::mutex_
boost::mutex mutex_
Definition: overlay_image_display.h:137
rviz::RosTopicProperty::getTopicStd
std::string getTopicStd() const
jsk_rviz_plugins::OverlayImageDisplay::updateTop
void updateTop()
Definition: overlay_image_display.cpp:323
PLUGINLIB_EXPORT_CLASS
PLUGINLIB_EXPORT_CLASS(jsk_rviz_plugins::PictogramArrayDisplay, rviz::Display)
jsk_rviz_plugins::OverlayImageDisplay::keep_aspect_ratio_property_
rviz::BoolProperty * keep_aspect_ratio_property_
Definition: overlay_image_display.h:144
jsk_rviz_plugins::OverlayImageDisplay::update_topic_property_
rviz::RosTopicProperty * update_topic_property_
Definition: overlay_image_display.h:142
sensor_msgs::image_encodings::BGRA8
const std::string BGRA8
jsk_rviz_plugins::OverlayDiagnosticDisplay::updateTop
virtual void updateTop()
Definition: overlay_diagnostic_display.cpp:704
jsk_rviz_plugins::OverlayImageDisplay::onEnable
virtual void onEnable()
Definition: overlay_image_display.cpp:152
point_test.count
int count
Definition: point_test.py:15
cv_bridge.h
jsk_rviz_plugins::OverlayImageDisplay::sub_
image_transport::Subscriber sub_
Definition: overlay_image_display.h:158
ROS_ERROR
#define ROS_ERROR(...)
jsk_rviz_plugins::ScopedPixelBuffer::getQImage
virtual QImage getQImage(unsigned int width, unsigned int height)
Definition: overlay_utils.cpp:89
jsk_rviz_plugins::OverlayImageDisplay::overwrite_alpha_
bool overwrite_alpha_
Definition: overlay_image_display.h:163
jsk_rviz_plugins::OverlayImageDisplay::isInRegion
virtual bool isInRegion(int x, int y)
Definition: overlay_image_display.cpp:355
rviz::IntProperty::getInt
virtual int getInt() const
jsk_rviz_plugins::OverlayImageDisplay::top_property_
rviz::IntProperty * top_property_
Definition: overlay_image_display.h:148
jsk_rviz_plugins::OverlayImageDisplay::OverlayImageDisplay
OverlayImageDisplay()
Definition: overlay_image_display.cpp:83
sensor_msgs::image_encodings::BGR8
const std::string BGR8
image_transport::TransportHints
jsk_rviz_plugins::OverlayImageDisplay::top_
int top_
Definition: overlay_image_display.h:151
jsk_rviz_plugins::OverlayDiagnosticDisplay::updateLeft
virtual void updateLeft()
Definition: overlay_diagnostic_display.cpp:709
jsk_rviz_plugins::OverlayImageDisplay::onDisable
virtual void onDisable()
Definition: overlay_image_display.cpp:159
jsk_rviz_plugins::OverlayObject
Definition: overlay_utils.h:121
jsk_rviz_plugins
Definition: __init__.py:1
ros::NodeHandle
jsk_rviz_plugins::OverlayImageDisplay::overwrite_alpha_property_
rviz::BoolProperty * overwrite_alpha_property_
Definition: overlay_image_display.h:150
uniform_string_stream.h
rviz::IntProperty
jsk_rviz_plugins::OverlayImageDisplay::onInitialize
virtual void onInitialize()
Definition: overlay_image_display.cpp:133
jsk_rviz_plugins::OverlayImageDisplay::left_
int left_
Definition: overlay_image_display.h:151
image_transport::Subscriber::shutdown
void shutdown()


jsk_rviz_plugins
Author(s): Kei Okada , Yohei Kakiuchi , Shohei Fujii , Ryohei Ueda
autogenerated on Tue Dec 10 2024 03:48:24