我试图增加灰度图像的亮度。 cv2.imread()返回一个numpy数组。 我将整数值添加到数组的每个元素。 从理论上讲,这将增加他们每个人。 之后,我可以将上限设置为255,并获得具有更高亮度的图像。
这是代码:
grey = cv2.imread(path+file,0)
print type(grey)
print grey[0]
new = grey + value
print new[0]
res = np.hstack((grey, new))
cv2.imshow('image', res)
cv2.waitKey(0)
cv2.destroyAllWindows()
但是,内部OpenCV例程显然可以执行以下操作:
new_array = old_array % 255
每个高于255的像素强度值都将除以255。
结果,我越来越黑,而不是全白。
这是输出:
[115 114 121 ..., 170 169 167]
[215 214 221 ..., 14 13 11]
这是图片:
如何关闭这种余数机制? 有没有更好的方法可以提高OpenCV的亮度?
一种想法是在添加value之前检查该添加是否会导致溢出,方法是检查255与当前像素值之间的差异,并检查它是否在value之内。如果是这样,我们将不添加value,我们将直接将它们设置为255