【STM32+OPENMV】矩形识别

一、准备工作

有关OPENMV最大色块追踪及与STM32通信内容,详情见【STM32+HAL】与OpenMV通信

二、所用工具

1、芯片:STM32F103C8T6

2、CUBEMX配置软件

3、KEIL5

4、OPENMV

三、实现功能

寻找黑色矩形,并将最大矩形的四个边缘坐标发送给STM32

四、OpenMV IDE

1、寻找最大的矩形,并沿矩形边框绘制线条
python 复制代码
# 寻找最大的矩形
# 沿矩形边框绘制线条
import sensor, image, time

# 相机初始化
sensor.reset()
sensor.set_pixformat(sensor.GRAYSCALE)      # 设置图像格式为灰度
sensor.set_framesize(sensor.QQQVGA)         # 设置图像大小
sensor.skip_frames(time=2000)               # 等待设置生效
clock = time.clock()                        # 用于跟踪帧率

while(True):
    clock.tick()
    img = sensor.snapshot().lens_corr(1.8)

    # 使用find_rects()方法寻找图像中的矩形
    rects = img.find_rects(threshold = 10000)

    # 初始化变量来存储最大矩形的信息
    max_area = 0
    max_rect = None

    # 遍历所有找到的矩形,找出面积最大的矩形
    for rect in rects:
        # 计算当前矩形的面积
        area = rect.w() * rect.h()
        # 如果当前矩形的面积大于之前记录的最大面积,则更新最大矩形和最大面积
        if area > max_area:
            max_area = area
            max_rect = rect

    # 如果找到了最大的矩形,则绘制它的边框
    if max_rect:
        corners = max_rect.corners()    # 获取最大矩形的四个角点
        # 绘制最大矩形的四条边
        for i in range(len(corners)):
            start_point = corners[i]
            end_point = corners[(i+1) % 4]
            img.draw_line(start_point[0], start_point[1], end_point[0], end_point[1], color = 255)

        print(corners)                  # 打印最大矩形的四个角点
2、完整通信+识别代码
python 复制代码
# 寻找最大的矩形
# 沿矩形边框绘制线条
import sensor, image, time
import ustruct
from pyb import UART


# 串口初始化
uart = UART(3, 115200, timeout_char=200)
uart.init(115200, bits=8, parity=None, stop=1)  # init with given parameters

# 相机初始化
sensor.reset()
sensor.set_pixformat(sensor.GRAYSCALE)      # 设置图像格式为灰度
sensor.set_framesize(sensor.QQQVGA)         # 设置图像大小
sensor.skip_frames(time=2000)               # 等待设置生效
clock = time.clock()                        # 用于跟踪帧率



def send_data(x):
    global uart;
    uart.write(bytearray([0xb3,0xb3]))
    uart.write(str(x))
    uart.write(bytearray([0x0d,0x0a]))



while(True):
    clock.tick()
    img = sensor.snapshot().lens_corr(1.8)

    # 使用find_rects()方法寻找图像中的矩形
    rects = img.find_rects(threshold = 10000)

    # 初始化变量来存储最大矩形的信息
    max_area = 0
    max_rect = None

    # 遍历所有找到的矩形,找出面积最大的矩形
    for rect in rects:
        # 计算当前矩形的面积
        area = rect.w() * rect.h()
        # 如果当前矩形的面积大于之前记录的最大面积,则更新最大矩形和最大面积
        if area > max_area:
            max_area = area
            max_rect = rect

    # 如果找到了最大的矩形,则绘制它的边框
    if max_rect:
        corners = max_rect.corners()    # 获取最大矩形的四个角点
        # 绘制最大矩形的四条边
        for i in range(len(corners)):
            start_point = corners[i]
            end_point = corners[(i+1) % 4]
            img.draw_line(start_point[0], start_point[1], end_point[0], end_point[1], color = 255)

        send_data(corners)

        print(corners)                  # 打印最大矩形的四个角点

五、源码提供

【STM32+OPENMV】矩形识别资源

相关推荐
森焱森2 小时前
无人机三轴稳定控制(2)____根据目标俯仰角,实现俯仰稳定化控制,计算出升降舵输出
c语言·单片机·算法·架构·无人机
白鱼不小白2 小时前
stm32 USART串口协议与外设(程序)——江协教程踩坑经验分享
stm32·单片机·嵌入式硬件
S,D2 小时前
MCU引脚的漏电流、灌电流、拉电流区别是什么
驱动开发·stm32·单片机·嵌入式硬件·mcu·物联网·硬件工程
芯岭技术5 小时前
PY32F002A单片机 低成本控制器解决方案,提供多种封装
单片机·嵌入式硬件
youmdt6 小时前
Arduino IDE ESP8266连接0.96寸SSD1306 IIC单色屏显示北京时间
单片机·嵌入式硬件
嘿·嘘6 小时前
第七章 STM32内部FLASH读写
stm32·单片机·嵌入式硬件
Meraki.Zhang6 小时前
【STM32实践篇】:I2C驱动编写
stm32·单片机·iic·驱动·i2c
几个几个n9 小时前
STM32-第二节-GPIO输入(按键,传感器)
单片机·嵌入式硬件
Despacito0o12 小时前
ESP32-s3摄像头驱动开发实战:从零搭建实时图像显示系统
人工智能·驱动开发·嵌入式硬件·音视频·嵌入式实时数据库
门思科技12 小时前
设计可靠 LoRaWAN 设备时需要考虑的关键能力
运维·服务器·网络·嵌入式硬件·物联网