将图像RGB值转换为灰度值的四个方法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/missyougoon/article/details/81108833

前言

图像从RGB值转灰度值非常重要,下面介绍四个方法.

1.opencv中的cv2.imread()方法

import cv2
img0 = cv2.imread('image0.jpg', 0)
cv2.imshow('image',img0)
cv2.waitKey(0)

imread()方法的第二个参数,0代表读进来的图像是灰度值;1代表以RGB值读入.
但是存在一个问题就是,读进来之后就是灰度图像,假如,需要先读入彩色图片,之后再转化为灰度值图片,就需要使用下面的方法.

2.opencv中的cv2.cvtColor方法

import cv2

img0 = cv2.imread('image0.jpg', 1)
dst = cv2.cvtColor(img0, cv2.COLOR_BGR2GRAY) # 颜色空间转换 1 data 2 BGR gray
cv2.imshow('image',dst)
cv2.waitKey(0)

cv2.cvtColor(img0, cv2.COLOR_BGR2GRAY) 第一个参数是原图像,第二个参数就是转化为灰度图像.

3.将RGB相加求均值

import cv2
import numpy as np

img = cv2.imread('image0.jpg', 1)
imgInfo = img.shape
height = imgInfo[0]
width = imgInfo[1]

# 方法: 将RGB 相加 求均值, 该均值就是该像素的灰度值
dst = np.zeros([height, width], np.uint8)
for i in range(height):
    for j in range(width):
        (b, g, r) = img[i, j]
        gray = (int(b)+int(g)+int(r)) / 3
        dst[i, j] = np.uint8( gray )

cv2.imshow('image1', dst)
#cv2.waitKey(0)

将RGB 相加 求均值, 该均值就是该像素的灰度值.

4.方法:将RGB值乘以一个系数

import cv2
import numpy as np
img = cv2.imread('image0.jpg', 1)
imgInfo = img.shape
height = imgInfo[0]
width = imgInfo[1]
dst = np.zeros([height, width], np.uint8)

for i in range(height):
    for j in range(width):
        (b, g, r) = img[i, j]
        b = int(b)
        g = int(g)
        r = int(r)
        gray = r*0.299 + g*0.587 + b*0.114
        dst[i, j] = np.uint8(gray)

cv2.imshow('image', dst)
cv2.waitKey(0)

用乘以一个系数的方式 gray = r*0.299 + g*0.587 + b*0.114 来求灰度值.

猜你喜欢

转载自blog.csdn.net/missyougoon/article/details/81108833