透视变换,最小外接矩形转正python

# 找到最小外接矩形
rect = cv2.minAreaRect(max_contour)
box = cv2.boxPoints(rect)
box = np.int0(box)
center, size, angle = rect # 外接矩形中心点坐标、尺寸和旋转角度
# 计算透视变换矩阵
M = cv2.getRotationMatrix2D(center, angle, 1)
# 进行透视变换
rotated = cv2.warpAffine(extracted_region, M, (extracted_region.shape[1], extracted_region.shape[0]), flags=cv2.INTER_LINEAR)
rotated_mask = cv2.warpAffine(extracted_region_mask, M, (extracted_region_mask.shape[1], extracted_region_mask.shape[0]), flags=cv2.INTER_LINEAR)
result1 = rotated[int(center[1] - size[1] / 2):int(center[1] + size[1] / 2),
int(center[0] - size[0] / 2):int(center[0] + size[0] / 2)] # 提取ROI
result2 = rotated_mask[int(center[1] - size[1] / 2):int(center[1] + size[1] / 2),
int(center[0] - size[0] / 2):int(center[0] + size[0] / 2)]

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值