博客
关于我
python截取图片
阅读量:227 次
发布时间:2019-02-28

本文共 1043 字,大约阅读时间需要 3 分钟。

使用 OpenCV 选择图片区域并进行截图

这段代码可以帮助用户从图片中选择特定区域并进行截图,适用于图像处理和编辑任务。以下是代码的详细说明:

代码解释

  • 导入库

    首先需要导入 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()
  • 使用说明

  • 选择区域

    在显示的原始图片上,使用鼠标点击选择需要截取的区域。

    • left-click 左键:开始选择
    • right-click 右键:确认选择
  • 保存截图

    选择有效区域后,系统会自动截图并保存为 crop.jpg

  • 注意事项

    • 确保图片路径正确,支持 *.jpg*.png 等格式。
    • 选择区域时,避免选择过大或过小的区域,确保截图清晰。
  • 操作流程

  • 导入库

    打开终端或脚本编辑器,输入以下命令:

    import cv2
  • 运行脚本

    将图片路径替换为实际路径,保存为 .py 文件,双击运行:

    python 选择区域截图.py
  • 操作截图

    -打开图片,使用鼠标选择区域,点击保存。-截图已保存为 crop.jpg,可以直接使用或进一步编辑。

  • 转载地址:http://lwvp.baihongyu.com/

    你可能感兴趣的文章
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js中环境变量process.env详解
    查看>>