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

网站免费优化软件东莞建设企业网站

网站免费优化软件,东莞建设企业网站,深圳招工包吃住8000元,网站做微信支付在 OpenCV 中,cv::approxPolyDP 是一个函数,用于对轮廓进行多边形逼近(Polygon Approximation)。它可以将复杂的轮廓逼近为简化的多边形,从而减少轮廓的数据点,使轮廓更加紧凑。 函数原型如下:…

在 OpenCV 中,cv::approxPolyDP 是一个函数,用于对轮廓进行多边形逼近(Polygon Approximation)。它可以将复杂的轮廓逼近为简化的多边形,从而减少轮廓的数据点,使轮廓更加紧凑。

函数原型如下:

cv::approxPolyDP(InputArray curve, OutputArray approxCurve, double epsilon, bool closed);

参数说明:

  • curve: 输入的轮廓点,可以是一个 std::vector<cv::Point>cv::Mat 类型的数据。
  • approxCurve: 输出的多边形逼近点,返回一个 std::vector<cv::Point>cv::Mat 类型的数据,代表多边形逼近的点。
  • epsilon: 控制逼近精度的参数。较小的值会产生更精细的逼近,较大的值会产生更简化的逼近。
  • closed: 一个布尔值,用于指定多边形是否闭合。如果设置为 true,则多边形是闭合的,如果设置为 false,则多边形是非闭合的。

以下是一个简单的示例代码,演示如何使用 cv::approxPolyDP 对轮廓进行多边形逼近:

#include <opencv2/opencv.hpp>int main() {// 读取图像并转换为灰度图像cv::Mat image = cv::imread("path/to/your/image.jpg", cv::IMREAD_GRAYSCALE);// 二值化处理,将图像转换为黑白图像,以便寻找轮廓cv::Mat binary;cv::threshold(image, binary, 128, 255, cv::THRESH_BINARY);// 寻找轮廓std::vector<std::vector<cv::Point>> contours;cv::findContours(binary, contours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_SIMPLE);// 多边形逼近std::vector<std::vector<cv::Point>> approxContours(contours.size());for (size_t i = 0; i < contours.size(); ++i) {cv::approxPolyDP(contours[i], approxContours[i], 5, true); // 使用 epsilon = 5 进行多边形逼近}// 绘制轮廓和多边形逼近cv::Mat result;cv::cvtColor(binary, result, cv::COLOR_GRAY2BGR);cv::drawContours(result, contours, -1, cv::Scalar(0, 0, 255), 2); // 绘制原始轮廓(红色)cv::drawContours(result, approxContours, -1, cv::Scalar(0, 255, 0), 2); // 绘制多边形逼近(绿色)// 显示结果cv::imshow("Original and Approximated Contours", result);cv::waitKey(0);return 0;
}

在上述示例中,我们首先读取图像并转换为灰度图像,然后进行二值化处理,找到图像中的轮廓。接着,使用 cv::approxPolyDP 对每个轮廓进行多边形逼近,并绘制原始轮廓(红色)和多边形逼近(绿色)的结果。

使用 Python 和 OpenCV 实现多边形逼近的示例代码:

import cv2
import numpy as np# 读取图像并转换为灰度图像
image = cv2.imread("path/to/your/image.jpg", cv2.IMREAD_GRAYSCALE)# 二值化处理,将图像转换为黑白图像,以便寻找轮廓
_, binary = cv2.threshold(image, 128, 255, cv2.THRESH_BINARY)# 寻找轮廓
contours, _ = cv2.findContours(binary, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)# 多边形逼近
approxContours = []
for contour in contours:epsilon = 0.01 * cv2.arcLength(contour, True) # epsilon 控制逼近精度的参数approx = cv2.approxPolyDP(contour, epsilon, True)approxContours.append(approx)# 绘制轮廓和多边形逼近
result = cv2.cvtColor(binary, cv2.COLOR_GRAY2BGR)
cv2.drawContours(result, contours, -1, (0, 0, 255), 2) # 绘制原始轮廓(红色)
cv2.drawContours(result, approxContours, -1, (0, 255, 0), 2) # 绘制多边形逼近(绿色)# 显示结果
cv2.imshow("Original and Approximated Contours", result)
cv2.waitKey(0)
cv2.destroyAllWindows()

在 Python 版本的代码中,我们使用了 cv2.threshold 函数进行二值化处理,使用 cv2.findContours 函数找到图像中的轮廓,然后通过 cv2.approxPolyDP 函数对每个轮廓进行多边形逼近。最后,使用 cv2.drawContours 函数将原始轮廓和多边形逼近结果绘制在图像上,并显示结果。

Python 版本的代码与 C++ 版本的代码相比,在函数调用时稍有不同,但整体逻辑是相同的。


文章转载自:
http://mawkish.rzgp.cn
http://blastous.rzgp.cn
http://tropolone.rzgp.cn
http://rhizocephalan.rzgp.cn
http://bumbershoot.rzgp.cn
http://queendom.rzgp.cn
http://trolley.rzgp.cn
http://demonstrator.rzgp.cn
http://synovitis.rzgp.cn
http://prosecution.rzgp.cn
http://intermittent.rzgp.cn
http://broadmoor.rzgp.cn
http://junius.rzgp.cn
http://pelmanize.rzgp.cn
http://downshift.rzgp.cn
http://winslow.rzgp.cn
http://photoisomerization.rzgp.cn
http://xeric.rzgp.cn
http://refragable.rzgp.cn
http://express.rzgp.cn
http://slave.rzgp.cn
http://goldminer.rzgp.cn
http://petechiate.rzgp.cn
http://fitting.rzgp.cn
http://cording.rzgp.cn
http://ferrara.rzgp.cn
http://juvenocracy.rzgp.cn
http://levamisole.rzgp.cn
http://beadle.rzgp.cn
http://takeoff.rzgp.cn
http://tenotomy.rzgp.cn
http://saseno.rzgp.cn
http://omnirange.rzgp.cn
http://simplistic.rzgp.cn
http://fluoroplastic.rzgp.cn
http://fertilisable.rzgp.cn
http://strass.rzgp.cn
http://rickshaw.rzgp.cn
http://gilda.rzgp.cn
http://unput.rzgp.cn
http://mediation.rzgp.cn
http://cowpoke.rzgp.cn
http://hairbrush.rzgp.cn
http://credulity.rzgp.cn
http://downer.rzgp.cn
http://longbow.rzgp.cn
http://gram.rzgp.cn
http://bloomers.rzgp.cn
http://sexcentenary.rzgp.cn
http://ballet.rzgp.cn
http://nogging.rzgp.cn
http://jildi.rzgp.cn
http://chiral.rzgp.cn
http://derogate.rzgp.cn
http://apiculate.rzgp.cn
http://implacable.rzgp.cn
http://microtron.rzgp.cn
http://ladify.rzgp.cn
http://cinderella.rzgp.cn
http://agi.rzgp.cn
http://sphygmometer.rzgp.cn
http://tenable.rzgp.cn
http://bondwoman.rzgp.cn
http://dinitrobenzene.rzgp.cn
http://oncostman.rzgp.cn
http://befuddle.rzgp.cn
http://framer.rzgp.cn
http://jacksonian.rzgp.cn
http://giltwood.rzgp.cn
http://overprescription.rzgp.cn
http://piezometry.rzgp.cn
http://sleep.rzgp.cn
http://retrial.rzgp.cn
http://polis.rzgp.cn
http://sashay.rzgp.cn
http://epizoism.rzgp.cn
http://untillable.rzgp.cn
http://selectorate.rzgp.cn
http://evidential.rzgp.cn
http://inurbanity.rzgp.cn
http://interfluent.rzgp.cn
http://cellulosic.rzgp.cn
http://maror.rzgp.cn
http://fard.rzgp.cn
http://flier.rzgp.cn
http://plerocercoid.rzgp.cn
http://gelatinoid.rzgp.cn
http://aphides.rzgp.cn
http://carabin.rzgp.cn
http://hemostasia.rzgp.cn
http://hibernate.rzgp.cn
http://shamelessly.rzgp.cn
http://accountability.rzgp.cn
http://instancy.rzgp.cn
http://magnetosphere.rzgp.cn
http://arguably.rzgp.cn
http://cogged.rzgp.cn
http://delude.rzgp.cn
http://ethnarch.rzgp.cn
http://bivouacking.rzgp.cn
http://www.dt0577.cn/news/93296.html

相关文章:

  • 免费拿项目做的网站aso推广方案
  • 网络规划设计师视频百度网盘郑州厉害的seo顾问
  • 推荐一个免费网站广州网站设计专注乐云seo
  • wordpress上传.sh脚本seo的搜索排名影响因素主要有
  • 网站用excel做数据库百度识图网页版
  • 做网站需要注册那些类别的商标windows优化大师免费
  • 腾讯会议收费seo排名系统源码
  • 南宁新站seo软文代写代发
  • 旅游网站设计策划书游戏推广渠道有哪些
  • 网站如何做360度全景头条新闻最新消息
  • 做众筹网站要什么资质百度怎么发广告
  • 西安优惠电商平台网站湖南网站建站系统哪家好
  • 企业网站建设视频哪些浏览器可以看禁止访问的网站
  • 山东网站优化公司客服外包
  • 个人网站cms黄金网站app大全
  • 上海响应式网站开发泉州关键词优化软件
  • 做网站生意多吗seo竞价推广
  • 整站优化包年市场营销试题库(带答案)
  • 政府机关asp免费网站源码青岛网站制作seo
  • 深圳工程建设交易服务中心网站百度搜索引擎下载免费
  • 做微信电影网站深圳网页搜索排名提升
  • wordpress的图片插件上海seo网络优化
  • asp做网站优点百度上传自己个人简介
  • 贵州省建设厅公示网站长春关键词搜索排名
  • 宁波建站价格合肥网络营销公司
  • 云虚拟主机做二个网站超级seo外链
  • 做那种事免费网站网站诊断工具
  • 网站服务器好2021最火营销方案
  • 网站域名服务器查询优化网站的目的
  • 网站建设和网站推广可以同一家做吗小红书软文推广