def button_image_open(self): print('button_image_open') name_list = [] img_name, _ = QtWidgets.QFileDialog.getOpenFileName( self, "打开图片", "", "*.jpg;;*.png;;All Files(*)") if not img_name: return img = cv2.imread(img_name) print(img_name) showimg = img with torch.no_grad(): img = letterbox(img, new_shape=self.opt.img_size)[0] # Convert # BGR to RGB, to 3x416x416 img = img[:, :, ::-1].transpose(2, 0, 1) img = np.ascontiguousarray(img) img = torch.from_numpy(img).to(self.device) img = img.half() if self.half else img.float() # uint8 to fp16/32 img /= 255.0 # 0 - 255 to 0.0 - 1.0 if img.ndimension() == 3: img = img.unsqueeze(0) # Inference pred = self.model(img, augment=self.opt.augment)[0] # Apply NMS pred = non_max_suppression(pred, self.opt.conf_thres, self.opt.iou_thres, classes=self.opt.classes, agnostic=self.opt.agnostic_nms) print(pred) # Process detections for i, det in enumerate(pred): if det is not None and len(det): # Rescale boxes from img_size to im0 size det[:, :4] = scale_coords( img.shape[2:], det[:, :4], showimg.shape).round() for *xyxy, conf, cls in reversed(det): label = '%s %.2f' % (self.names[int(cls)], conf) name_list.append(self.names[int(cls)]) plot_one_box(xyxy, showimg, label=label, color=self.colors[int(cls)], line_thickness=10)
时间: 2023-06-19 17:06:54 浏览: 145
这是一个用于打开图片并进行目标检测的函数,使用了OpenCV和PyTorch进行图像处理和模型推理。具体流程如下:
1. 使用QtWidgets.QFileDialog打开一个图片选择对话框,选中需要检测的图片。
2. 使用OpenCV的cv2.imread函数读取所选图片。
3. 对读取的图片进行预处理,包括调整图片大小、转换颜色空间、归一化等操作,使其符合模型输入要求。
4. 使用PyTorch进行模型推理,得到目标检测结果。
5. 对检测结果进行处理,包括将检测框坐标还原到原始图片尺寸、绘制检测框、输出检测结果等操作。
6. 返回检测到的目标类别列表。
阅读全文