我正在使用OpenCV与numpy和Python。我有一个2D的uint8
numpy数组。这些值表示阈值图像中超过阈值像素的局部密度。我想将其转换为三维RGB图像,其中所有RGB值都设置为相同,因此基本上是灰度图像,其中最大值得到(255,255,255)
,其他所有值按比例缩放。(我需要RGB,因为这似乎是我可以使用OpenCV写入视频的唯一类型的图像)。哪种方法最有效?
我假设您有一张二维灰度图像,类似于:
>>> import cv2
>>> img_gray = cv2.imread('./440px-Lenna.png', cv2.CV_LOAD_IMAGE_GRAYSCALE) # image take from http://en.wikipedia.org/wiki/Lenna
img_gray
包含一个灰度图像:>>> print(img_gray.shape)
(440, 440)
cv2.cvtColor
以高效的方式将图像转换为BGR:>>> img_bgr = cv2.cvtColor(img_gray, cv2.COLOR_GRAY2BGR)
>>> print(img_bgr.shape)
(440, 440, 3)