OpenCV——总结《图像基本操作》

1.数据读取-图像

函数介绍:

1.cv2.IMREAD_COLOR:彩色图像
2.cv2.IMREAD_GRAYSCALE:灰度图像

img=cv2.imread('cat.jpg',cv2.IMREAD_GRAYSCALE)

2.数据读取-视频

函数介绍:

cv2.VideoCapture可以捕获摄像头,用数字来控制不同的设备,例如0,1。如果是视频文件,直接指定好路径即可。
vc = cv2.VideoCapture(‘test.mp4’)

vc = cv2.VideoCapture('test.mp4')

# 检查是否打开正确
if vc.isOpened(): 
    oepn, frame = vc.read()
else:
    open = False

while open:
    ret, frame = vc.read()
    if frame is None:
        break
    if ret == True:
        gray = cv2.cvtColor(frame,  cv2.COLOR_BGR2GRAY)
        cv2.imshow('result', gray)
        if cv2.waitKey(100) & 0xFF == 27:
            break
vc.release()
cv2.destroyAllWindows()

3.截取部分图像数据

img=cv2.imread('cat.jpg')
cat=img[0:50,0:200] 

4.颜色通道提取

b,g,r=cv2.split(img)

5.边界填充

五种方法:
1.BORDER_REPLICATE:复制法,也就是复制最边缘像素。
2.BORDER_REFLECT:反射法,对感兴趣的图像中的像素在两边进行复制例如:fedcba|abcdefgh|hgfedcb
3.BORDER_REFLECT_101:反射法,也就是以最边缘像素为轴,对称,gfedcb|abcdefgh|gfedcba
4.BORDER_WRAP:外包装法cdefgh|abcdefgh|abcdefg
5.BORDER_CONSTANT:常量法,常数值填充。

replicate = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, borderType=cv2.BORDER_REPLICATE)
reflect = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size,cv2.BORDER_REFLECT)
reflect101 = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_REFLECT_101)
wrap = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size, cv2.BORDER_WRAP)
constant = cv2.copyMakeBorder(img, top_size, bottom_size, left_size, right_size,cv2.BORDER_CONSTANT, value=0)

6.图像融合

函数介绍:

res = cv2.addWeighted(img_cat, 0.4, img_dog, 0.6, 0)

参数1:src1,第一个原数组.
参数2:alpha,第一个数组元素权重

参数3:src2第二个原数组
参数4:beta,第二个数组元素权重
参数5:gamma,图1与图2作和后添加的数值。不要太大,不然图片一片白。总和等于255以上就是纯白色了。

连接:
https://blog.csdn.net/fanjiule/article/details/81607873
https://blog.csdn.net/weixin_41466575/article/details/113058802

你可能感兴趣的:(opencv,opencv,计算机视觉,python)