【Python】【OpenCV】凸輪廓和Douglas-Peucker演算法

来源:https://www.cnblogs.com/vangoghpeng/archive/2023/12/06/17880586.html
-Advertisement-
Play Games

針對遇到的各種複雜形狀的主體,大多情況下,我們可以求得一個近似的多邊形來簡化視覺圖像處理,因為多邊形是由直線組成的,這樣就可以準確的劃分區域來便捷後續的操作。 cv2.arcLength() Method: 參數: curve:要計算周長的輪廓,可以是一個矩形、圓形、多邊形等封閉曲線。 closed ...


針對遇到的各種複雜形狀的主體,大多情況下,我們可以求得一個近似的多邊形來簡化視覺圖像處理,因為多邊形是由直線組成的,這樣就可以準確的劃分區域來便捷後續的操作。

 

cv2.arcLength() Method:

參數:

  • curve:要計算周長的輪廓,可以是一個矩形、圓形、多邊形等封閉曲線。
  • closed:一個布爾值,表示輪廓是否為封閉曲線。如果 closed=True,則假設輪廓是閉合的;如果 closed=False,則假設輪廓是開放的。

返回值:

  • retval:給定輪廓的周長或長度。如果輪廓是一個封閉曲線(如圓形、多邊形等),則 retval 表示該曲線的周長;如果輪廓是一條開放曲線(如一條直線),則 retval 表示該曲線的長度。

 

cv2.approxPolyDP() Method:

參數:

  • curve:要逼近的輸入輪廓。
  • epsilon:指定逼近精度的參數,即逼近多邊形與原始曲線之間的最大距離。這個參數決定了逼近的精度,值越小表示逼近得越精確。通常情況下,這個值是一個很小的正數。
  • closed:一個布爾值,表示逼近多邊形是否是封閉的。如果 closed=True,則表示輸出的逼近多邊形是封閉的,即首尾相連形成一個閉合多邊形;如果 closed=False,則表示輸出的逼近多邊形是開放的。

返回值:

  • approxCurve:表示逼近後的多邊形曲線。這是一個新的輪廓,它是對輸入輪廓進行多邊形逼近後得到的結果。

 

 1 import cv2
 2 import numpy
 3 
 4 img = cv2.imread('../img/img.png', -1)
 5 ret, thresh = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
 6 contours, hier = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
 7 
 8 img = cv2.cvtColor(img, cv2.COLOR_GRAY2BGR)
 9 for c in contours:
10     # 計算輪廓的總長的百分之一,作為最大差值
11     epsilon = 0.01 * cv2.arcLength(c, True)
12     # 將輪廓近似為一個多邊形
13     approx = cv2.approxPolyDP(c, epsilon, True)
14     # 獲取輪廓的凸多邊形,並且可以完全包含整個輪廓
15     hull = cv2.convexHull(c)
16 
17     # cv2.drawContours(img, [c], -1, (0, 255, 0), 2)
18     cv2.drawContours(img, [approx], -1, (255, 255, 0), 2)
19     cv2.drawContours(img, [hull], -1, (0, 0, 255), 2)
20 
21 
22 # img = cv2.cvtColor(img, cv2.COLOR_GRAY2BGR)
23 # img = cv2.drawContours(img, contours, -1, (0, 255, 0), 2)
24 cv2.imshow('', img)
25 cv2.waitKey()
26 cv2.destroyAllWindows()

 

上述代碼中,可以修改 epsilon(ε)參數來獲得不同逼近的多邊形,當 epsilon(ε)越大,則得到的多邊形越簡易,越小則越貼近傳入的輪廓形狀。

 

運行結果:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 實現原理是使用TWEEN.Tween實現動畫效果 實現 汽車模型載入 使用Promise編寫模型的非同步載入方法 參數position是汽車初始位置,參數rotation是汽車初始朝向 Car.prototype.loadCar = function (position, rotation) { le ...
  • 人生的游戲不在於拿了一副好牌,而在於怎樣去打好壞牌,世上沒有常勝將軍,勇於超越自我者才能得到最後的獎盃。 1. 父子組件通信方式 1.1 父組件傳遞到子組件 直接通過屬性進行傳遞,數據的傳遞可以提高組件的復用性。 1.2 子組件傳遞到父組件 通過回調函數(callback)來實現。 ref 標記:父 ...
  • 本文本記錄了使用 Vue3+Vite+ElementPlus 從0開始搭建一個前端工程會面臨的常見問題,沒有技術深度,但全都是解決實際問題的乾貨,可以當作是問題手冊以備後用。本人日常工作偏後端開發,因此,文中的一些前端術語描述可能不嚴謹,敬請諒解。重點是:這裡記錄的解決方案都是行之有效果的,拿來即可 ...
  • Vite 是一種新型前端構建工具,在我們保險前端項目中已經推動並應用很久了,Vite 能夠顯著降低構建時間,提升前端開發效率。 ...
  • 上一章講完如何獲取用戶信息授權 後,下一步就可以進行小程式支付了。 本期就來介紹下支付寶小程式支付如何實現。 PS:接入前的準備工作可以參考:接入準備;接入指南可參考:接入指南~ 獲取小程式支付許可權 獲取許可權分為三步:分別是 賬號開通 JSAPI 支付、賬號與小程式賬號綁定 以及 小程式綁定 JSA ...
  • 元素分類 一、行內元素 1.不獨占一行,高寬由內容撐開 2.無法設置width和height 3.margin(單用無效,配合別的標簽可以有效,下麵案例中有解釋)/padding的上下無效,但是左右有效 <a></a> <strong></strong> <span></span> 二、行內塊元素 ...
  • 一、定義 提供一種方法順序訪問一個聚合對象中的各個元素,且不用暴露該對象的內部表示。迭代器模式是一種對象行為型模式,又稱為游標(Cursor)模式。 二、描述 在軟體系統中,聚合對象擁有兩個職責:一是存儲數據,二是遍曆數據。從依賴性來看,前者是聚合對象的基本職責,而後者既是可變化的,又是可分離的。因 ...
  • 首先回顧了傳統SSM開發步驟,介紹了項目實現過程,從需求分析、設計、編碼到測試的流程。展示了一個簡單的員工信息管理功能,並提供了環境搭建及相關依賴配置的詳細代碼和配置。接著,提出了SSM開發存在的問題,如配置繁瑣和版本相容性。第二章介紹了Spring Boot的引言,解釋了Spring Boot的概... ...
一周排行
    -Advertisement-
    Play Games
  • PasteSpider是什麼? 一款使用.net編寫的開源的Linux容器部署助手,支持一鍵發佈,平滑升級,自動伸縮, Key-Value配置,項目網關,環境隔離,運行報表,差量升級,私有倉庫,集群部署,版本管理等! 30分鐘上手,讓開發也可以很容易的學會在linux上部署你得項目! [從需求角度介 ...
  • SQLSugar是什麼 **1. 輕量級ORM框架,專為.NET CORE開發人員設計,它提供了簡單、高效的方式來處理資料庫操作,使開發人員能夠更輕鬆地與資料庫進行交互 2. 簡化資料庫操作和數據訪問,允許開發人員在C#代碼中直接操作資料庫,而不需要編寫複雜的SQL語句 3. 支持多種資料庫,包括但 ...
  • 在C#中,經常會有一些耗時較長的CPU密集型運算,因為如果直接在UI線程執行這樣的運算就會出現UI不響應的問題。解決這類問題的主要途徑是使用多線程,啟動一個後臺線程,把運算操作放在這個後臺線程中完成。但是原生介面的線程操作有一些難度,如果要更進一步的去完成線程間的通訊就會難上加難。 因此,.NET類 ...
  • 一:背景 1. 講故事 前些天有位朋友在微信上丟了一個崩潰的dump給我,讓我幫忙看下為什麼出現了崩潰,在 Windows 的事件查看器上顯示的是經典的 訪問違例 ,即 c0000005 錯誤碼,不管怎麼說有dump就可以上windbg開幹了。 二:WinDbg 分析 1. 程式為誰崩潰了 在 Wi ...
  • CSharpe中的IO+NPOI+序列化 文件文件夾操作 學習一下常見的文件、文件夾的操作。 什麼是IO流? I:就是input O:就是output,故稱:輸入輸出流 將數據讀入記憶體或者記憶體輸出的過程。 常見的IO流操作,一般說的是[記憶體]與[磁碟]之間的輸入輸出。 作用 持久化數據,保證數據不再 ...
  • C#.NET與JAVA互通之MD5哈希V2024 配套視頻: 要點: 1.計算MD5時,SDK自帶的計算哈希(ComputeHash)方法,輸入輸出參數都是byte數組。就涉及到字元串轉byte數組轉換時,編碼選擇的問題。 2.輸入參數,字元串轉byte數組時,編碼雙方要統一,一般為:UTF-8。 ...
  • CodeWF.EventBus,一款靈活的事件匯流排庫,實現模塊間解耦通信。支持多種.NET項目類型,如WPF、WinForms、ASP.NET Core等。採用簡潔設計,輕鬆實現事件的發佈與訂閱。通過有序的消息處理,確保事件得到妥善處理。簡化您的代碼,提升系統可維護性。 ...
  • 一、基本的.NET框架概念 .NET框架是一個由微軟開發的軟體開發平臺,它提供了一個運行時環境(CLR - Common Language Runtime)和一套豐富的類庫(FCL - Framework Class Library)。CLR負責管理代碼的執行,而FCL則提供了大量預先編寫好的代碼, ...
  • 本章將和大家分享在ASP.NET Core中如何使用高級客戶端NEST來操作我們的Elasticsearch。 NEST是一個高級別的Elasticsearch .NET客戶端,它仍然非常接近原始Elasticsearch API的映射。所有的請求和響應都是通過類型來暴露的,這使得它非常適合快速上手 ...
  • 參考delphi的代碼更改為C# Delphi 檢測密碼強度 規則(仿 google) 仿 google 評分規則 一、密碼長度: 5 分: 小於等於 4 個字元 10 分: 5 到 7 字元 25 分: 大於等於 8 個字元 二、字母: 0 分: 沒有字母 10 分: 全都是小(大)寫字母 20 ...