当前位置: 首页 > news >正文

pyclipper和ClipperLib操作多边型

目录

1. 等距离缩放多边形

1.1 python

1.2 c++


1. 等距离缩放多边形

1.1 python

环境配置pip install opencv-python opencv-contrib-python
pip install pyclipper
pip install numpy
import cv2
import numpy as np
import pyclipperdef equidistant_zoom_contour(contour, margin):"""等"距离"缩放多边形轮廓点:param contour: 一个图形的轮廓格式[[[x1, x2]],...],shape是(-1, 1, 2):param margin: 轮廓外扩的像素距离,margin正数是外扩,负数是缩小:return: 外扩后的轮廓点"""pco = pyclipper.PyclipperOffset()#  参数限制,默认成2,这里设置大一些,主要是用于多边形的尖角是否用圆角代替pco.MiterLimit = 10  # 2是圆角,10是尖角contour = contour[:, 0, :]pco.AddPath(contour, pyclipper.JT_MITER, pyclipper.ET_CLOSEDPOLYGON)solution = pco.Execute(margin)solution = np.array(solution).reshape(-1, 1, 2).astype(int)return solutionif __name__ == '__main__':poly = np.array([[[200, 200]], [[200, 300]], [[400, 350]], [[350, 200]], [[300, 200]], [[200, 100]]])contour1 = equidistant_zoom_contour(poly, 20)  # 等距离img = np.zeros((500, 500, 3))cv2.polylines(img, [contour1], True, (0, 255, 0), 3)cv2.polylines(img, [poly], True, (0, 0, 255), 3)cv2.namedWindow("img", cv2.WINDOW_NORMAL), cv2.imshow("img", img), cv2.waitKey()

参数MiterLimit=10是尖角(左图),默认值是2,圆角(右图) 

 

1.2 c++

第一版clipper: Download Clipper

最新版clipper2: https://github.com/AngusJohnson/Clipper2

官方介绍:https://angusj.com/clipper2/Docs/Overview.htm 

 (1)这里使用旧版clipper,下载后解压

(2)vs2019配置clipper环境,只需要添加包含目录即可。

(3) 添加现有clipper头文件和源码 clipper.cpp和clipper.hpp

#include <iostream>
#include <vector>
#include <clipper.hpp>using namespace ClipperLib;std::vector<IntPoint> equidistant_zoom_contour(const std::vector<std::vector<IntPoint>>& contours, double margin) {ClipperOffset co;co.MiterLimit = 10;  // 默认2圆角,10尖角co.AddPaths(contours, jtMiter, etClosedPolygon);Paths solution;co.Execute(solution, margin);std::vector<IntPoint> result;for (const auto& path : solution) {result.insert(result.end(), path.begin(), path.end());}return result;
}int main() {Paths poly = {{{200, 200}, {200, 300}, {400, 350}, {350, 200}, {300, 200}, {200, 100}}};double margin = 20.0;std::vector<IntPoint> contour1 = equidistant_zoom_contour(poly, margin);cv::Mat img = cv::Mat::zeros(500, 500, CV_8UC3);std::vector<std::vector<cv::Point>> contours_cv(1);for (const auto& point : contour1) {contours_cv[0].emplace_back(point.X, point.Y);}cv::polylines(img, contours_cv, true, cv::Scalar(0, 255, 0), 3);contours_cv.clear();for (const auto& path : poly) {std::vector<cv::Point> contour_cv;for (const auto& point : path) {contour_cv.emplace_back(point.X, point.Y);}contours_cv.push_back(contour_cv);}cv::polylines(img, contours_cv, true, cv::Scalar(0, 0, 255), 3);cv::namedWindow("img", cv::WINDOW_NORMAL);cv::imshow("img", img);cv::waitKey(0);return 0;
}

MiterLimit默认2圆角(左图),10尖角 (右图)

 

待续。。。

参考:https://www.cnblogs.com/01black-white/p/15292193.html

http://www.lryc.cn/news/231612.html

相关文章:

  • Golang 协程、主线程
  • 【SA8295P 源码分析】125 - MAX96712 解串器 start_stream、stop_stream 寄存器配置 过程详细解析
  • pandas教程:Apply:General split-apply-combine 通常的分割-应用-合并
  • 第一讲之递归与递推下篇
  • 第十六篇-Awesome ChatGPT Prompts-备份
  • Python Web框架Django
  • 1.Spring的简单使用
  • 02.智慧商城——vant组件库使用和vw适配
  • Android笔记(十三):结合JetPack Compose和CameraX实现视频的录制和存储
  • 【开题报告】基于SpringBoot的音乐鉴赏平台的设计与实现
  • 云原生 黑马Kubernetes教程(K8S教程)笔记——第一章 kubernetes介绍——Master集群控制节点、Node工作负载节点、Pod控制单元
  • ElasticSearch 安装(单机版本)
  • 读书笔记:《BackTrader 量化交易案例图解》
  • CentOS 7 免密密钥登陆sftp服务 —— 筑梦之路
  • 记一次 .NET 某券商论坛系统 卡死分析
  • DevExpress WinForms HeatMap组件,一个高度可自定义热图控件!
  • 振弦传感器表面应变计与振弦采集仪形成岩土工程监测的解决方案
  • 笔记本电脑没有声音?几招恢复声音流畅!
  • JavaScript学习_01——JavaScript简介
  • 11.10~11.15置信区间,均值、方差假设检验,正态,t,卡方,F分布,第一第二类错误
  • 【洛谷 P2440】木材加工 题解(二分查找+循环)
  • 反向传播详解BP
  • 2023.11.16-hive sql高阶函数lateral view,与行转列,列转行
  • 解决Jetson Xavier NX上Invalid CUDA ‘--device 0‘ requested等问题
  • git push 报错 The requested URL returned error: 500
  • 应用软件安全编程--17预防基于 DOM 的 XSS
  • 【FastCAE源码阅读9】鼠标框选网格、节点的实现
  • 【ArcGIS处理】行政区划与流域区划间转化
  • Session、Token、Jwt三种登录方案介绍
  • Linux操作系统使用及C高级编程-D5Linux shell命令(进程管理、用户管理)