catchrobo2022 mbed LPC1768 メインプログラム
Dependencies: mbed
PointsArray.h
00001 #ifndef _ROS_jsk_recognition_msgs_PointsArray_h 00002 #define _ROS_jsk_recognition_msgs_PointsArray_h 00003 00004 #include <stdint.h> 00005 #include <string.h> 00006 #include <stdlib.h> 00007 #include "ros/msg.h" 00008 #include "std_msgs/Header.h" 00009 #include "sensor_msgs/PointCloud2.h" 00010 00011 namespace jsk_recognition_msgs 00012 { 00013 00014 class PointsArray : public ros::Msg 00015 { 00016 public: 00017 typedef std_msgs::Header _header_type; 00018 _header_type header; 00019 uint32_t cloud_list_length; 00020 typedef sensor_msgs::PointCloud2 _cloud_list_type; 00021 _cloud_list_type st_cloud_list; 00022 _cloud_list_type * cloud_list; 00023 00024 PointsArray(): 00025 header(), 00026 cloud_list_length(0), cloud_list(NULL) 00027 { 00028 } 00029 00030 virtual int serialize(unsigned char *outbuffer) const 00031 { 00032 int offset = 0; 00033 offset += this->header.serialize(outbuffer + offset); 00034 *(outbuffer + offset + 0) = (this->cloud_list_length >> (8 * 0)) & 0xFF; 00035 *(outbuffer + offset + 1) = (this->cloud_list_length >> (8 * 1)) & 0xFF; 00036 *(outbuffer + offset + 2) = (this->cloud_list_length >> (8 * 2)) & 0xFF; 00037 *(outbuffer + offset + 3) = (this->cloud_list_length >> (8 * 3)) & 0xFF; 00038 offset += sizeof(this->cloud_list_length); 00039 for( uint32_t i = 0; i < cloud_list_length; i++){ 00040 offset += this->cloud_list[i].serialize(outbuffer + offset); 00041 } 00042 return offset; 00043 } 00044 00045 virtual int deserialize(unsigned char *inbuffer) 00046 { 00047 int offset = 0; 00048 offset += this->header.deserialize(inbuffer + offset); 00049 uint32_t cloud_list_lengthT = ((uint32_t) (*(inbuffer + offset))); 00050 cloud_list_lengthT |= ((uint32_t) (*(inbuffer + offset + 1))) << (8 * 1); 00051 cloud_list_lengthT |= ((uint32_t) (*(inbuffer + offset + 2))) << (8 * 2); 00052 cloud_list_lengthT |= ((uint32_t) (*(inbuffer + offset + 3))) << (8 * 3); 00053 offset += sizeof(this->cloud_list_length); 00054 if(cloud_list_lengthT > cloud_list_length) 00055 this->cloud_list = (sensor_msgs::PointCloud2*)realloc(this->cloud_list, cloud_list_lengthT * sizeof(sensor_msgs::PointCloud2)); 00056 cloud_list_length = cloud_list_lengthT; 00057 for( uint32_t i = 0; i < cloud_list_length; i++){ 00058 offset += this->st_cloud_list.deserialize(inbuffer + offset); 00059 memcpy( &(this->cloud_list[i]), &(this->st_cloud_list), sizeof(sensor_msgs::PointCloud2)); 00060 } 00061 return offset; 00062 } 00063 00064 virtual const char * getType(){ return "jsk_recognition_msgs/PointsArray"; }; 00065 virtual const char * getMD5(){ return "0aa7e57c9da77fc1a0d8277bba5672b1"; }; 00066 00067 }; 00068 00069 } 00070 #endif
Generated on Mon Sep 26 2022 13:47:03 by
1.7.2