Skip to content

video_stream: implement auto focus #82

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ You can use any input that OpenCV on your system accepts, e.g.:

Note these important ones on the behaviour of the node:

* `set_camera_fps`: Will set the OpenCV parameter `CV_CAP_PROP_FPS` to that amount of fps, if the camera allows it.
* `set_camera_fps`: Will set the OpenCV parameter `CV_CAP_PROP_FPS` to that amount of fps, if the camera allows it.
Does nothing on video streams or video files.

* `buffer_queue_size`: Will set the size of the buffer of images read from the capturing device. We read
Expand All @@ -70,9 +70,9 @@ So if you want the very latest image published from a camera, set `buffer_queue_

If you want to publish all images (don't drop any and you don't mind some possible delay from real time), set `buffer_queue_size` big enough for your case (1000?),
`set_camera_fps` and `fps` to whatever FPS it has.

The rest of the parameters explained, even though they are pretty self explanatory:

* `camera_name`: node name and ros graph name. All topics will hang from this e.g.: /camera_name/<TOPICS>.
* `video_stream_provider`: A number for the /dev/videoX device, e.g.: 0 for /dev/video0. A string for a path for a video file, e.g.: /home/user/Videos/myvideo.avi
or a url of a video stream e.g.: rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mov and http://10.68.0.6/mjpg/video.mjpg.
Expand All @@ -84,6 +84,7 @@ If you want to publish all images (don't drop any and you don't mind some possib
* `width` and `height`: force a width and height to the capturing device (if it allows), 0 means no forcing.
* `start_frame`: if the provider is a video file, set the start frame of video.
* `stop_frame`: if the provider is a video file, set the stop frame of video. `-1` means the end of the video. Also setting `stop_frame = start_frame + 1` can publish a single frame with a certain rate.
* `auto_focus`: enable/disable auto focus on capture devices that support auto focus, disable auto focus if you want to use the device tag tracking

# Extras

Expand All @@ -100,4 +101,3 @@ And you'll see an output like:
Correctly opened resource, starting to show feed.

With an OpenCV image show window showing the stream (which should close when pressing ESC, or Control+C the shell).

2 changes: 2 additions & 0 deletions cfg/VideoStream.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@ gen.add("hue", double_t, LEVEL.RUNNING, "Target hue", 0.5, 0.0, 1.0)
gen.add("saturation", double_t, LEVEL.RUNNING, "Target saturation", 0.64, 0.0, 1.0)
gen.add("auto_exposure", bool_t, LEVEL.RUNNING, "Target auto exposure", True)
gen.add("exposure", double_t, LEVEL.RUNNING, "Target exposure", 0.5, 0.0, 1.0)
gen.add("auto_focus", bool_t, LEVEL.RUNNING, "Target auto focus", True)
gen.add("focus", double_t, LEVEL.RUNNING, "Target focus", 0.5, 0.0, 1.0)
gen.add("loop_videofile", bool_t, LEVEL.RUNNING, "Loop videofile", False)
gen.add("reopen_on_read_failure", bool_t, LEVEL.RUNNING, "Re-open camera device on read failure", False)
gen.add("output_encoding", str_t, LEVEL.NORMAL, "Output encoding", "bgr8")
Expand Down
8 changes: 8 additions & 0 deletions src/video_stream.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -293,6 +293,14 @@ virtual void subscribe() {
cap->set(cv::CAP_PROP_HUE, latest_config.hue);
cap->set(cv::CAP_PROP_SATURATION, latest_config.saturation);

if (latest_config.auto_focus) {
cap->set(cv::CAP_PROP_AUTOFOCUS, 1);
latest_config.focus = 0.5;
} else {
cap->set(cv::CAP_PROP_AUTOFOCUS, 0);
cap->set(cv::CAP_PROP_FOCUS, latest_config.focus);
}

if (latest_config.auto_exposure) {
cap->set(cv::CAP_PROP_AUTO_EXPOSURE, 0.75);
latest_config.exposure = 0.5;
Expand Down