chessboard.py
1 | #!/usr/bin/python
|
---|---|
2 | import cv2.cv as cv |
3 | import sys |
4 | import urllib2 |
5 | |
6 | if __name__ == "__main__": |
7 | cv.NamedWindow("win")
|
8 | if len(sys.argv) > 1: |
9 | filename = sys.argv[1]
|
10 | im = cv.LoadImage(filename, cv.CV_LOAD_IMAGE_GRAYSCALE) |
11 | im3 = cv.LoadImage(filename, cv.CV_LOAD_IMAGE_COLOR) |
12 | else:
|
13 | try: # try opening local copy of image |
14 | fileName = '../cpp/left01.jpg'
|
15 | im = cv.LoadImageM(fileName, False)
|
16 | im3 = cv.LoadImageM(fileName, True)
|
17 | except: # if local copy cannot be opened, try downloading it |
18 | url = 'https://code.ros.org/svn/opencv/trunk/opencv/samples/cpp/left01.jpg'
|
19 | filedata = urllib2.urlopen(url).read() |
20 | imagefiledata = cv.CreateMatHeader(1, len(filedata), cv.CV_8UC1) |
21 | cv.SetData(imagefiledata, filedata, len(filedata))
|
22 | im = cv.DecodeImageM(imagefiledata, cv.CV_LOAD_IMAGE_GRAYSCALE) |
23 | im3 = cv.DecodeImageM(imagefiledata, cv.CV_LOAD_IMAGE_COLOR) |
24 | |
25 | chessboard_dim = ( 9, 6 ) |
26 | |
27 | found_all, corners = cv.FindChessboardCorners( im, chessboard_dim ) |
28 | print found_all, len(corners) |
29 | |
30 | cv.DrawChessboardCorners( im3, chessboard_dim, corners, found_all ) |
31 | |
32 | cv.ShowImage("win", im3);
|
33 | cv.WaitKey() |