本文共 1050 字,大约阅读时间需要 3 分钟。
这段代码可以帮助用户从图片中选择特定区域并进行截图,适用于图像处理和编辑任务。以下是代码的详细说明:
导入库
首先需要导入 OpenCV 库,用于图像处理功能。import cv2
读取图片
使用cv2.imread 读取图片文件。 img = '1.jpg'img = cv2.imread(img)
显示原始图片
使用cv2.imshow 显示原始图片。 cv2.imshow('original', img) 选择区域
使用cv2.selectROI 选择图片区域。 roi = cv2.selectROI(windowName="original", img=img, showCrosshair=True, fromCenter=False)
windowName:窗口名称,用于显示选择区域。img:需要处理的图片。showCrosshair:是否显示交叉hair。fromCenter:是否从中心开始选择区域。获取 ROI 参数
获取选区域的坐标和尺寸。x, y, w, h = roi
显示并保存截图
如果 ROI 选择的区域有效,进行截图并保存。if roi != (0, 0, 0, 0): crop = img[y:y+h, x:x+w] cv2.imshow('crop', crop) cv2.imwrite('crop.jpg', crop) print('Saved!') 退出窗口
使用cv2.waitKey 退出所有 OpenCV 窗口。 cv2.waitKey(0)cv2.destroyAllWindows()
选择区域
在显示的原始图片上,使用鼠标点击选择需要截取的区域。保存截图
选择有效区域后,系统会自动截图并保存为crop.jpg。 注意事项
*.jpg、*.png 等格式。导入库
打开终端或脚本编辑器,输入以下命令:import cv2
运行脚本
将图片路径替换为实际路径,保存为.py 文件,双击运行: python 选择区域截图.py
操作截图
-打开图片,使用鼠标选择区域,点击保存。 -截图已保存为crop.jpg,可以直接使用或进一步编辑。 转载地址:http://lwvp.baihongyu.com/