Python OpenCV 直線檢測

本文將介紹在Python OpenCV中進行直線檢測的方法,主要涉及到圖像的邊緣檢測、霍夫變換和繪製直線等操作。

一、邊緣檢測

由於直線檢測是從圖像的邊緣開始的,因此必須先找到圖像中的邊緣。實現邊緣檢測的方法有很多,這裡介紹一種簡單但常用的方法:Canny邊緣檢測。

Canny邊緣檢測是一種基於梯度的方法,它通過計算每個像素點的梯度和方向,從而找到圖像中的邊緣。在Python OpenCV中,可以使用cv2.Canny()函數來實現Canny邊緣檢測。

import cv2

img = cv2.imread('image.jpg', 0) # 以灰度方式讀入圖片
edges = cv2.Canny(img, 50, 150) # Canny邊緣檢測
cv2.imshow('Canny', edges)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代碼中,使用cv2.imread()函數以灰度方式讀入一張圖片,然後使用cv2.Canny()函數進行Canny邊緣檢測,最後使用cv2.imshow()函數顯示邊緣檢測結果。

二、霍夫變換

霍夫變換是一種常用於圖像處理中的技術,它可以將圖像中的某些特定形狀(如直線、圓)從投影空間映射到參數空間中,並通過參數空間中的投票機制找到形狀的位置和方向。

在進行直線檢測時,可以使用霍夫線變換(Hough Line Transform)來找到圖像中的直線。在Python OpenCV中,可以使用cv2.HoughLines()函數進行霍夫變換。

import cv2
import numpy as np

img = cv2.imread('image.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 轉灰度圖像
edges = cv2.Canny(gray, 50, 150) # Canny邊緣檢測
lines = cv2.HoughLines(edges, 1, np.pi/180, 200) # 霍夫線變換

for line in lines:
    rho, theta = line[0]
    a = np.cos(theta)
    b = np.sin(theta)
    x0 = a * rho
    y0 = b * rho
    x1 = int(x0 + 1000 * (-b))
    y1 = int(y0 + 1000 * (a))
    x2 = int(x0 - 1000 * (-b))
    y2 = int(y0 - 1000 * (a))
    cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)

cv2.imshow('Hough Lines', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代碼中,使用cv2.HoughLines()函數進行霍夫線變換,返回的是一組笛卡爾坐標系(rho, theta),其中rho表示直線到原點的距離,theta表示直線與x軸的夾角。然後對每條直線進行處理,獲取起始和結束坐標,最後使用cv2.line()函數繪製直線。

三、霍夫概率變換

霍夫概率變換(Hough Line Transform)是一種基於霍夫變換的改進方法,其主要優點是可以對圖像中的部分區域進行直線檢測,避免檢測整張圖像。

在Python OpenCV中,可以使用cv2.HoughLinesP()函數進行霍夫概率變換。

import cv2
import numpy as np

img = cv2.imread('image.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 轉灰度圖像
edges = cv2.Canny(gray, 50, 150) # Canny邊緣檢測
lines = cv2.HoughLinesP(edges, 1, np.pi/180, 100, minLineLength=100, maxLineGap=10) # 霍夫概率線變換

for line in lines:
    x1, y1, x2, y2 = line[0]
    cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)

cv2.imshow('Hough Lines P', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代碼中,使用cv2.HoughLinesP()函數進行霍夫概率變換,其中minLineLength表示每條直線的最短長度,maxLineGap表示兩條直線之間的最大間隔。然後對每條直線進行處理,獲取起始和結束坐標,最後使用cv2.line()函數繪製直線。

四、結論

本文介紹了Python OpenCV中進行直線檢測的方法,主要涉及到圖像的邊緣檢測、霍夫變換和繪製直線等操作。在實際應用中,可以選擇不同的方法進行直線檢測,從而達到最佳效果。

原創文章,作者:JDXSV,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/375499.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
JDXSV的頭像JDXSV
上一篇 2025-04-29 12:49
下一篇 2025-04-29 12:49

相關推薦

  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • Python編程二級證書考試相關現已可以上網購買

    計算機二級Python考試是一項重要的國家級認證考試,也是Python編程的入門考試。與其他考試一樣,Python編程二級證書的考生需要進入正式考試,而為了備考,這篇文章將詳細介紹…

    編程 2025-04-29
  • Python字符串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字符串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字符串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29

發表回復

登錄後才能評論