Skip to content

Commit

Permalink
Merge pull request OTL#19 from okalachev/capture_delay
Browse files Browse the repository at this point in the history
Add capture_delay parameter
  • Loading branch information
OTL authored Sep 24, 2018
2 parents 8474514 + 506f106 commit 22973af
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 4 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ If no calibration data is set, it has dummy values except for width and height.
* ~image_height (int) try to set capture image height.
* ~camera_info_url (string) url of camera info yaml.
* ~file (string: default "") if not "" then use movie file instead of device.
* ~capture_delay (double: default 0) estimated duration of capturing and receiving the image.
* ~rescale_camera_info (bool: default false) rescale camera calibration info automatically.

supports CV_CAP_PROP_*, by below params.
Expand Down
5 changes: 5 additions & 0 deletions include/cv_camera/capture.h
Original file line number Diff line number Diff line change
Expand Up @@ -213,6 +213,11 @@ class Capture
* @brief rescale_camera_info param value
*/
bool rescale_camera_info_;

/**
* @brief capture_delay param value
*/
ros::Duration capture_delay_;
};

} // namespace cv_camera
Expand Down
9 changes: 5 additions & 4 deletions src/capture.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,8 @@ Capture::Capture(ros::NodeHandle &node, const std::string &topic_name,
topic_name_(topic_name),
buffer_size_(buffer_size),
frame_id_(frame_id),
info_manager_(node_, frame_id)
info_manager_(node_, frame_id),
capture_delay_(ros::Duration(node_.param("capture_delay", 0.0)))
{
}

Expand Down Expand Up @@ -130,9 +131,9 @@ bool Capture::capture()
{
if (cap_.read(bridge_.image))
{
ros::Time now = ros::Time::now();
ros::Time stamp = ros::Time::now() - capture_delay_;
bridge_.encoding = enc::BGR8;
bridge_.header.stamp = now;
bridge_.header.stamp = stamp;
bridge_.header.frame_id = frame_id_;

info_ = info_manager_.getCameraInfo();
Expand All @@ -158,7 +159,7 @@ bool Capture::capture()
info_.width, info_.height, bridge_.image.cols, bridge_.image.rows);
}
}
info_.header.stamp = now;
info_.header.stamp = stamp;
info_.header.frame_id = frame_id_;

return true;
Expand Down

0 comments on commit 22973af

Please sign in to comment.