48 #include <opencv2/highgui/highgui.hpp>
49 #include <opencv2/imgproc/imgproc.hpp>
51 #include <dynamic_reconfigure/server.h>
52 #include "opencv_apps/GoodfeatureTrackConfig.h"
53 #include "opencv_apps/Point2D.h"
54 #include "opencv_apps/Point2DArrayStamped.h"
67 typedef opencv_apps::GoodfeatureTrackConfig
Config;
87 const std::string&
frameWithDefault(
const std::string& frame,
const std::string& image_frame)
94 void imageCallbackWithInfo(
const sensor_msgs::ImageConstPtr& msg,
const sensor_msgs::CameraInfoConstPtr& cam_info)
96 doWork(msg, cam_info->header.frame_id);
101 doWork(msg, msg->header.frame_id);
109 void doWork(
const sensor_msgs::ImageConstPtr& msg,
const std::string& input_frame_from_msg)
118 opencv_apps::Point2DArrayStamped corners_msg;
119 corners_msg.header = msg->header;
123 int max_trackbar = 100;
125 if (frame.channels() > 1)
127 cv::cvtColor(frame, src_gray, cv::COLOR_BGR2GRAY);
132 cv::cvtColor(src_gray, frame, cv::COLOR_GRAY2BGR);
155 std::vector<cv::Point2f> corners;
156 double quality_level = 0.01;
157 double min_distance = 10;
159 bool use_harris_detector =
false;
165 cv::goodFeaturesToTrack(src_gray, corners,
max_corners_, quality_level, min_distance, cv::Mat(), block_size,
166 use_harris_detector, k);
171 for (
const cv::Point2f& corner : corners)
173 cv::circle(frame, corner, r, cv::Scalar(rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255)), -1, 8,
181 int c = cv::waitKey(1);
185 for (
const cv::Point2f& i : corners)
187 opencv_apps::Point2D corner;
190 corners_msg.points.push_back(corner);
197 catch (cv::Exception& e)
199 NODELET_ERROR(
"Image processing error: %s %s %s %i", e.err.c_str(), e.func.c_str(), e.file.c_str(), e.line);
239 dynamic_reconfigure::Server<Config>::CallbackType
f = boost::bind(
244 msg_pub_ = advertise<opencv_apps::Point2DArrayStamped>(*
pnh_,
"corners", 1);
259 ROS_WARN(
"DeprecationWarning: Nodelet goodfeature_track/goodfeature_track is deprecated, "
260 "and renamed to opencv_apps/goodfeature_track.");
266 #ifdef USE_PLUGINLIB_CLASS_LIST_MACROS_H