##两种图像灰度变换的手动实现方法(内附实现代码)
处理处理图像时直接调用相关函数外,自己手动实现也很重要噢!接下来介绍两种灰度转换的方法。
1、R,G,B 三通道像素值取均值来获得灰度图像。
2、NTSC方法 将 R,G,B 三通道采用不同加权系数来获得灰度图像。这种方法更符合人眼对颜色的感知。
实现结果图:
具体实现代码如下:
通过手动输入不同参数,选择不同的处理方式!
import cv2 as cv
import numpy as np
def rgb1gray(f,method):
rows=img.shape[0]
cols=img.shape[1]
img_1=np.zeros((rows,cols),dtype=np.uint8)
img_2=np.zeros((rows,cols),dtype=np.uint8)
if method=='average':
for i in range(rows):
for j in range(cols):
img_1[i][j] = int((int(img[i][j][0]) + int(img[i][j][1]) + int(img[i][j][2])) / 3)
cv.imshow('average',img_1)
elif method=='NTSC':
for m in range(rows):
for n in range(cols):
img_2[m][n]=int((int(img[m][n][0])*0.2989+int(img[m][n][1])*0.5870+int(img[m][n][2])*0.1140))
cv.imshow('NTSC', img_2)
else:
for m in range(rows):
for n in range(cols):
img_2[m][n]=int((int(img[m][n][0])*0.2989+int(img[m][n][1])*0.5870+int(img[m][n][2])*0.1140))
cv.imshow('NTSC', img_2)
print("结果图像已输出")
img=cv.imread("D://lena512color.tiff")
print("选择灰度图像转换方式'average'还是'NTSC:")
method=str(input())
if len(method.split(" "))==1:
g=rgb1gray(img,method)
cv.waitKey(0)
如果觉得有用的话,记得点个赞,鼓励一下!