颜色范围
color_dict_HSV = {'black': [[180, 255, 30], [0, 0, 0]],
'white': [[180, 18, 255], [0, 0, 231]],
'red1': [[180, 255, 255], [159, 50, 70]],
'red2': [[9, 255, 255], [0, 50, 70]],
'green': [[89, 255, 255], [36, 50, 70]],
'blue': [[128, 255, 255], [90, 50, 70]],
'yellow': [[35, 255, 255], [25, 50, 70]],
'purple': [[158, 255, 255], [129, 50, 70]],
'orange': [[24, 255, 255], [10, 50, 70]],
'gray': [[180, 18, 230], [0, 0, 40]]}
鸣谢:
Ali Hashemian
如何使用OpenCV从图像中去除颜色
由于大多数人都想这样做,即在我的例子中,任务是从图像中去除蓝色,我使用了以下代码来去除蓝色印章和蓝色勾选标记,以便使用Tesseract进行正确的OCR。
[颜色去除] 代码
import cv2
import numpy as np
import matplotlib.pyplot as plt
%matplotlib inline
inputImage = cv2.imread('0.jpg')
grayscaleImage = cv2.cvtColor(inputImage, cv2.COLOR_BGR2GRAY)
hsvImage = cv2.cvtColor(inputImage, cv2.COLOR_BGR2HSV)
lowerValues = np.array([90, 50, 70])
upperValues = np.array([128, 255, 255])
bluepenMask = cv2.inRange(hsvImage, lowerValues, upperValues)
kernelSize = 3
opIterations = 1
morphKernel = cv2.getStructuringElement(cv2.MORPH_RECT, (kernelSize, kernelSize))
bluepenMask = cv2.morphologyEx(bluepenMask, cv2.MORPH_CLOSE, morphKernel, None, None, opIterations, cv2.BORDER_REFLECT101)
colorMask = cv2.add(grayscaleImage, bluepenMask)
_, binaryImage = cv2.threshold(colorMask, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
cv2.imwrite('bwimage.jpg',binaryImage)
thresh, im_bw = cv2.threshold(binaryImage, 210, 230, cv2.THRESH_BINARY)
kernel = np.ones((1, 1), np.uint8)
imgfinal = cv2.dilate(im_bw, kernel=kernel, iterations=1)
cv2.imshow(imgfinal)
处理前的图片
![Original Image](https://istack.dev59.com/kUliE.webp)
提取蓝色标记
![Blue Tick Marks Determined](https://istack.dev59.com/4SraP.webp)
最终图片
![enter image description here](https://istack.dev59.com/WJt9i.webp)
可以看到,所有的勾号都被几乎完全移除了。这是因为总有改进的空间,但是即使去掉这些小标记,对使用Tesseract的OCR也不会产生深刻的影响。
希望这可以帮助!