這個是全網(wǎng)最詳細(xì)的STM32項目教學(xué)視頻。
第一篇在這里:
視頻在這里:
第19章-OpenMV視覺循跡功能
19.3-openmv發(fā)送五個uchar
openmv 通過串口發(fā)送數(shù)據(jù)格式:幀頭+一個字節(jié) +一個字節(jié)+一個字節(jié)+一個字節(jié)+一個字節(jié)+幀尾。
把上面識別的數(shù)據(jù)發(fā)送出來結(jié)合電腦串口上位機調(diào)試、顯示上位機上
前面我們通過openmv 識別到線的相對位置,那么現(xiàn)在要openmv 把上面的信息發(fā)給STM32,然后STM32接受到信息知道線位置才能更好控制電機運動。
如何完成通信 發(fā)送什么數(shù)據(jù)
如何驗證發(fā)送正確的數(shù)據(jù)了
把openmv 的串口連接串口上位機,通過上位機接收數(shù)據(jù),查看數(shù)據(jù)是否正確。
我們看一下代碼,主要看串口部分
#.....省略部分代碼...
uart = UART(3,115200,bits=8, parity=None, stop=1, timeout_char = 1000)#初始化串口三、波特率115200 TXD:P4PB10 RXD:P5PB11
#.....省略部分代碼...
def send_five_uchar(c1,c2,c3,c4,c5):#功能發(fā)送五個無符號字符(unsigned char)
global uart;
data = ustruct.pack("<BBBBBBBB",#使用了 ustruct.pack() 函數(shù)將這些數(shù)據(jù)打包為二進制格式。使用 "<BBBBBBBB" 作為格式字符串來指定要打包的數(shù)據(jù)的類型和順序:
0xA5,
0xA6,
c1,
c2,
c3,
c4,
c5,
0x5B
)
uart.write(data);#uart.write(data) 將打包好的二進制數(shù)據(jù)幀寫入 UART 發(fā)送緩沖區(qū),從而將數(shù)據(jù)通過串口發(fā)送出去
print(data)#通過 print(data) 打印發(fā)送的數(shù)據(jù)到串行終端,方便調(diào)試和確認(rèn)發(fā)送的內(nèi)容。
#.....省略部分代碼...
send_five_uchar(flag[0],flag[1],flag[2],flag[3],flag[4])#把五個數(shù)據(jù)通過串口發(fā)送出去、發(fā)送五個無符號字符。
整個工程代碼如下
import pyb, sensor, image, math, time
from pyb import UART
import ustruct
from image import SEARCH_EX, SEARCH_DS
import time
import sensor, lcd
#導(dǎo)入需要的庫和模塊
#使用中可能根據(jù)自己情況需要修改的值
#1. GROUND_THRESHOLD 閾值參數(shù) 通過工具->機器視覺->閾值編輯器->幀緩沖區(qū) 調(diào)整出要識別的LAB閾值。
#2.注意是否有下面兩句根據(jù)自己攝像頭調(diào)整
#sensor.set_vflip(True)
#sensor.set_hmirror(True)
#sensor.set_contrast(1)#設(shè)置相機圖像對比度。-3至+3。
#sensor.set_gainceiling(16)#設(shè)置相機圖像增益上限。2, 4, 8, 16, 32, 64, 128。
uart = UART(3,115200,bits=8, parity=None, stop=1, timeout_char = 1000)#初始化串口三、波特率115200 TXD:P4PB10 RXD:P5PB11
roi1 = [( 20, 105, 10, 10),
( 45, 105, 10, 10),
( 75, 105, 10, 10),
( 105, 105, 10, 10),
(130, 105, 10, 10)]#定義一個名為roi1的列表,其中包含了5個元組。每個元組代表了一個矩形感興趣區(qū)域在圖像上的位置和大小。
#具體而言,每個元組包含了4個數(shù)值依次的含義是:ROI左上角點的x坐標(biāo)、ROI左上角點的y坐標(biāo)、ROI的寬度、ROI的高度
led = pyb.LED(1) # led = pyb.LED(1)表示led表示紅燈。各種狀態(tài)如下:Red LED = 1, Green LED = 2, Blue LED = 3, IR LEDs = 4.
led.on() #點亮紅燈 板載紅燈點亮表示程序得到執(zhí)行
sensor.reset()#初始化相機傳感器。
sensor.set_pixformat(sensor.RGB565)#設(shè)置相機模塊的像素模式:sensor.RGB565: 16 bits/像素。
sensor.set_framesize(sensor.QQVGA)#設(shè)置圖像分辨率、如果改變分辨率也要調(diào)整ROI區(qū)域。攝像頭不同、應(yīng)用場景不同可以選擇不同分辨率。這里使用QQVGA可能畫質(zhì)很胡,但是為了兼容不同型號攝像頭我們先使用QQVGA 不影響循跡效果
sensor.skip_frames(time=2000)#跳過指定數(shù)目的幀。在這里,設(shè)置為跳過2000毫秒(即2秒)的幀。這樣可以給傳感器一些時間進行初始化和自適應(yīng)調(diào)整。
sensor.set_auto_whitebal(True)#設(shè)置為自動白平衡模式。這使得攝像頭可以根據(jù)場景中的光照條件自動調(diào)整圖像的白平衡,從而保持圖像色彩更加準(zhǔn)確和自然。
sensor.set_auto_gain(False)#關(guān)閉自動增益模式。通常情況下,開啟自動增益會幫助攝像頭自動調(diào)整亮度,并在低亮度環(huán)境下提高圖像清晰度。通過設(shè)置為False,禁用了這個功能,使用固定增益值。
# 注意是否有下面兩句根據(jù)自己攝像頭調(diào)整
sensor.set_vflip(True) #垂直方向翻轉(zhuǎn) 根據(jù)自己攝像頭和模塊安裝位置調(diào)整 ?。。≈匾煌瑪z像頭是否需要鏡像根據(jù)實際情況定,如果不需要鏡像需要注釋掉
sensor.set_hmirror(True) #水平方向反轉(zhuǎn) 根據(jù)自己攝像頭和模塊安裝位置調(diào)整 !??!重要不同攝像頭是否需要鏡像根據(jù)實際情況定,如果不需要鏡像需要注釋掉
#lcd.init() #初始化lcd屏幕
#最好根據(jù)自己情況設(shè)置一下?。。?
#GROUND_THRESHOLD=(0, 8, -128, 23, -128, 80)#閾值參數(shù),用于在圖像處理中對標(biāo)物體進行顏色識別分割。在OpenMV IDE軟件 工具->機器視覺->閾值編輯器->幀緩沖區(qū) 調(diào)整出要識別的LAB閾值。
GROUND_THRESHOLD=(0, 30, -22, 23, -128, 80)#閾值參數(shù),用于在圖像處理中對標(biāo)物體進行顏色識別分割。在OpenMV IDE軟件 工具->機器視覺->閾值編輯器->幀緩沖區(qū) 調(diào)整出要識別的LAB閾值。
def send_five_uchar(c1,c2,c3,c4,c5):#功能發(fā)送五個無符號字符(unsigned char)
global uart;
data = ustruct.pack("<BBBBBBBB",#使用了 ustruct.pack() 函數(shù)將這些數(shù)據(jù)打包為二進制格式。使用 "<BBBBBBBB" 作為格式字符串來指定要打包的數(shù)據(jù)的類型和順序:
0xA5,
0xA6,
c1,
c2,
c3,
c4,
c5,
0x5B
)
uart.write(data);#uart.write(data) 將打包好的二進制數(shù)據(jù)幀寫入 UART 發(fā)送緩沖區(qū),從而將數(shù)據(jù)通過串口發(fā)送出去
print(data)#通過 print(data) 打印發(fā)送的數(shù)據(jù)到串行終端,方便調(diào)試和確認(rèn)發(fā)送的內(nèi)容。
while(True):
data=0
blob1=None
blob2=None
blob3=None
blob4=None
blob5=None
flag = [0,0,0,0,0]
img = sensor.snapshot().lens_corr(strength = 1.7 , zoom = 1.0)#對獲取到的圖像執(zhí)行鏡頭校正的操作。
blob1 = img.find_blobs([GROUND_THRESHOLD], roi=roi1[0])#在圖像中通過顏色閾值 GROUND_THRESHOLD1 檢測 roi1[0] 區(qū)域內(nèi)的色塊,并將檢測結(jié)果賦值給 blob1。
blob2 = img.find_blobs([GROUND_THRESHOLD], roi=roi1[1])#同理
blob3 = img.find_blobs([GROUND_THRESHOLD], roi=roi1[2])
blob4 = img.find_blobs([GROUND_THRESHOLD], roi=roi1[3])
blob5 = img.find_blobs([GROUND_THRESHOLD], roi=roi1[4])
if blob1:#如果roi1區(qū)域內(nèi)找到閾值色塊 就會賦值flag[0]為1
flag[0] = 1
if blob2:
flag[1] = 1
if blob3:
flag[2] = 1
if blob4:
flag[3] = 1
if blob5:
flag[4] = 1
# print(flag[0],flag[1],flag[2],flag[3],flag[4])#把數(shù)據(jù)打印在串行終端方便調(diào)試
send_five_uchar(flag[0],flag[1],flag[2],flag[3],flag[4])#把五個數(shù)據(jù)通過串口發(fā)送出去、發(fā)送五個無符號字符。
for rec in roi1:#遍歷所有感興趣的區(qū)域roi1 并繪制color=(255,0,0)顏色
img.draw_rectangle(rec, color=(255,0,0))
#lcd.display(img) # Take a picture and display the image.#將圖像顯示在lcd中
openmv在線運行(即板子需要連接openmv IDE 控制運行)
使用openmv連接外部供電時候**一定不能接錯接反電源
通過SSCOM查看發(fā)送的數(shù)據(jù) 是否和攝像頭應(yīng)該識別的狀態(tài)一致
如何脫機運行
然后就可以脫機運行(openmv 板子不連接 openmv IDE 上電自動運行)
- 用USB 把openmv 連接到電腦,點擊連接
- 點擊連接
點擊否保留我們的注釋內(nèi)容
然后我們在openmv 對應(yīng)的U盤就會看到多的main文件,打開可以可以看到是剛剛代碼
現(xiàn)在我們拔掉USB進行如下連接
然后打開串口軟件查看接收到的數(shù)據(jù)。
這里我們openmv發(fā)送了數(shù)據(jù),下面我們使用STM32進行接受
聯(lián)系:Q,1930299709