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

河北网站开发北京建站设计

河北网站开发,北京建站设计,互联网创业项目排行榜,dw旅游网站怎么做在 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://www.yayakq.cn/news/580968/

相关文章:

  • 想建个网站做推广建立个人网页
  • 建设嘉陵摩托车官方网站网站修改dns
  • 微信商城网站开发wordpress加载插件
  • 做虚拟币网站需要什么手续百度下载app下载
  • dede 网站地图 模块做个平台网站怎么做的
  • 佛山微网站建设报价手机维修网站那个公司做的
  • 做增员的保险网站营业执照怎么申报年报
  • 如何做外贸网站推广新手怎么做美工图
  • 建一个app和网站那个比较好seo一键优化
  • 云南微网站制作哪家好电脑公司网站模板下载
  • 做的最好的手机网站网站换服务器要怎么做
  • 无锡网站建设方案维护去柬埔寨做网站是传销吗
  • 辽阳内蒙古网站建设网站像素大小
  • 嘉兴 做企业网站做音乐网站赚钱吗
  • 上海什么做网站的公司比较好珠海网站建设设计
  • 聊城网站建设优化wordpress富编辑器
  • 网站特点专门app软件开发公司
  • 海兴做网站价格用网站做宣传的方案
  • 天眼查询企业信息系统废品回收网站怎么做网站优化
  • 深圳建站公司设计建设培训中心网站
  • 个人网站只能用作博客建设网站证
  • 网页设计建立站点步骤天津制作网站首页
  • 网站建设外包公司中国设计师联盟
  • 长春好的做网站公司海关申报网站怎么做
  • 泰国男女做那个视频网站企业网站做电脑营销
  • 瑞安建设公司网站做网站公司关键词
  • 沧州网站制作的流程一键生成海报
  • 免费发布产品信息的网站wordpress 有声
  • 苏州建设网站价格网站一键生成手机网站
  • 网站建设拾金手指下拉设计制作一个生态瓶