OpenCV的颜色图数量有限。 MatplotLib具有更多的颜色图,但是将这些颜色图应用于给定的OpenCV图像并非易事。使用Python API时,如何将下一页的MatplotLib颜色映射应用于OpenCV图像?这类似于将自定义颜色图应用于给定图像。
https://matplotlib.org/examples/color/colormaps_reference.html
答案 0 :(得分:3)
回答我自己的问题,因为在StackOverflow上找不到简单的解决方案:
def apply_custom_colormap(image_gray, cmap=plt.get_cmap('seismic')):
assert image_gray.dtype == np.uint8, 'must be np.uint8 image'
if image_gray.ndim == 3: image_gray = image_gray.squeeze(-1)
# Initialize the matplotlib color map
sm = plt.cm.ScalarMappable(cmap=cmap)
# Obtain linear color range
color_range = sm.to_rgba(np.linspace(0, 1, 256))[:,0:3] # color range RGBA => RGB
color_range = (color_range*255.0).astype(np.uint8) # [0,1] => [0,255]
color_range = np.squeeze(np.dstack([color_range[:,2], color_range[:,1], color_range[:,0]]), 0) # RGB => BGR
# Apply colormap for each channel individually
channels = [cv2.LUT(image_gray, color_range[:,i]) for i in range(3)]
return np.dstack(channels)
image_gray = cv2.imread('./lena.jpg', cv2.IMREAD_GRAYSCALE)
image_bgr = apply_custom_colormap(image_gray, cmap=plt.get_cmap('bwr'))
cv2.imshow('image with colormap', image_bgr)
cv2.waitKey(0)
产生图像:
答案 1 :(得分:2)
对于Python> = 2.7,cmapy以方便的方式打包了此功能。安装:
Python 2.7:
pip install cmapy
Python 3.x:
pip3 install cmapy
或者,对于Anaconda(来自conda-forge):
conda install -c conda-forge cmapy
并像这样使用它:
import cv2
import matplotlib.pyplot as plt
import cmapy
# Read image.
img = cv2.imread('imgs/woman.png')
# Colorize.
img_colorized = cv2.applyColorMap(img, cmapy.cmap('viridis'))
# Display
plt.imshow(img_colorized)
plt.show()
不同的颜色图会给出如下信息:
查看实际使用的所有here颜色图。
免责声明:我写了cmapy(因为我需要另一个项目使用此功能),并且在内部,它与其他答案几乎相同。
答案 2 :(得分:0)
在最新版本的OpenCV(从3.3开始)中,有applyColorMap
的重载,它允许您提供自定义的颜色图(1或3通道)。我已经修改了verified.human的代码,以简单地生成适合与此功能配合使用的色图。
我还有更多机会简化代码:
bytes
参数设置为True
时,ScalarMappable.to_rgba
可以直接返回字节(范围为0-255)。代码:
import cv2
import numpy as np
from matplotlib import pyplot as plt
def get_mpl_colormap(cmap_name):
cmap = plt.get_cmap(cmap_name)
# Initialize the matplotlib color map
sm = plt.cm.ScalarMappable(cmap=cmap)
# Obtain linear color range
color_range = sm.to_rgba(np.linspace(0, 1, 256), bytes=True)[:,2::-1]
return color_range.reshape(256, 1, 3)
image_gray = cv2.imread('cage.png', cv2.IMREAD_GRAYSCALE)
image_bgr = cv2.applyColorMap(image_gray, get_mpl_colormap('bwr'))
cv2.imshow('image with colormap', image_bgr)
cv2.waitKey()