目录

选择多边形区域ROI:

多边形裁剪:

加个顺时针排序:


选择多边形区域ROI:

import cv2
import numpy as np
import joblibpts = []  # 用于存放点# 统一的:mouse callback function
def draw_roi(event, x, y, flags, param):img2 = img.copy()if event == cv2.EVENT_LBUTTONDOWN:  # 左键点击,选择点pts.append((x, y))if event == cv2.EVENT_RBUTTONDOWN:  # 右键点击,取消最近一次选择的点pts.pop()if event == cv2.EVENT_MBUTTONDOWN:  # 中键绘制轮廓mask = np.zeros(img.shape, np.uint8)points = np.array(pts, np.int32)points = points.reshape((-1, 1, 2))# 画多边形mask = cv2.polylines(mask, [points], True, (255, 255, 255), 2)mask2 = cv2.fillPoly(mask.copy(), [points], (255, 255, 255))  # 用于求 ROImask3 = cv2.fillPoly(mask.copy(), [points], (0, 255, 0))  # 用于 显示在桌面的图像show_image = cv2.addWeighted(src1=img, alpha=0.8, src2=mask3, beta=0.2, gamma=0)cv2.imshow("mask", mask2)cv2.imshow("show_img", show_image)ROI = cv2.bitwise_and(mask2, img)cv2.imshow("ROI", ROI)cv2.waitKey(0)if len(pts) > 0:# 将pts中的最后一点画出来cv2.circle(img2, pts[-1], 3, (0, 0, 255), -1)if len(pts) > 1:# 画线for i in range(len(pts) - 1):cv2.circle(img2, pts[i], 5, (0, 0, 255), -1)  # x ,y 为鼠标点击地方的坐标cv2.line(img=img2, pt1=pts[i], pt2=pts[i + 1], color=(255, 0, 0), thickness=2)cv2.imshow('image', img2)# 创建图像与窗口并将窗口与回调函数绑定
img = cv2.imread("./123.jpg")
cv2.namedWindow('image')
cv2.setMouseCallback('image', draw_roi)
print("[INFO] 单击左键:选择点,单击右键:删除上一次选择的点,单击中键:确定ROI区域")
print("[INFO] 按‘S’确定选择区域并保存")
print("[INFO] 按 ESC 退出")while True:key = cv2.waitKey(1) & 0xFFif key == 27:breakif key == ord("s"):saved_data = {"ROI": pts}joblib.dump(value=saved_data, filename="config.pkl")print("[INFO] ROI坐标已保存到本地.")break
cv2.destroyAllWindows()

多边形裁剪:

方法1:

先上效果图:

代码:

import cv2
import numpy as np
img = cv2.imread(r'd:/qinlan.jpg')shape = img.shape
points_704 = np.array([[30, 280], [240, 290], [280, 30], [30, 30]])height = shape[1]
# 图片的高度尺寸
img_origin = img.copy()
cv2.fillConvexPoly(img, points_704, 1)
bitwisexor = cv2.bitwise_xor(img, img_origin)cv2.imshow("asdf", bitwisexor)
cv2.waitKey(0)

注意:points_704的坐标格式是[[x1,y1],[x2,y2],[x3,y3],[x4,y4]]

points_704的坐标点需要是顺时针或者逆时针顺序,如果顺序随机的,可能出现下图情况:

import cv2
import numpy as np
img = cv2.imread(r'd:/qinlan.jpg')shape = img.shape
points_704 = np.array([[30, 280], [240, 290],[30, 30], [280, 30]])height = shape[1]
# 图片的高度尺寸
img_origin = img.copy()
cv2.fillConvexPoly(img, points_704, 1)
bitwisexor = cv2.bitwise_xor(img, img_origin)cv2.imshow("asdf", bitwisexor)
cv2.waitKey(0)

别着急,还有办法:

加个顺时针排序:

import cv2
import numpy as npfrom functools import reduce
import operator
import mathimg = cv2.imread(r'd:/qinlan.jpg')shape = img.shape
points_704 = np.array([[30, 280], [240, 290],[30, 30], [280, 30]])coords =points_704
#开始顺时针排序
center = tuple(map(operator.truediv, reduce(lambda x, y: map(operator.add, x, y), coords), [len(coords)] * 2))
points_new=sorted(coords, key=lambda coord: (-135 - math.degrees(math.atan2(*tuple(map(operator.sub, coord, center))[::-1]))) % 360, reverse=True)points_new=np.array(points_new)height = shape[1]
# 图片的高度尺寸
img_result = img.copy()
cv2.fillConvexPoly(img, points_new, 1)
bitwisexor = cv2.bitwise_xor(img, img_result)cv2.imshow("bitwisexor", bitwisexor)
cv2.imshow("img", img)
cv2.waitKey(0)

python多边形裁剪相关推荐

  1. C++ 计算多边形的面积,计算IOU

    //求任意多边形的面积 /*语法:result = polygonarea(vector<Point>&polygon, int N); 参数: polygon:多变形顶点数组 N ...

  2. arcgis python实例_arcgis python脚本工具实例教程—栅格范围提取至多边形要素类

    arcgis python脚本工具实例教程-栅格范围提取至多边形要素类 商务合作,科技咨询,版权转让:向日葵,135-4855_4328,xiexiaokui#qq.com 功能:提取栅格数据的范围, ...

  3. 基于 Python 的自然邻域法空间插值的实现与优化

      接上期基于 Python 的自然邻域法空间插值的实现与思考.   上期说到,我们仅仅利用自然邻域法基础原理进行插值,会出现许多空值.异常值,且与ArcGIS相同分辨率.范围下的插值结果对比(对比图 ...

  4. Github配置(git+vscode+python+jupyter)

    ①下载git 打开 git bash 工具的用户名和密码存储 $ git config --global user.name "Your Name" $ git config -- ...

  5. 【实验楼】python简明教程

    ①终端输入python进入 欣赏完自己的杰作后,按 Ctrl + D 输入一个 EOF 字符来退出解释器,你也可以键入 exit() 来退出解释器. ②vim键盘快捷功能分布 ③这里需要注意如果程序中 ...

  6. 【Kaggle Learn】Python 5-8

    五. Booleans and Conditionals Using booleans for branching logic x = True print(x) print(type(x))''' ...

  7. 【Kaggle Learn】Python 1-4

    [Kaggle Learn]Python https://www.kaggle.com/learn/python 一. Hello, Python A quick introduction to Py ...

  8. 使用python愉快地做高数线代题目~

    今天接触到了python,发现真是极易上手啊!对比c语言是什么鬼东西= = 诶,等下,看完教学文章发现TA在下面写了这句话 如果做了前面的内容你可能已被吸引了,觉得c语言真的是废材! 不...不是的. ...

  9. python 位运算与等号_Python 运算符

    和大多数语言一样,Python也有很多运算符,并且运算符跟其他语言的运算符大同小异接下来一一介绍: 算术运算符: 运算符描述实例 +加 - 两个对象相加a+b的输出结果是30 -减 - 得到复数或者一 ...

最新文章

  1. 全民K歌推荐后台架构
  2. Python 获取图片文件大小并转换为base64编码
  3. C# 单元测试简单入门
  4. 脉冲宽度测量程序 c51 c语言,基于C51单片机和LCD1602显示的超声波测距仪C语言程序...
  5. linux系统中使用oracle透明网关连接db2数据库,Linux系统中使用Oracle透明网关连接DB2数据库...
  6. 2011Google校园招聘笔试题
  7. 寻一名师傅叫我破译电脑各种密码和攻克防火墙
  8. 怎样将计算机添加桌面快捷方式,Win10系统下如何将程序快捷方式添加到桌面上?【图文教程】...
  9. php 如何生成exe文件怎么打开,如何把PHP转成EXE文件
  10. Hamburger Steak
  11. mysql 手动执行event_MYSQL 定时自动执行EVENT
  12. 好爸爸陪宝宝必做的50件小事儿
  13. 随想录(学习消费类soc芯片)
  14. 网关屏蔽mac地址,linux下修改mac地址方法
  15. 可视化——matplotlib常用api(一)
  16. Filter和interceptor比较
  17. 记住:永远不要在MySQL中使用utf8,请使用utf8mb4
  18. JS对象 颠倒数组元素顺序reverse() reverse() 方法用于颠倒数组中元素的顺序。
  19. 语音排队叫号系统源码
  20. vcpkg工具+vs2019

热门文章

  1. 如何在Linux使用Eclipse + CDT开发C/C++程序 OS Linux C/C++ gcc
  2. 问题集锦(26-29)
  3. Linux内核网络中数据报在协议层的处理
  4. 检测到目标URL存在http host头攻击漏洞
  5. java nio doug_Java NIO简介
  6. chrome 禁用恢复页面提示_有哪些很值得推荐的Chrome插件?精选7款实用插件
  7. Spring MVC控制器的单元测试:“普通”控制器
  8. python这么多包、怎么记住_学Python的人这么多 有哪些技巧可言
  9. Java 9 - 17 特性解读:Java 11
  10. Java 17正式发布, Oracle宣布免费提供!“版本任你发,我用Java 8”或成历史?...