0

胸部 X 射线图像 我需要使用 OpenCV 上的 skimage 删除 png 图像中多余的黑色部分。有人可以指导如何做吗?我是图像处理的新手。提前致谢。

4

1 回答 1

0

您可以通过查找不是全黑的第一行和最后一行/列来解决此问题。有了这些,您可以轻松创建仅包含感兴趣区域的新图像。

下面的代码使用 openCV 执行您想要的操作。

结果: 结果

!注意调整大小功能。将其移除以进行最终处理。

import numpy as np
import cv2

# Load a color image as grayscale
img = cv2.imread('Xray.png',0)

# resize to easily view (img is ~4000x4000), remove for final version
img = cv2.resize(img,None,fx=0.2, fy=0.2, interpolation = cv2.INTER_CUBIC)

# sum each row and each volumn of the image
sumOfCols = np.sum(img, axis=0)
sumOfRows = np.sum(img, axis=1)

# Find the first and last row / column that has a sum value greater than zero, 
# which means its not all black. Store the found values in variables
for i in range(len(sumOfCols)):
    if sumOfCols[i] > 0:
        x1 = i
        print('First col: ' + str(i))
        break

for i in range(len(sumOfCols)-1,-1,-1):
    if sumOfCols[i] > 0:
        x2 = i
        print('Last col: ' + str(i))
        break

for i in range(len(sumOfRows)):
    if sumOfRows[i] > 0:
        y1 = i
        print('First row: ' + str(i))
        break

for i in range(len(sumOfRows)-1,-1,-1):
    if sumOfRows[i] > 0:
        y2 = i
        print('Last row: ' + str(i))
        break

# create a new image based on the found values
roi = img[y1:y2,x1:x2]

# save new image with region of interest
cv2.imwrite('Xray_roi.png',roi)

# display image / subimage and release resources when key is pressed
cv2.imshow('full_image',img)
cv2.imshow('RoI',roi)
cv2.waitKey(0)
cv2.destroyAllWindows()
于 2018-12-23T18:57:56.143 回答