一、Section #1 - Basics
1.basic_functions
import cv2 as cv
img = cv.imread('../Resources/Photos/park.jpg')
cv.imshow('Park', img)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
cv.imshow('Gray', gray)
blur = cv.GaussianBlur(img, (7,7), cv.BORDER_DEFAULT)
cv.imshow('Blur', blur)
canny = cv.Canny(blur, 125, 175)
cv.imshow('Canny Edges', canny)
dilated = cv.dilate(canny, (7,7), iterations=3)
cv.imshow('Dilated', dilated)
eroded = cv.erode(dilated, (7,7), iterations=3)
cv.imshow('Eroded', eroded)
resized = cv.resize(img, (500,500), interpolation=cv.INTER_CUBIC)
cv.imshow('Resized', resized)
cropped = img[50:200, 200:400]
cv.imshow('Cropped', cropped)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/632d4/632d4146739da07a2264d0609a296066a05b400d" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/21b3b/21b3bde83090108a9f0145a8cccb6c81fbcb0c61" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/6d51d/6d51df511f46c233643c0b3a005e3eba22fc7089" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/62480/62480b58d69cd801cc52afcffe88d42b26722f72" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c1f48/c1f485a42e391ad53370336dc7fa2bfb076ce4d1" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/7bb8e/7bb8e95efbf31f98a6913e47920c135b6578b82a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e0f4b/e0f4b73a8e4c87c5e9d70acaf4710066dc1d5511" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/14954/1495449a90caf5385f3c26301b4df234c0ea094e" alt="在这里插入图片描述"
2.contours
import cv2 as cv
import numpy as np
img = cv.imread('../Resources/Photos/cats.jpg')
cv.imshow('Cats', img)
blank = np.zeros(img.shape, dtype='uint8')
cv.imshow('Blank', blank)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
cv.imshow('Gray', gray)
blur = cv.GaussianBlur(gray, (5,5), cv.BORDER_DEFAULT)
cv.imshow('Blur', blur)
canny = cv.Canny(blur, 125, 175)
cv.imshow('Canny Edges', canny)
contours, hierarchies = cv.findContours(canny, cv.RETR_LIST, cv.CHAIN_APPROX_SIMPLE)
print(f'{len(contours)} contour(s) found!')
cv.drawContours(blank, contours, -1, (0,0,255), 1)
cv.imshow('Contours Drawn', blank)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/c7f13/c7f13a1e961f90433814f4c43a778155ef2316a8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ece60/ece60453015a6995da96fa92379230ad64922913" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/df0e3/df0e320e65857897b227846fd7618ec4abb66128" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/43dd7/43dd7aa305a3096c45eaa91a53bd0f53cdd70359" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/44c4e/44c4e3e09d394933b5bb8c5fa9006678231bec52" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/31bbf/31bbfc1bc88581ef85771c547eada0996358a9be" alt="在这里插入图片描述"
3.draw
import cv2 as cv
import numpy as np
blank = np.zeros((500,500,3), dtype='uint8')
cv.imshow('Blank', blank)
blank[200:300, 300:400] = 0,0,255
cv.imshow('Green', blank)
cv.rectangle(blank, (0,0), (blank.shape[1]//2, blank.shape[0]//2), (0,255,0), thickness=-1)
cv.imshow('Rectangle', blank)
cv.circle(blank, (blank.shape[1]//2, blank.shape[0]//2), 40, (0,0,255), thickness=-1)
cv.imshow('Circle', blank)
cv.line(blank, (100,250), (300,400), (255,255,255), thickness=3)
cv.imshow('Line', blank)
cv.putText(blank, 'Hello, my name is Jason!!!', (0,225), cv.FONT_HERSHEY_TRIPLEX, 1.0, (0,255,0), 2)
cv.imshow('Text', blank)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/018df/018dfc8f102bcc76786d1eb9220cb535c7e44d27" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/554c4/554c40d46406a2034a887bf45e85bd1747d708b7" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/516e4/516e49c9903dd50bc364c966ab91d6a385419f0a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f5f67/f5f67814ebb1c69ba9c9bcd7265224f3762593c1" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/88aa8/88aa8dfa415c3b7445cef0731b75fcb5288970f9" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f3df9/f3df9aed40855b1203511f76841efa547cea73c5" alt="在这里插入图片描述"
4.read
import cv2 as cv
img = cv.imread('../Resources/Photos/cats.jpg')
cv.imshow('Cats', img)
cv.waitKey(0)
capture = cv.VideoCapture('../Resources/Videos/dog.mp4')
while True:
isTrue, frame = capture.read()
if isTrue:
cv.imshow('Video', frame)
if cv.waitKey(20) & 0xFF==ord('d'):
break
else:
break
capture.release()
cv.destroyAllWindows()
data:image/s3,"s3://crabby-images/89468/89468b4a930ef9b93c9d24795e738a0a5fccada7" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c7ca4/c7ca4a5b0b09774c017183dfe8e9ce5a8caf5c39" alt="在这里插入图片描述"
5.thresh
import cv2 as cv
img = cv.imread('../Resources/Photos/cats.jpg')
cv.imshow('Cats', img)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
cv.imshow('Gray', gray)
threshold, thresh = cv.threshold(gray, 150, 255, cv.THRESH_BINARY )
cv.imshow('Simple Thresholded', thresh)
threshold, thresh_inv = cv.threshold(gray, 150, 255, cv.THRESH_BINARY_INV )
cv.imshow('Simple Thresholded Inverse', thresh_inv)
adaptive_thresh = cv.adaptiveThreshold(gray, 255, cv.ADAPTIVE_THRESH_GAUSSIAN_C, cv.THRESH_BINARY_INV, 11, 9)
cv.imshow('Adaptive Thresholding', adaptive_thresh)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/f8872/f887244f4ee121eec4833170b303f391e58068d0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/50198/50198b03132be56b192e3d689fe9dd4e2e349805" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d8f65/d8f65115ec16494b68aedd4034343b7a9c79dfa6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/a67b4/a67b49a757611df6c2d3d6c4f8f4db371bab2e86" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5a0ce/5a0ce96c92a115ef88171569db2d35dce2133810" alt="在这里插入图片描述"
6.transformations
import cv2 as cv
import numpy as np
img = cv.imread('../Resources/Photos/park.jpg')
cv.imshow('Park', img)
def translate(img, x, y):
transMat = np.float32([[1,0,x],[0,1,y]])
dimensions = (img.shape[1], img.shape[0])
return cv.warpAffine(img, transMat, dimensions)
translated = translate(img, -100, 100)
cv.imshow('Translated', translated)
def rotate(img, angle, rotPoint=None):
(height,width) = img.shape[:2]
if rotPoint is None:
rotPoint = (width//2,height//2)
rotMat = cv.getRotationMatrix2D(rotPoint, angle, 1.0)
dimensions = (width,height)
return cv.warpAffine(img, rotMat, dimensions)
rotated = rotate(img, -45)
cv.imshow('Rotated', rotated)
rotated_rotated = rotate(img, -90)
cv.imshow('Rotated Rotated', rotated_rotated)
resized = cv.resize(img, (500,500), interpolation=cv.INTER_CUBIC)
cv.imshow('Resized', resized)
flip = cv.flip(img, -1)
cv.imshow('Flip', flip)
cropped = img[200:400, 300:400]
cv.imshow('Cropped', cropped)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/58f99/58f99d30ea19d5f508760c20cd10e42eae75dccc" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/0140b/0140bfc4d3c62da66a4ba7f7b22b9352a484f250" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d4b69/d4b6920820953965f853e7da9a8afcf4efc8c649" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f067d/f067df16cc046355c267d138840b64a055ea79ea" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/eac1c/eac1c1cc8d96af02913ff192f3a86a8f09db4ca8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d54dd/d54dd753c08c3b395e52fd3f449daea1c312aaab" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/21736/217366ccd6ed74313e11195f56f7c4b98231d2d5" alt="在这里插入图片描述"
二、Section #2 - Advanced
1.bitwise
import cv2 as cv
import numpy as np
blank = np.zeros((400,400), dtype='uint8')
rectangle = cv.rectangle(blank.copy(), (30,30), (370,370), 255, -1)
circle = cv.circle(blank.copy(), (200,200), 200, 255, -1)
cv.imshow('Rectangle', rectangle)
cv.imshow('Circle', circle)
bitwise_and = cv.bitwise_and(rectangle, circle)
cv.imshow('Bitwise AND', bitwise_and)
bitwise_or = cv.bitwise_or(rectangle, circle)
cv.imshow('Bitwise OR', bitwise_or)
bitwise_xor = cv.bitwise_xor(rectangle, circle)
cv.imshow('Bitwise XOR', bitwise_xor)
bitwise_not = cv.bitwise_not(circle)
cv.imshow('Circle NOT', bitwise_not)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/be95f/be95f045c24d0a87841f3beef0b023ec20e1d3a2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/98bc0/98bc022d6f01a3f2251ab464613ba848b60f4cb6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ecf93/ecf9311f8a89d7cbe8bf51ff230aaf8c5f629c30" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/7d582/7d582b625a1471a2366e2eee8d337a982779cfb0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d5625/d562520b0abdfad51a3942de66ff3146ec53a42a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/30976/3097692d6fcb6f65d75d655a0ad83014e688558a" alt="在这里插入图片描述"
2.blurring
import cv2 as cv
img = cv.imread('../Resources/Photos/cats.jpg')
cv.imshow('Cats', img)
average = cv.blur(img, (3,3))
cv.imshow('Average Blur', average)
gauss = cv.GaussianBlur(img, (3,3), 0)
cv.imshow('Gaussian Blur', gauss)
median = cv.medianBlur(img, 3)
cv.imshow('Median Blur', median)
bilateral = cv.bilateralFilter(img, 10, 35, 25)
cv.imshow('Bilateral', bilateral)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/22b9a/22b9a9097084ae7f6a84bd4a451ada2d3d9ec99d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/85968/859683cc387fa77be06e3f2bb501f81db6d36381" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/40f15/40f1509cec16a9a7179ce0366920ac4fff3bbf06" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/6bd63/6bd639a62f84a82327dfe34cf44041e9c60f9585" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c44dd/c44dd7c8129d51a7cc903f266ee3d0973af337c7" alt="在这里插入图片描述"
3.colour_spaces
import cv2 as cv
import matplotlib.pyplot as plt
img = cv.imread('../Resources/Photos/park.jpg')
cv.imshow('Park', img)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
cv.imshow('Gray', gray)
hsv = cv.cvtColor(img, cv.COLOR_BGR2HSV)
cv.imshow('HSV', hsv)
lab = cv.cvtColor(img, cv.COLOR_BGR2LAB)
cv.imshow('LAB', lab)
rgb = cv.cvtColor(img, cv.COLOR_BGR2RGB)
cv.imshow('RGB', rgb)
lab_bgr = cv.cvtColor(lab, cv.COLOR_LAB2BGR)
cv.imshow('LAB --> BGR', lab_bgr)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/743ed/743edb9d4358b43049abbfee4eefab14c9173d6e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f9e7d/f9e7d6a10258923ba6524196495a94abb76265e8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4be6e/4be6e6dd70c99c4c0eccda1f9fd9c56531e89050" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1e969/1e96940ba3b02994ada05ded0e6e4bb4921f0f58" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1a4e2/1a4e2cf32d8df0f77b6a49cdfa74371582e7b1b3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8372c/8372cf288a926047747cedf1d70559b6912c5bda" alt="在这里插入图片描述"
4.gradients
import cv2 as cv
import numpy as np
img = cv.imread('../Resources/Photos/park.jpg')
cv.imshow('Park', img)
gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
cv.imshow('Gray', gray)
lap = cv.Laplacian(gray, cv.CV_64F)
lap = np.uint8(np.absolute(lap))
cv.imshow('Laplacian', lap)
sobelx = cv.Sobel(gray, cv.CV_64F, 1, 0)
sobely = cv.Sobel(gray, cv.CV_64F, 0, 1)
combined_sobel = cv.bitwise_or(sobelx, sobely)
cv.imshow('Sobel X', sobelx)
cv.imshow('Sobel Y', sobely)
cv.imshow('Combined Sobel', combined_sobel)
canny = cv.Canny(gray, 150, 175)
cv.imshow('Canny', canny)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/504bf/504bf68b63dfcb76dbee42ce9cf5b029b542994b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4146f/4146fdb4d3c94570def4b27861f64e5f23f47b92" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/731bf/731bf29b066a0f11adfdb5a6b1b1909fa409175d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e72c8/e72c85673206bf72980955433b84b6d01716dd37" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/9eeb8/9eeb8fffb95bd9bc0753c6464a8cd56e960ec794" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ae210/ae2108791486efc3e30166a697321ec5aafc4d8a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/80a0c/80a0c340145820eb41d4260b36f7c1d902275435" alt="在这里插入图片描述"
5.histogram
import cv2 as cv
import matplotlib.pyplot as plt
import numpy as np
img = cv.imread('../Resources/Photos/cats.jpg')
cv.imshow('Cats', img)
blank = np.zeros(img.shape[:2], dtype='uint8')
mask = cv.circle(blank, (img.shape[1]//2,img.shape[0]//2), 100, 255, -1)
masked = cv.bitwise_and(img,img,mask=mask)
cv.imshow('Mask', masked)
plt.figure()
plt.title('Colour Histogram')
plt.xlabel('Bins')
plt.ylabel('# of pixels')
colors = ('b', 'g', 'r')
for i,col in enumerate(colors):
hist = cv.calcHist([img], [i], mask, [256], [0,256])
plt.plot(hist, color=col)
plt.xlim([0,256])
plt.show()
cv.waitKey(0)
data:image/s3,"s3://crabby-images/c3cb9/c3cb9973a22076b6cc104d2a7bf7fb537b5605cf" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/38876/388768b2b1c888675593b44386cde3fd368310bc" alt="在这里插入图片描述"
6.masking
import cv2 as cv
import numpy as np
img = cv.imread('../Resources/Photos/cats 2.jpg')
cv.imshow('Cats', img)
blank = np.zeros(img.shape[:2], dtype='uint8')
cv.imshow('Blank Image', blank)
circle = cv.circle(blank.copy(), (img.shape[1]//2 + 45,img.shape[0]//2), 100, 255, -1)
rectangle = cv.rectangle(blank.copy(), (30,30), (370,370), 255, -1)
weird_shape = cv.bitwise_and(circle,rectangle)
cv.imshow('Weird Shape', weird_shape)
masked = cv.bitwise_and(img,img,mask=weird_shape)
cv.imshow('Weird Shaped Masked Image', masked)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/26d28/26d2857be6458a39c23e8321099bc0edf5aa6fdd" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/03214/0321482c59780d35acc2f43920f5a281d86e2609" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/aa381/aa381ff42893ea6d2152b195e12b45de2e2efb0d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b9604/b9604ae328b8080f85109a0d09ca97ff4b7de8bf" alt="在这里插入图片描述"
7.rescale_resize
import cv2 as cv
def rescaleFrame(frame, scale=0.75):
width = int(frame.shape[1] * scale)
height = int(frame.shape[0] * scale)
dimensions = (width,height)
return cv.resize(frame, dimensions, interpolation=cv.INTER_AREA)
def changeRes(width,height):
capture.set(3,width)
capture.set(4,height)
capture = cv.VideoCapture('../Resources/Videos/dog.mp4')
while True:
isTrue, frame = capture.read()
frame_resized = rescaleFrame(frame, scale=.2)
cv.imshow('Video', frame)
cv.imshow('Video Resized', frame_resized)
if cv.waitKey(20) & 0xFF==ord('d'):
break
capture.release()
cv.destroyAllWindows()
data:image/s3,"s3://crabby-images/35fbc/35fbc739d308d037f6d546386bbead02c7ab4acc" alt="在这里插入图片描述"
8.splitmerge
import cv2 as cv
import numpy as np
img = cv.imread('../Resources/Photos/park.jpg')
cv.imshow('Park', img)
blank = np.zeros(img.shape[:2], dtype='uint8')
b,g,r = cv.split(img)
blue = cv.merge([b,blank,blank])
green = cv.merge([blank,g,blank])
red = cv.merge([blank,blank,r])
cv.imshow('Blue', blue)
cv.imshow('Green', green)
cv.imshow('Red', red)
print(img.shape)
print(b.shape)
print(g.shape)
print(r.shape)
merged = cv.merge([b,g,r])
cv.imshow('Merged Image', merged)
cv.waitKey(0)
data:image/s3,"s3://crabby-images/2f1ed/2f1ed25bb8e89c3f31bd98ae4cb92d1ebe847e53" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5210d/5210d8ec0abed57b669f34ffd0cb2d2e7b14cf6c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/24ba4/24ba4e2351c39577dd21b227c7d897bac14d8202" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/6de7c/6de7c8b129fa0e1d7b060537657cae77cd4a1cc9" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/4ffec/4ffec73f4aea8f549a2fd54016a9e10a2525e095" alt="在这里插入图片描述"
sa
|