import cv2
import pdb
# 读取图片
image = cv2.imread('/data/zcy/Domain-adaptation-object-detection/1011-cycle-confusion-github/1011-cycle-confusion-github2/datasets/cityscapes/visimg/val/hamburg_000000_000042_leftImg8bit_foggy_beta_0.02.png')

color_map = {'0.0': (255, 0, 0),    # 红色
             '1.0': (0, 255, 0),    # 绿色
             '2.0': (0, 0, 255),    # 蓝色
             '3.0': (255, 255, 0),  # 黄色
             '4.0': (255, 0, 255),  # 粉色
             '5.0': (0, 255, 255),  # 青色
             '6.0': (128, 0, 0),    # 深红色
             '7.0': (0, 128, 0)}    # 深绿色

# 读取txt文件，每一行是一个bounding box
with open('/data/zcy/Domain-adaptation-object-detection/1011-cycle-confusion-github/1011-cycle-confusion-github2/tensor.txt', 'r') as file:
    bounding_boxes = file.readlines()

# 遍历bounding boxes并绘制到图像上
for bbox_str in bounding_boxes:
    bbox = bbox_str.split()
    x, y, w, h = map(round, map(float, bbox[:4]))  # 左上角坐标和宽高
    label = bbox[4]
    # pdb.set_trace()
    color = color_map.get(label, (255, 255, 255))
    # 绘制矩形框
    cv2.rectangle(image, (x, y), (w, h), color, 5)

    # 在矩形框上标注类别信息
    thing_classes = ['person', 'rider', 'car', 'bicycle', 'truck', 'bus', 'motorcycle', 'train']
    cv2.putText(image, thing_classes[int(float(label))], (x, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, color, 5)

# 保存图像到文件
cv2.imwrite('4.png', image)
