您好,登錄后才能下訂單哦!
import cv2 from matplotlib import pyplot as plt import numpy as np img= cv2.imread('39.jpg')#加載圖片 cv2.namedWindow('Canny edge detect')#設(shè)置窗口,cv2.WINDOW_NORMAL表示窗口大小可自動調(diào)節(jié) cv2.namedWindow('Original Image',cv2.WINDOW_NORMAL) cv2.namedWindow('Canny edgeImage',cv2.WINDOW_NORMAL) def nothing(x):#回調(diào)函數(shù) pass #創(chuàng)建兩個(gè)滑動條,分別控制minVal(最小閾值)、maxVal(最大閾值). # minVal:滑動條名稱; 'Canny edge detect':窗口名; 60:滑動條默認(rèn)滑動位置; 300:最大值 ; nothing:回調(diào)函數(shù) cv2.createTrackbar('minVal','Canny edge detect',60,300,nothing) cv2.createTrackbar('maxVal','Canny edge detect',100,400,nothing) while(1): #獲得滑動條所在的位置 #cv2.getTrackbarPos(滑動條名稱,窗口名); minVal = cv2.getTrackbarPos('minVal','Canny edge detect') maxVal = cv2.getTrackbarPos('maxVal','Canny edge detect') #Canny邊緣檢測 #cv2.Canny函數(shù)參數(shù)解析: # img:原圖像名 # minVal:最小梯度 # maxVal:最大梯度 # 5 :5*5大小的高斯濾波器(卷積核),用來消除噪聲影響 # L2gradient :求圖像梯度,從而進(jìn)行去除非邊界上的點(diǎn)(非極大值抑制) edgeImage = cv2.Canny(img,minVal,maxVal,5,L2gradient=True)
L2gradient,它可以用來設(shè)定 求梯度大小的方程。如果設(shè)為 True,就會使用方程,
否則 False ,使用方程:
其中Gx,Gy為使用 Sobel 算子的計(jì)算水平方向和豎直方向的一階導(dǎo)數(shù)。
#顯示圖片 cv2.imshow('Original Image',img) #原圖 cv2.imshow('Canny edgeImage',edgeImage) # Canny檢測后的圖 k = cv2.waitKey(1) if k ==ord('w')& 0xFF: # 按 w 退出 break cv2.destroyAllWindows()#銷毀窗口
效果圖如下。
總結(jié)
以上所述是小編給大家介紹的使用OpenCV-python3實(shí)現(xiàn)滑動條更新圖像的Canny邊緣檢測功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。