现有文件夹A内有若干张滑坡二进制掩码图像,如何在pycharm软件中利用代码求得值为1的多边形也就是滑坡体的目标检测标签VOC格式的xml文件,注意每张图片内有四个滑坡体,也就是每张照片需要四个检测框(可以通过多边形的连续性判断)
时间: 2024-04-30 18:22:39 浏览: 60
这是一个计算机视觉相关的问题,可以通过使用Python的OpenCV和xml.etree.ElementTree库编写代码实现。 首先,使用OpenCV读取文件夹A中的每一张图片,然后对每个图片进行二值化处理,找出滑坡体的边缘。接下来,使用cv2.findContours()函数找出每个滑坡体的边缘并确定多边形的顶点,最后将多边形的顶点存储到xml文件中即可。以下是示例代码:
```
import cv2
import os
import xml.etree.ElementTree as ET
xml_template = '''<annotation>
<folder>{}</folder>
<filename>{}</filename>
<size>
<width>{}</width>
<height>{}</height>
<depth>{}</depth>
</size>
<object>
<name>{}</name>
<bndbox>
<xmin>{}</xmin>
<ymin>{}</ymin>
<xmax>{}</xmax>
<ymax>{}</ymax>
</bndbox>
</object>
</annotation>
'''
folder_name = "A"
output_folder_name = "output"
if not os.path.exists(output_folder_name):
os.makedirs(output_folder_name)
for file_name in os.listdir(folder_name):
if file_name.endswith(".bmp"):
image = cv2.imread(os.path.join(folder_name, file_name), cv2.IMREAD_GRAYSCALE)
ret, thresh = cv2.threshold(image, 127, 255, 0)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
xml_file_content = []
xml_file_content.append("<annotations>")
xml_file_content.append("<version>1.1</version>")
xml_file_content.append("<folder>{}</folder>".format(folder_name))
xml_file_content.append("<filename>{}</filename>".format(file_name))
xml_file_content.append("<source>")
xml_file_content.append("<database>Unknown</database>")
xml_file_content.append("</source>")
xml_file_content.append("<size>")
xml_file_content.append("<width>{}</width>".format(image.shape[1]))
xml_file_content.append("<height>{}</height>".format(image.shape[0]))
xml_file_content.append("<depth>{}</depth>".format(1))
xml_file_content.append("</size>")
for contour in contours:
x, y, w, h = cv2.boundingRect(contour)
xml_file_content.append(xml_template.format(folder_name, file_name, image.shape[1], image.shape[0], 1,
"slippery_slope", x, y, x + w, y + h))
xml_file_content.append("</annotations>")
output_file_path = os.path.join(output_folder_name, file_name.replace(".bmp", ".xml"))
with open(output_file_path, "w") as f:
f.write('\n'.join(xml_file_content))
```
阅读全文