0
我得到了RGB图像(224x224x3)和覆盖图(224x224)。 现在我想将我的覆盖图应用为我的RGB图像上的红色像素,因此我将其作为灰度。覆盖范围从0到255.较高的值应该使红色更强。
我试图使用斯蒂芬的教程,但我无法适应它:tutorial。
这里是我的代码:将覆盖图应用于具有不同透明度的图像
# RGB input, shape (224x224x3)
img = self.inputImage
# make to grayscale
img = np.average(img, axis=2)
rows, cols = img.shape[0], img.shape[1]
color_mask = np.zeros((rows, cols, 3))
# convert to uint8 to plot in QImage::Format_RGB888
img = img.astype(np.uint8)
overlay = self.outputImage.astype(np.uint8)
# normalize to range 0 to 1
img = (img*1.0-img.min())/(img.max()-img.min())
overlay = (overlay*1.0 - overlay.min())/(overlay.max() - overlay.min())
# create a mask, where only the red channels contains values
mask = np.zeros((rows,cols,3))
mask[:,:,0] = mask[:,:,0]+overlay
color_mask = mask
img_color = np.dstack((img, img, img))
# make everysthing to HSV colorspace
img_hsv = color.rgb2hsv(img_color)
color_mask_hsv = color.rgb2hsv(color_mask)
img_hsv[..., 0] = color_mask_hsv[..., 0]
img_hsv[..., 1] = color_mask_hsv[..., 1] * nAlpha
# convert back
img_masked = color.hsv2rgb(img_hsv)
# rescale
ov = img_masked*255
self.mainWindow_images.label_outputImg.setPixmap(
QPixmap(QImage(ov, ov.shape[1], ov.shape[0], ov.shape[1] * 3, QImage.Format_RGB888)))
结果只是以黑色为主画面,从而改变与nAlpha一点点。 result_screenshot
我提到的博客帖也有相关的代码。 :) –