00001 /* 00002 * Copyright (c) 2017 Roboception GmbH 00003 * All rights reserved 00004 * 00005 * Author: Heiko Hirschmueller 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions are met: 00009 * 00010 * 1. Redistributions of source code must retain the above copyright notice, 00011 * this list of conditions and the following disclaimer. 00012 * 00013 * 2. Redistributions in binary form must reproduce the above copyright notice, 00014 * this list of conditions and the following disclaimer in the documentation 00015 * and/or other materials provided with the distribution. 00016 * 00017 * 3. Neither the name of the copyright holder nor the names of its contributors 00018 * may be used to endorse or promote products derived from this software without 00019 * specific prior written permission. 00020 * 00021 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00022 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00023 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00024 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00025 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00026 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00027 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00028 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00029 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00030 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00031 * POSSIBILITY OF SUCH DAMAGE. 00032 */ 00033 00034 #include "confidence_publisher.h" 00035 00036 #include <rc_genicam_api/pixel_formats.h> 00037 00038 #include <sensor_msgs/image_encodings.h> 00039 00040 namespace rc 00041 { 00042 00043 ConfidencePublisher::ConfidencePublisher(ros::NodeHandle &nh, 00044 std::string frame_id_prefix) 00045 : GenICam2RosPublisher(frame_id_prefix) 00046 { 00047 pub=nh.advertise<sensor_msgs::Image>("confidence", 1); 00048 } 00049 00050 bool ConfidencePublisher::used() 00051 { 00052 return pub.getNumSubscribers() > 0; 00053 } 00054 00055 void ConfidencePublisher::publish(const rcg::Buffer *buffer, uint64_t pixelformat) 00056 { 00057 if (pub.getNumSubscribers() > 0 && pixelformat == Confidence8) 00058 { 00059 // create image and initialize header 00060 00061 sensor_msgs::ImagePtr im=boost::make_shared<sensor_msgs::Image>(); 00062 00063 const uint64_t freq=1000000000ul; 00064 uint64_t time=buffer->getTimestampNS(); 00065 00066 im->header.seq=seq++; 00067 im->header.stamp.sec=time/freq; 00068 im->header.stamp.nsec=time-freq*im->header.stamp.sec; 00069 im->header.frame_id=frame_id; 00070 00071 // set image size 00072 00073 im->width=static_cast<uint32_t>(buffer->getWidth()); 00074 im->height=static_cast<uint32_t>(buffer->getHeight()); 00075 00076 // get pointer to image data in buffer 00077 00078 size_t px=buffer->getXPadding(); 00079 const uint8_t *ps=static_cast<const uint8_t *>(buffer->getBase())+buffer->getImageOffset(); 00080 00081 // convert image data 00082 00083 im->encoding=sensor_msgs::image_encodings::TYPE_32FC1; 00084 im->is_bigendian=rcg::isHostBigEndian(); 00085 im->step=im->width*sizeof(float); 00086 00087 im->data.resize(im->step*im->height); 00088 float *pt=reinterpret_cast<float *>(&im->data[0]); 00089 00090 float scale=1.0f/255.0f; 00091 00092 for (uint32_t k=0; k<im->height; k++) 00093 { 00094 for (uint32_t i=0; i<im->width; i++) 00095 { 00096 *pt++=scale **ps++; 00097 } 00098 00099 ps+=px; 00100 } 00101 00102 // publish message 00103 00104 pub.publish(im); 00105 } 00106 } 00107 00108 }