opencv中凸包运算函数convexHull()的使用

2024-06-20 16:12

本文主要是介绍opencv中凸包运算函数convexHull()的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

1.功能描述

该函数cv::convexHull用于寻找一组二维点集的凸包,采用的是Sklansky算法[242],当前实现中具有O(N logN)的时间复杂度。

1.1什么是凸包?

让我们先从术语的两部分来理解——“凸”和“包”。

一个“凸”对象是指没有内角大于180度的对象。非凸的对象称为非凸的或凹的,下图展示了凸对象和非凸对象的例子。

包指的是物体的外部或轮廓。

因此,一组点或形状的凸包是一个紧贴着这些点或形状的最紧凑的凸边界。如图2所示,两个黑色形状的凸包用红色线条描绘。对于凸对象,其凸包就是其边界本身;而对于凹形状,凸包则是一个最紧致地包围它的凸边界。

2.函数原型


void cv::convexHull	(	InputArray 	points,OutputArray 	hull,bool 	clockwise = false,bool 	returnPoints = true 
)		

3.参数

  • 参数 points 输入的二维点集,存储在std::vector或Mat中.
  • 参数 hull 输出的凸包。它可以是一个索引的整数向量或点的向量。在第一种情况下,凸包元素是原数组中凸包点的基于0的索引(因为凸 包点的集合是原点集的子集)。在第二种情况下,凸包元素即凸包点本身.
  • 参数 clockwise 方向标志。如果该标志为真,输出的凸包按顺时针方向排列。否则,它按照逆时针方向排列。所采用的坐标系统其X轴指向右侧,Y轴指向上方。.
  • 参数 returnPoints 操作标志。当输入为矩阵且该标志为真时,函数返回凸包的点坐标。否则,它返回凸包点在原点集中的索引。如果输出数组是std::vector,该标志将被忽略,输出类型依据vector的实际类型而定:std::vector意味着returnPoints=false(返回索引),std::vector意味着returnPoints=true(返回点坐标)。

注意
points(输入点集)和hull(输出凸包)应该是不同的数组,不支持原地处理。这意味着cv::convexHull函数不会直接修改输入的点集数 组来存储结果,你需要提供一个独立的变量来接收计算出的凸包信息。

4.代码示例

#include "opencv2/highgui.hpp"
#include "opencv2/imgproc.hpp"
#include <iostream>
using namespace cv;
using namespace std;
int main( int argc, char** argv )
{Mat img( 500, 500, CV_8UC3 );RNG& rng = theRNG();for ( ;; ){int i, count = ( unsigned )rng % 100 + 1;vector< Point > points;for ( i = 0; i < count; i++ ){Point pt;pt.x = rng.uniform( img.cols / 4, img.cols * 3 / 4 );pt.y = rng.uniform( img.rows / 4, img.rows * 3 / 4 );points.push_back( pt );}vector< Point > hull;convexHull( points, hull, true );img = Scalar::all( 0 );for ( i = 0; i < count; i++ )circle( img, points[ i ], 3, Scalar( 0, 0, 255 ), FILLED, LINE_AA );imshow( "original", img );polylines( img, hull, true, Scalar( 0, 255, 0 ), 1, LINE_AA );imshow( "hull", img );char key = ( char )waitKey();if ( key == 27 || key == 'q' || key == 'Q' )  // 'ESC'break;}return 0;
}

5.运行结果

根据随机生成的点,然后根据这些点去进行运算,再把这些凸包点连接起来,如下图所示:

这篇关于opencv中凸包运算函数convexHull()的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078622

相关文章

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经