OpenCV+python:像素运算
一、數(shù)值運(yùn)算(調(diào)節(jié)亮度,調(diào)整對(duì)比度)
OpenCV提供的圖片色素的處理函數(shù)(運(yùn)算的要求:兩張圖片的shape要一樣):
(1)相加:add()
(2)相減:subtract()
(3)相乘:divide()
(4)相除:multiply()
原理就是:通過(guò)獲取兩張(一次只能是兩張)個(gè)圖片的同一個(gè)位置的色素值來(lái)實(shí)現(xiàn)運(yùn)算,黑色是0,白色為255,當(dāng)大于255會(huì)為白色,小于0為黑色。
import cv2 as cv#數(shù)值運(yùn)算:加減乘除def shu_image(src11, src22):src = cv.add(src11, src22)#加cv.imshow("add", src)src = cv.subtract(src11, src22)#減cv.imshow("subtract", src)src = cv.divide(src11, src22)#乘cv.imshow("divide", src)src = cv.multiply(src11, src22)#除cv.imshow("multiply", src)src1 = cv.imread("D:/images/demo1.png")src2 = cv.imread("D:/images/demo2.png")cv.imshow("11", src1)cv.imshow("22", src2)shu_image(src1, src2)cv.waitKey(0)cv.destroyAllWindows()
(5)獲取各個(gè)通道的均值
m = cv.mean(image)print(m) #都過(guò)小則偏暗,單個(gè)過(guò)大的通道可認(rèn)為是主色彩
(6)獲取每個(gè)圖像的方差
m,dev = cv.meanStdDev(image) #返回均值和方差,分別對(duì)應(yīng)3個(gè)通道
print(m)
print(dev) 過(guò)大說(shuō)明像素間的差異就大
若dev小,則說(shuō)明圖片的色彩差異(對(duì)比性)是較小的,若整張圖片同色,則方差是0,均值是0,可以用來(lái)查看掃描儀中是否有信息丟失(方差小于一個(gè)預(yù)值,則失效,丟棄)
二、邏輯運(yùn)算(遮罩層控制)
1,opencv提供圖片像素的處理函數(shù):
與:bitwise_add() (類似于遮罩,當(dāng)我們使用白色遮罩)
或:bitwise_or()
非:bitwise_not() (對(duì)一張圖片取反)
異或:bitwise_xor()
import cv2 as cv#邏輯運(yùn)算:與或非的操作
def luo_image(src11, src22):src = cv.bitwise_and(src11, src22) # 兩張圖片同一位置的色素兩個(gè)值均不為零的才會(huì)有輸出cv.imshow("與", src)src = cv.bitwise_or(src11, src22) # 兩張圖片同一位置的色素兩個(gè)值不全為零的才會(huì)有輸出cv.imshow("或", src)src = cv.bitwise_not(src11) # 對(duì)一張圖片操作 取反cv.imshow("非", src)src = cv.bitwise_xor(src11, src22) # 兩張圖片同一位置的色素兩個(gè)值有一個(gè)為零,另一個(gè)不為零才會(huì)輸出cv.imshow("異或", src)src1 = cv.imread("D:/images/demo1.png")src2 = cv.imread("D:/images/demo2.png")cv.imshow("11", src1)cv.imshow("22", src2)luo_image(src1, src2)cv.waitKey(0)cv.destroyAllWindows()
2,針對(duì)視頻中inrange,先將image二值化,提取出目標(biāo)對(duì)象,然后再與原圖bitwise_and,就會(huì)把目標(biāo)對(duì)象提取出來(lái)關(guān)于lower_hsv 和 upper_hsv 的取值參見(jiàn)下表:
import cv2 as cv
import numpy as npdef extrace_object_demo(): #追蹤有顏色的對(duì)象capture = cv.VideoCapture("D:/vcprojects/images/video.mp4")while(True):ret, frame = capture.read() #frame是每一幀圖像,ret是返回值,為0是表示圖像讀取完畢if ret == False:break;hsv = cv.cvtColor(frame, cv.COLOR_BGR2HSV) lower_hsv = np.array([37, 43, 46])upper_hsv = np.array([77, 255, 255])mask = cv.inRange(hsv, lowerb=lower_hsv, upperb=upper_hsv) #該函數(shù)輸出的dst是一幅二值化之后的圖像(是將滿足我們的圖像對(duì)象所有位都設(shè)為1白色,不滿足設(shè)置為0黑色)dst = cv.bitwise_and(frame, frame, mask=mask) #提取出目標(biāo)對(duì)象,然后再與原圖bitwise_and,就會(huì)把目標(biāo)對(duì)象提取出來(lái)cv.imshow("video", frame)cv.imshow("mask", mask)cv.imshow("dst", dst)c = cv.waitKey(40)if c == 27: #退出break
3,調(diào)整亮度和對(duì)比度 addWeighted
def contrast_brightness_demo(image,c,b):''':param image: 原圖:param c: 對(duì)比度 是將像素乘與c,原來(lái)2,4---->4, 8 差距由2--->4導(dǎo)致對(duì)比增強(qiáng):param b: 亮度 是將每個(gè)像素點(diǎn)加上相關(guān)亮度:return:'''h,w,ch = image.shapeblank = np.zeros([h,w,ch],image.dtype) #創(chuàng)建一個(gè)全黑圖像dst = cv.addWeighted(image,c,blank,1-c,b)cv.imshow("dst",dst)
說(shuō)明
基本原理:兩張圖片合成。dst = src1alpha+src2beta+gamma
對(duì)比度:制造一個(gè)全黑(像素為0),通過(guò)權(quán)重相加,乘以倍數(shù)就會(huì)使像素之間的差異性成倍增大,對(duì)比度提升
亮度:+像素值,讓圖片像素往255靠近,(255,255,255)是白色,圖片越來(lái)越亮
1、第1個(gè)參數(shù),輸入圖片1,
2、第2個(gè)參數(shù),圖片1的融合比例
3、第3個(gè)參數(shù),輸入圖片2
4、第4個(gè)參數(shù),圖片2的融合比例
5、第5個(gè)參數(shù),偏差
6、第6個(gè)參數(shù),輸出圖片
總結(jié)
以上是生活随笔為你收集整理的OpenCV+python:像素运算的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: OpenCV+python:色彩空间转换
- 下一篇: qq昵称横线网名大全