【笔记】opencv图像运算 图像加密
圖像加權和
可以用cv2.addWeighted()表示加權和
一個注意點:
cv2.addWeighted(a,0.5,b,0.5,0)中兩個圖像的尺寸和通道數(shù)要相同,不然會報錯。
示例:
按位邏輯運算
cv2.bitwise_and() 按位與
cv2.bitwise_or()按位或
cv2.bitwise_xor()異或
cv2.bitwise_nor()取反
數(shù)值200與255進行按位與,保持200不變
示例:
由于按位與操作要求參與運算的數(shù)據(jù)有相同的通道,所以無法直接將彩色圖像與單通道掩膜圖像進行按位與操作
將函數(shù)改為按位或:
opencv很多函數(shù)都指定一個掩膜作為參數(shù),使用掩膜參數(shù)時,操作只會在掩膜非空的像素點上執(zhí)行,并將其他像素置為0
cv2.threshold()
這個函數(shù)有四個參數(shù),第一個原圖像,第二個進行分類的閾值,第三個是高于(低于)閾值時賦予的新值,第四個是一個方法選擇參數(shù),常用的有:
? cv2.THRESH_BINARY(黑白二值)
? cv2.THRESH_BINARY_INV(黑白二值反轉)
? cv2.THRESH_TRUNC (得到的圖像為多像素值)
? cv2.THRESH_TOZERO
? cv2.THRESH_TOZERO_INV
該函數(shù)有兩個返回值,第一個retVal(得到的閾值值(在后面一個方法中會用到)),第二個就是閾值化后的圖像。
圖像加密:
a = cv2.imread("p7.jpg",0) # a = cv2.cvtColor(a, cv2.COLOR_BGR2GRAY) h,w = a.shape mask = np.zeros((h,w),dtype=np.uint8) mask[100:300,200:400] = 1 key = np.random.randint(0,256,size=[h,w],dtype=np.uint8) after = np.bitwise_and(a,mask*255)afterxor = cv2.bitwise_xor(key,a) cv2.imshow("afterxor",afterxor) #圖片加密 cv2.imshow("a",after) encypt = cv2.bitwise_and(afterxor,mask*255) cv2.imshow("encypt",encypt) noface1 = cv2.bitwise_and(a,(1-mask)*255) cv2.imshow("noface",noface1) noface2 = cv2.bitwise_and(a,afterxor) maskface = encypt+noface1 #圖像打碼 cv2.imshow("maskface",maskface) cv2.imshow("noface2",noface2) cv2.waitKey(0) cv2.destroyAllWindows()效果:
顏色空間的轉化用到了如下約定:
8位圖像值的范圍是[0,255] 16位圖像值的范圍是[0,65535] 浮點數(shù)圖像值的范圍是[0,1]
np.random.randint
np.random.randint(5, size=(3,2, 4))
生成0-5的范圍內(不包括5)的三個矩陣,每個矩陣為2行4列
進行試驗:
結果:
size=[200,70,4]中隨著第二個參數(shù)的增大,橫向區(qū)域不斷變大。且第二個和第三個參數(shù)的大小不能超過第一個,不然報錯
第一個參數(shù)增大后縱向距離變大
其中第三個參數(shù)為4時程序可以正常,但是為5和2時就會報錯,猜測應該是小于4通道數(shù)
第三個參數(shù)為1時也可以正常運行:
不加第三個參數(shù)時,顯示的也是如上的灰度圖
當圖像從GRAY色彩空間轉化到RGB/BGR色彩空間時,最終所有的通道的值都是相同的
在RGB和BGR模式之間發(fā)生轉化時,R和B通道的位置發(fā)生了交換。
模式轉化之后:
總結
以上是生活随笔為你收集整理的【笔记】opencv图像运算 图像加密的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【笔记】opencv图像轮廓 获得平均灰
- 下一篇: 【错误记录】Error creating