opencv——实现智能小车巡线

代码如下:

import cv2
import numpy as np

screen_height = 480
screen_width = 640

def readImg(path):
    img = cv2.imread(path, 1)
    img = cv2.resize(img, (screen_width, screen_height))
    return img


def createWait():
    img = np.ones((screen_height, screen_width), dtype=np.uint8)
    img[:, :] = 225
    return img

def calculate(dst2):
    points = []
    sum_x = 0
    sum_y = 0
    for y in range(screen_height):
        for x in range(screen_width):
            if dst2[y][x] == 0:
                points.append([x, y])
    for point in points:
        sum_x += point[0]
        sum_y += point[1]
    points_len = len(points)
    average_x = sum_x / points_len
    average_y = sum_y / points_len

    sum_up = 0
    sum_down = 0
    for point in points:
        sum_up += point[0] * point[1]
        sum_down += point[0] ** 2
    sum_up -= points_len * average_x * average_y
    sum_down -= points_len * average_x ** 2
    b = sum_up / sum_down
    a = average_y - b * average_x
    end = {'b': b, 'a': a}

    return end

def getLine(path):
    frame = readImg(path)
    # 灰度化
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    cv2.imwrite('./gray.jpg', gray)


    # 二值化
    threshold_image = cv2.threshold(gray, 60, 225, cv2.THRESH_BINARY)
    binary = threshold_image[1]
    cv2.imwrite('./binary.jpg', binary)


    # 取反
    subtract = cv2.subtract(createWait(), binary)
    cv2.imwrite('./dst2.jpg', subtract)

    # 腐蚀
    kernel = np.ones((5, 5), np.uint8)
    erode = cv2.erode(subtract, kernel, iterations=3)

    # 膨胀
    dilate = cv2.dilate(erode, kernel)

    # 寻找轮廓
    contours = cv2.findContours(dilate, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)
    contour = contours[0]

    area = []

    for k in range(len(contour)):
        area.append((cv2.contourArea(contour[k])))

    max_idx = np.argmax(np.array(area))

    tatImg = cv2.drawContours(createWait(), contour, max_idx, (0, 0, 225), -1)
    cv2.imwrite('./tatImg.jpg', tatImg)

    return calculate(tatImg)


def showResult(path):
    img = readImg(path)
    end = getLine(path)

    for i in range(screen_width):
        cv2.circle(img,
                   (int(i), int(end['b'] * i + end['a'])),
                   2,
                   (0, 0, 225),
                   0,
                   1)
    cv2.imshow(path[6:], img)
    cv2.imwrite('./img.jpg', img)


if __name__ == '__main__':
    path = r'path/to/your/img'
    showResult(path=path)

识别效果:

a)原图
在这里插入图片描述
b)轨迹轮廓
在这里插入图片描述

c)边缘检测
在这里插入图片描述
d)轨迹绘制
在这里插入图片描述

  • 2
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
opencv——基于python语言实现》pdf 是一本介绍了使用Python语言实现OpenCV库的编程技术的电子书。 OpenCV 是一个广泛应用于计算机视觉领域的开源库,它提供了许多用于图像处理和计算机视觉的函数和算法。 该电子书首先介绍了OpenCVPython的基本概念和背景知识,如图像处理的基本操作和图像编程的基本原理。它还详细介绍了OpenCV库中的各种图像处理算法和函数,并提供了许多示例代码和案例研究,以帮助读者理解和应用这些算法和函数。 该电子书还涵盖了如何使用PythonOpenCV进行人脸检测、目标跟踪、图像识别和图像分割等常见任务。它还介绍了如何利用OpenCVPython进行视频处理和实时图像处理,并展示了如何与摄像头和外部设备进行交互。 这本书对于希望学习和应用OpenCVPython进行图像处理和计算机视觉的人来说是非常有价值的。它详细讲解了OpenCV库中的各种函数和算法的使用方法,并提供了丰富的示例和案例研究。读者可以通过学习该书,深入了解OpenCVPython的使用,并掌握图像处理和计算机视觉的基本原理和技术,从而能够应用于实际项目和应用中。 总之,《opencv——基于python语言实现》pdf 是一本适合初学者和有一定基础的人学习和应用OpenCVPython进行图像处理和计算机视觉的电子书。通过阅读该书,读者可以全面了解OpenCV库的使用方法和基本原理,并掌握使用Python语言进行图像处理和计算机视觉任务的技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值