oh_my_loam/main.cc

31 lines
964 B
C++
Raw Normal View History

2020-10-12 21:09:32 +08:00
#include <pcl_conversions/pcl_conversions.h>
#include <ros/ros.h>
#include <sensor_msgs/PointCloud2.h>
#include <functional>
#include "oh_my_loam.h"
void PointCloudHandler(const sensor_msgs::PointCloud2ConstPtr& msg,
oh_my_loam::OhMyLoam* const slam);
int main(int argc, char* argv[]) {
oh_my_loam::OhMyLoam slam;
slam.Init();
ros::init(argc, argv, "oh_my_loam");
ros::NodeHandle nh;
ros::Subscriber sub_point_cloud = nh.subscribe<sensor_msgs::PointCloud2>(
"/velodyne_points", 100,
std::bind(PointCloudHandler, std::placeholders::_1, &slam));
ros::spin();
return 0;
}
void PointCloudHandler(const sensor_msgs::PointCloud2ConstPtr& msg,
oh_my_loam::OhMyLoam* const slam) {
oh_my_loam::PointCloud cloud;
pcl::fromROSMsg(*msg, cloud);
ROS_INFO_STREAM("Point num = " << cloud.size()
<< "ts = " << msg->header.stamp.toSec());
slam->Run(cloud, 0.0);
}