测试代码
import numpy as np import cv2 from matplotlib import pyplot as plt imgname1 = "D:\Study\Master's project\code\image\GPR_exp.png" img = cv2.imread(imgname1) img1 = cv2.imread(imgname1,0) img2 = cv2.imread(imgname1,1) img2 = cv2.cvtColor(img2, cv2.COLOR_BGR2GRAY) cv2.imshow("bgr",img) cv2.imshow("gray_read",img1) cv2.imshow("gray",img2) cv2.waitKey() cv2.destroyAllWindows()结果对比(对比图像左上角的像素点):
上图可以看出用imread和cvtColor两个方法产生的灰度图像值不相同,图像处理的过程还是需要注意,其中通过cvtColor将彩色图像转为灰度图像是采用下面的经典公式
G r a y = R ∗ 0.3 + G ∗ 0.59 + B ∗ 0.11 . \ Gray=R*0.3+G*0.59+B*0.11\,. Gray=R∗0.3+G∗0.59+B∗0.11.