mirror of
https://github.com/ruby-opencv/ruby-opencv
synced 2023-03-27 23:22:12 -04:00
add example for bounding rectangle detection without GUI
This commit is contained in:
parent
2281b21386
commit
ef5f25909a
3 changed files with 45 additions and 0 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -16,3 +16,4 @@ ext/opencv/test.txt
|
|||
pkg/
|
||||
log.txt
|
||||
*.avi
|
||||
examples/rotated-boxes-with-detected-bounding-rectangles.jpg
|
||||
|
|
44
examples/bounding-box-detect-canny-no-gui.rb
Normal file
44
examples/bounding-box-detect-canny-no-gui.rb
Normal file
|
@ -0,0 +1,44 @@
|
|||
#!/usr/bin/env ruby
|
||||
#
|
||||
# Detects contours in an image and
|
||||
# their boundingboxes
|
||||
#
|
||||
require "opencv"
|
||||
|
||||
# Load image
|
||||
cvmat = OpenCV::CvMat.load("rotated-boxes.jpg")
|
||||
|
||||
# The "canny" edge-detector does only work with grayscale images
|
||||
# so to be sure, convert the image
|
||||
# otherwise you will get something like:
|
||||
# terminate called after throwing an instance of 'cv::Exception'
|
||||
# what(): /opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_ports_graphics_opencv/work/OpenCV-2.2.0/modules/imgproc/src/canny.cpp:67: error: (-210) in function cvCanny
|
||||
cvmat = cvmat.BGR2GRAY
|
||||
|
||||
# Use the "canny" edge detection algorithm (http://en.wikipedia.org/wiki/Canny_edge_detector)
|
||||
# Parameters are two colors that are then used to determine possible corners
|
||||
canny = cvmat.canny(50, 150)
|
||||
|
||||
# Look for contours
|
||||
# We want them to be returned as a flat list (CV_RETR_LIST) and simplified (CV_CHAIN_APPROX_SIMPLE)
|
||||
# Both are the defaults but included here for clarity
|
||||
contour = canny.find_contours(:mode => OpenCV::CV_RETR_LIST, :method => OpenCV::CV_CHAIN_APPROX_SIMPLE)
|
||||
|
||||
# The Canny Algorithm returns two matches for every contour (see O'Reilly: Learning OpenCV Page 235)
|
||||
# We need only the external edges so we ignore holes.
|
||||
# When there are no more contours, contours.h_next will return nil
|
||||
while contour
|
||||
# No "holes" please (aka. internal contours)
|
||||
unless contour.hole?
|
||||
box = contour.bounding_rect
|
||||
puts "found external contour from #{box.top_left.x},#{box.top_left.y} to #{box.bottom_right.x},#{box.bottom_right.y}"
|
||||
|
||||
# Draw that bounding rectangle
|
||||
cvmat.rectangle! box.top_left, box.bottom_right, :color => OpenCV::CvColor::Black
|
||||
end
|
||||
contour = contour.h_next
|
||||
end
|
||||
|
||||
# And save the image
|
||||
puts "Saving image with bounding rectangles"
|
||||
cvmat.save_image("rotated-boxes-with-detected-bounding-rectangles.jpg")
|
BIN
examples/rotated-boxes.jpg
Normal file
BIN
examples/rotated-boxes.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 23 KiB |
Loading…
Add table
Add a link
Reference in a new issue