无人机实验(提取目标区域)

       无人机飞行过程中,飞的越高,视野范围也越远,而所需要的区域只是一部分,额外的区域都会成为干扰,那么就需要提取目标区域。

无人机实验(提取目标区域)

       这是我们的高空俯视图,从图中看出,我们的目标区域明显的特点是:很大面积的白色的底。那方法就显而易见了,先删选出白色区域,再提取轮廓点,最后根据轮廓点在原图提取出目标区域。

代码:

import cv2
import numpy as np
import imutils
from imutils.perspective import four_point_transform


frame = cv2.imread("cut3.JPG")
frame = imutils.resize(frame, width=320)    #调整图片大小

edges = cv2.Canny(frame,100,300)   #边缘检测,只是为了显示

#提取白色区域
hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
mask = cv2.inRange(hsv, np.array((0., 0., 160)), np.array((180., 15.,255.)))
mask = cv2.medianBlur(mask,3)           #去椒盐噪

#提取白色区域轮廓点
cnts = cv2.findContours(mask.copy(), cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
aimcnt = None


if len(cnts) > 0:
    #根据面积大小,从大到小排序
    cnts = sorted(cnts, key=cv2.contourArea, reverse=True)
    #找到目标轮廓四个角点
    for i in cnts:
        arc = cv2.arcLength(i, True)    #计算周长,下面函数一般要以周长为参数
        approx = cv2.approxPolyDP(i, 0.1 * arc, True)  #提取近似轮廓点
        if len(approx) == 4:
            aimcnt = approx
            break

#rect = cv2.minAreaRect(cnts[0])
#box = np.int0(cv2.boxPoints(rect))     #这里也能得到四个轮廓点,只是在这幅图中效果没有上面方法理想


#绘制四个目标轮廓点
newFrame=frame.copy()
for i in aimcnt:
    cv2.circle(newFrame, (i[0][0],i[0][1]),4, (0, 0, 255), -1)


#提取目标区域
aimFrame = four_point_transform(frame, aimcnt.reshape(4, 2))
aimMask = four_point_transform(mask, aimcnt.reshape(4, 2))
aimEdges =  four_point_transform(edges, aimcnt.reshape(4, 2))

aimGray = cv2.cvtColor(aimFrame,cv2.COLOR_BGR2GRAY)   #转化为灰度图,进行霍夫圆检测

#检测圆
circles = cv2.HoughCircles(aimGray,cv2.HOUGH_GRADIENT,1,100,param1=100,param2=20,minRadius=1,maxRadius=20)

#绘出圆
if circles is not None:
        for i in circles[0,:]:
            cv2.circle(aimFrame,(i[0],i[1]),i[2],(255,0,0),2)
            Circles_x = int(i[0])
            Circles_y = int(i[1])
        cv2.line(aimFrame, (circles[0][0][0], circles[0][0][1]), (circles[0][1][0], circles[0][1][1]), (255, 0, 0), 2)
else:
    Circles_x = 160  #开启摄像头时的图像中点
    Circles_y = 120


cv2.imshow('newFrame',newFrame)
cv2.imshow('mask',mask)
cv2.imshow('edges',edges)

cv2.imshow('aimFrame',aimFrame)
cv2.imshow('aimMask',aimMask)
cv2.imshow('aimEdges',aimEdges)


cv2.waitKey(0)

结果图:

无人机实验(提取目标区域)

 

源码下载:

         https://github.com/LNanL/drone

上一篇:原生PHP生成二维码(thinkphp5生成二维码)


下一篇:函数指针的书写和用法