OpenCV 在Python環(huán)境下讀取、顯示、寫入、變灰圖片

讀取圖片、并顯示圖片

import cv2 ?#核心包

import numpy as np

input = cv2.imread('./images/input.jpg')

cv2.imshow("Hello openCV",input)

cv2.waitKey(10)

cv2.destroyAllWindows()

寫入圖片

# imwrite 這個方法,加上文件名就可以幫我們保存圖片

cv2.imwrite('output.jpg', input)

cv2.imwrite('output.png', input)

圖片灰度(圖片變灰可以提高圖片處理效率,通道減少維度下降了)

# 使用 cvtColor 這個方法來轉換圖片的成黑白

gray_image = cv2.cvtColor(input,cv2.COLOR_BGR2GRAY)

#方式二:img = cv2.imread('./images/input.jpg',0) ?#直接讀取其中一個通道

圖片對應坐標像素點查看

B,G,R = image[0, 0]

print(B,G,R) ?# 會打印對應的三個色值

#如果灰度的話 ?只有一個值

gray_iamge = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) print(gray_iamge.shape) print(gray_iamge[0,0]) #21 ?這個時候只有一個值輸出

color for HSV (色調、飽和度、亮度 什么的)

image = cv2.imread('./images/input.jpg')

hsv_image = cv2.cvtColor(image,cv2.COLOR_BGR2HSV)

# 打印原圖,還有 HSV 單個通道的內容

cv2.imshow("HSV image",hsv_image)

cv2.imshow("Hue channel",hsv_image[:,:,0])

cv2.imshow("Saturation channel",hsv_image[:,:,1])

cv2.imshow("valie channel",hsv_image[:,:,2])

cv2.waitKey()

cv2.destroyAllWindows()

改變圖片單(可以任意)個通道的色值,通過先分離,再合并

image = cv2.imread('./images/input.jpg')

# 使用 split 方法來抽出單個 BGR 通道

B,G,R = cv2.split(image)

print (B.shape)

# cv2.imshow("Red",R)

# cv2.imshow("Blue",B)

# cv2.imshow("Green",G)

# cv2.waitKey()

# cv2.destroyAllWindows()

# 使用 re-mark. 來重新制作原始圖片

# merged = cv2.merge([B,G,R])

# cv2.imshow("Merged",merged)

# cv2.waitKey()

# cv2.destroyAllWindows()

# 修改單個顏色強度

merged = cv2.merge([B+100,G,R])

cv2.imshow("Merged with blue",merged)

cv2.waitKey()

cv2.destroyAllWindows()

只顯示一個顏色(這個背景是黑色)

import cv2

import numpy as np

B,G,R = cv2.split(image)

# 創(chuàng)建一個矩陣 [0,0,0] zero

zeros = np.zeros(image.shape[:2], dtype="uint8")

cv2.imshow("Red", cv2.merge([zeros, zeros, R]))

cv2.imshow("Green", cv2.merge([zeros, G, zeros]))

cv2.imshow("Blue", cv2.merge([B, zeros, zeros]))

cv2.waitKey()

cv2.destroyAllWindows()

一張圖片的顏色直方圖(Y軸像素量)

from matplotlib import pyplot as plt

import cv2

import numpy as np

image = cv2.imread('./images/input.jpg')

histogram = cv2.calcHist([image],[0],None,[256],[0,256])

# cv2.calcHist([圖像],[通道],掩碼,[範圍],[BIN 的數量表示尺寸])

# calcHist 幫助我們繪圖(直方圖)

# 圖像:uint8 或者。uint32 的圖像要用 []

# 通道:對於彩色圖像來說可以分別使用 [0][1][2] 的方式分別來計算 藍色 綠色 或是紅色

# 掩碼:掩蓋掉圖片,如果我們有想要指定特定的顏色再給他數據(蒙太奇)後面會講

# hitsize: 表示圖表的單位數量

#整張圖片裡面藍色的分佈情況

# plt.hist(image.ravel(), 256, [0, 256]); plt.show()

color = ("b","g","r")

for i, col in enumerate(color):

histogram2 = cv2.calcHist([image],[i],None,[256],[0,256])

plt.plot(histogram2, color = col)

plt.xlim([0,256])

plt.show()


最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容