博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《python+opencv实践》一、基于颜色的物体追踪(下)
阅读量:4093 次
发布时间:2019-05-25

本文共 2870 字,大约阅读时间需要 9 分钟。

本文对

做了功能上的强化,强化如下:

(1)加了pts清空,即当没有检测到目标时,清空pts,显示的图像上不再有轨迹;

(2)加了运动方向判别,能够判别目标的运动方向及当前坐标。

from collections import  dequeimport numpy as npimport time#import imutilsimport cv2#设定红色阈值,HSV空间redLower = np.array([170, 100, 100])redUpper = np.array([179, 255, 255])#初始化追踪点的列表mybuffer = 16pts = deque(maxlen=mybuffer)counter = 0#打开摄像头camera = cv2.VideoCapture(0)#等待两秒time.sleep(3)#遍历每一帧,检测红色瓶盖while True:    #读取帧    (ret, frame) = camera.read()    #判断是否成功打开摄像头    if not ret:        print 'No Camera'        break    #frame = imutils.resize(frame, width=600)    #转到HSV空间    hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)    #根据阈值构建掩膜    mask = cv2.inRange(hsv, redLower, redUpper)    #腐蚀操作    mask = cv2.erode(mask, None, iterations=2)    #膨胀操作,其实先腐蚀再膨胀的效果是开运算,去除噪点    mask = cv2.dilate(mask, None, iterations=2)    cnts = cv2.findContours(mask.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)[-2]    #初始化瓶盖圆形轮廓质心    center = None    #如果存在轮廓    if len(cnts) > 0:        #找到面积最大的轮廓        c = max(cnts, key = cv2.contourArea)        #确定面积最大的轮廓的外接圆        ((x, y), radius) = cv2.minEnclosingCircle(c)        #计算轮廓的矩        M = cv2.moments(c)        #计算质心        center = (int(M["m10"]/M["m00"]), int(M["m01"]/M["m00"]))        #只有当半径大于10时,才执行画图        if radius > 10:            cv2.circle(frame, (int(x), int(y)), int(radius), (0, 255, 255), 2)            cv2.circle(frame, center, 5, (0, 0, 255), -1)            #把质心添加到pts中,并且是添加到列表左侧            pts.appendleft(center)    else:#如果图像中没有检测到瓶盖,则清空pts,图像上不显示轨迹。        pts.clear()        for i in xrange(1, len(pts)):        if pts[i - 1] is None or pts[i] is None:            continue        #计算所画小线段的粗细        thickness = int(np.sqrt(mybuffer / float(i + 1)) * 2.5)        #画出小线段        cv2.line(frame, pts[i - 1], pts[i], (0, 0, 255), thickness)        #判断移动方向        if counter >= 10 and i == 1 and len(pts) >= 10:            dX = pts[-10][0] - pts[i][0]            dY = pts[-10][1] - pts[i][1]            (dirX, dirY) = ("", "")                        if np.abs(dX) > 20:                dirX = "East" if np.sign(dX) == 1 else "West"                        if np.abs(dY) > 20:                dirY = "North" if np.sign(dY) == 1 else "South"                        if dirX != "" and dirY != "":                direction = "{}-{}".format(dirY, dirX)            else:                direction = dirX if dirX != "" else dirY                    cv2.putText(frame, direction, (20, 50), cv2.FONT_HERSHEY_SIMPLEX, 2,                         (0, 255, 0), 3)            cv2.putText(frame, "dx: {}, dy: {}".format(dX, dY), (10, frame.shape[0] - 10),                         cv2.FONT_HERSHEY_SIMPLEX, 0.35, (0, 0, 255), 1)                cv2.imshow('Frame', frame)    #键盘检测,检测到esc键退出    k = cv2.waitKey(1)&0xFF    counter += 1    if k == 27:        break#摄像头释放camera.release()#销毁所有窗口cv2.destroyAllWindows()

由于视频是镜像的,所以图片上的South-East结果是正确的!

你可能感兴趣的文章
想快速上手机器学习?来看下这个 GitHub 项目!
查看>>
GitHub 标星 3.6k,一本开源的深度学习中文教程!
查看>>
9 款你不能错过的 JSON 工具
查看>>
就在昨天,全球 42 亿 IPv4 地址宣告耗尽!
查看>>
200页!分享珍藏很久的Python学习知识手册(附链接)
查看>>
程序员之神
查看>>
4 岁小女孩给 Linux 内核贡献提交
查看>>
推荐几个私藏很久的技术公众号给大家
查看>>
20 个 2020 年软件开发趋势预测
查看>>
王垠受邀面试阿里 P9,被 P10 面跪后网上怒发文,惨打 325 的 P10 赵海平回应了!...
查看>>
Python 趣味打怪:147 段简单代码助你从入门到大师
查看>>
按我说的来,让 VS Code 好用 10 倍 | VS Code 新手指南
查看>>
恕我直言,有了这款 IDEA 插件,你可能只需要写 30% 的代码...
查看>>
这几个冷门却实用的 Python 库,我爱了!
查看>>
太赞了,IDEA 2020 要本土化,真的是全中文了!
查看>>
面试官,别问我 HTTP 了!看这 30 张图就行!
查看>>
一场地狱级的 MySQL 索引面试!
查看>>
太赞了,微软正式推出 Python 零基础教程!
查看>>
骚操作:Uber 开源 "食人鱼" 工具,专吃落后代码!
查看>>
超酷炫!教你如何用 Python 实现动态可视化交互大屏图...
查看>>