中文字幕第二一区_久久久久在线视频_精品国产自在现线看久久_亚洲精品一区二区三区电影网

產(chǎn)品分類

當(dāng)前位置: 首頁 > 工業(yè)電氣產(chǎn)品 > 端子與連接器 > 線路板連接器 > FFC連接器

類型分類:
科普知識
數(shù)據(jù)分類:
FFC連接器

機(jī)器視覺運(yùn)動控制一體機(jī)應(yīng)用例程(三) 基于BLOB分析的多圓定位

發(fā)布日期:2022-04-25 點(diǎn)擊率:144

  • 關(guān)鍵詞:正運(yùn)動技術(shù),機(jī)器視覺,運(yùn)動控制一體機(jī)


  • 摘要:我們在《VPLC系列機(jī)器視覺運(yùn)動控制一體機(jī)快速入門(三)》的推文中,講述了基于形狀匹配的視覺定位功能,而BLOB斑點(diǎn)分析也可以實(shí)現(xiàn)定位功能。


image.png


我們在《VPLC系列機(jī)器視覺運(yùn)動控制一體機(jī)快速入門(三)》的推文中,講述了基于形狀匹配的視覺定位功能,而BLOB斑點(diǎn)分析也可以實(shí)現(xiàn)定位功能。


本期課程我們將在BLOB斑點(diǎn)分析定位的基礎(chǔ)上進(jìn)行檢測圓形,輸出圓心的坐標(biāo)數(shù)據(jù)。


一檢測原理


(一)BLOB斑點(diǎn)定位


BLOB斑點(diǎn)分析功能可以輸出BLOB區(qū)域的重心位置XY,BLOB斑點(diǎn)區(qū)域還可以擬合成特定形狀如外接矩形,輸出矩形的角度,從而實(shí)現(xiàn)定位的功能。


(二)BLOB分析的圓形檢測+示意圖


圓形測量器不具有定位功能,因此當(dāng)檢測目標(biāo)在視野的位置是隨機(jī)時,我們需要配合定位功能將測量器跟隨目標(biāo)移動。本節(jié)程序示例將檢測到的BLOB重心XY數(shù)據(jù)作為圓形測量器的中心XY值,即可實(shí)現(xiàn)位置跟隨功能。


image.png


二軟件演示


(一)檢測要求


使用ZDevelop軟件的ZBASIC編程語言編寫程序,用于檢測以下路徑中圖片的圓環(huán)零件的圓心位置XY以及半徑。 


使用到的視覺功能:BLOB斑點(diǎn)分析+檢測圓形+九點(diǎn)標(biāo)定。


image.png


(二)實(shí)例演示


1.打開ZDevelop軟件:新建項(xiàng)目→新建HMI文件→新建main.bas文件,用于編寫界面響應(yīng)函數(shù)→新建global_variable.bas文件用于定義全局變量并開啟HMI自動運(yùn)行任務(wù)→新建detectParam.bas文件,用于初始化測量參數(shù)→新建camera.bas文件用于實(shí)現(xiàn)相機(jī)采集功能→文件添加到項(xiàng)目。


image.png


2.設(shè)計(jì)HMI界面。


image.png


3.在global_variable.bas文件中添加全局變量。


'''''全局變量大部分使用數(shù)組結(jié)構(gòu)'''''

''注:basic編程中很多函數(shù)會以TABLE(系統(tǒng)的數(shù)據(jù)結(jié)構(gòu))做為參數(shù)

''table        說明                 table            說明

''0  '    自動二值化閾值            11~12   鼠標(biāo)操作時獲取的坐標(biāo)

''2       亮區(qū)域的面積            20~24   圖像信息

''4       暗區(qū)域的面積            6       連通區(qū)域的數(shù)量   

''40~42  小圓斑點(diǎn)的面積和位置X,Y數(shù)據(jù)  81~98  標(biāo)定圖像坐標(biāo)xy       

''46~48  小圓圓心X,Y和半徑          131~148  標(biāo)定世界坐標(biāo)xy

''39     提取mark點(diǎn)成功標(biāo)志          56~57  圓點(diǎn)矩陣行列數(shù)

''49~50  圓上的點(diǎn)坐標(biāo)

'主任務(wù)狀態(tài)

'0 - 未初始化

'1 - 停止

'2 - 運(yùn)行中

'3 - 正在停止

GLOBAL DIM main_task_state

main_task_state = 1


'采集開關(guān)

'0 - 停止采集

'1 - 請求采集

GLOBAL DIM grab_switch

grab_switch = 0


'相機(jī)個數(shù)

GLOBAL cam_num

cam_num = 0


'相機(jī)種類,"zmotion;mvision;basler;mindvision;huaray"

GLOBAL DIM CAMERA_TYPE(16)

CAMERA_TYPE = "mvision"


' 定義主任務(wù)id - 10

GLOBAL DIM main_task_id

main_task_id = 10


'定義連續(xù)采集任務(wù)id - 9

GLOBAL DIM grab_task_id

grab_task_id = 9


'定義全局圖像變量

GLOBAL ZVOBJECT grabImg '采集圖像

GLOBAL ZVOBJECT binImg '二值化圖像

GLOBAL ZVOBJECT disImg '顯示圖像


'定義常用顏色變量

GLOBAL C_RED, C_GREEN, C_BLUE, C_YELLOW

C_RED   = RGB(255,  0,  0)

C_GREEN = RGB(  0,255,  0)

C_BLUE  = RGB(  0,  0,255)

C_YELLOW= RGB(255,255,  0)


'檢測參數(shù):閾值模式(自動閾值或手動閾值)、低閾值、高閾值、最小面積、最大面積

GLOBAL DIM d_detect_param(5) 'd開頭表示數(shù)據(jù)結(jié)構(gòu)


'開/閉運(yùn)算參數(shù)

GLOBal DIM d_deal_value(2)


'檢測消耗時間

GLOBal DIM d_detect_time


'小圓的位置x/y結(jié)果

GLOBal DIM d_circle_rst(18)


'顯示打印的字符

GLOBAL ShowString(64)


'***********定義坐標(biāo)標(biāo)定相關(guān)變量*********************

'是否標(biāo)定

GLOBAL DIM is_ca_success


'定義標(biāo)定成功標(biāo)志,0-標(biāo)定未成功,1-標(biāo)定成功

GLOBAL DIM d_calib_success

d_calib_success = 0


'定義標(biāo)定系數(shù)即矩陣轉(zhuǎn)換系數(shù)

GLOBAL ZVOBJECT ca_param


'定義標(biāo)定參數(shù)數(shù)組,依次為:標(biāo)定類型、對比度、極性、最小面積、最大面積、世界坐標(biāo)點(diǎn)間距

GLOBAL DIM d_ca_param(6) 'd開頭表示數(shù)據(jù)結(jié)構(gòu)


'定義是否使用標(biāo)定功能

GLOBAL DIM d_use_calib

d_use_calib=0


'定義標(biāo)定誤差,依次為最小誤差、最大誤差、平均誤差

GLOBAL DIM ca_min_err,ca_max_err,ca_avg_err

ca_min_err = 0

ca_max_err = 0

ca_avg_err = 0


'***********定義讀取本地文件功能相關(guān)變量**************

''注意,該功能只在使用仿真器時有效

'定義是否使用本地圖片標(biāo)志

GLOBAL DIM d_use_imgfile


'定義本地圖片索引

GLOBAL DIM d_index


'定義讀取圖片的路徑

GLOBAL DIM File_Name(100)   


'***********結(jié)束定義讀取本地文件功能相關(guān)變量**********


'運(yùn)行HMI文件

RUN "Hmi.hmi",1

4.關(guān)聯(lián)HMI界面控件變量。


image.png


5.在detectParam.bas文件中初始化測量參數(shù)。


end


GLOBAL SUB init_detect_param()    '初始化測量參數(shù)

  

    d_deal_value(0)=1          '初始化開/閉運(yùn)算參數(shù)

    d_deal_value(1)=1

    

    '初始化檢測參數(shù):閾值模式(自動閾值 = 1 或 手動閾值 = 0)、低閾值、高閾值、極性(黑或白)、最大、最小、反向(即結(jié)果取反,成功變成失敗、失敗變成成功)

    d_detect_param(0) = 0      '手動閾值

    d_detect_param(1) = 140    '低閾值

    d_detect_param(2) = 255     '高閾值

    d_detect_param(3) = 11000    '最小面積即像素個數(shù)

    d_detect_param(4) = 12000    '最大面積

  

    d_use_imgfile = 1           '默認(rèn)使用本地圖片

    d_index      = 0

    

    TABLE(6)=0   '將小圓數(shù)量初始化為0

    for i=0 to 17

        d_circle_rst(i)=0

    next

    '初始化坐標(biāo)標(biāo)定相關(guān)的變量

    d_ca_param(0) = 0    '標(biāo)定類型

    d_ca_param(1) = 120    '對比度

    d_ca_param(2) = 0    '極性

    d_ca_param(3) = 80    '最小面積

    d_ca_param(4) = 20000  '最大面積

    d_ca_param(5) = 9       '世界坐標(biāo)點(diǎn)間距

    ca_min_err = 0      '最小誤差

    ca_max_err = 0      '最大誤差

    ca_avg_err = 0      '平均誤差

    

    for i=0 to 17           '初始化圓點(diǎn)矩陣像素坐標(biāo)    

        TABLE(81+i)=0

    next

    

    for i=0 to 17           '初始化圓點(diǎn)矩陣世界坐標(biāo)    

        TABLE(131+i)=0

    next

    TABLE(39)=0             '提取mark點(diǎn)狀態(tài)默認(rèn)為失敗 

    

END SUB

6.在main.bas文件中添加界面初始化函數(shù),并在hmi系統(tǒng)設(shè)置中關(guān)聯(lián)初始化函數(shù)名。


end


'注:

'凡是要使用Region有關(guān)的算子在系統(tǒng)初始化時都要調(diào)用ZV_RESETCLIPSIZE(width, height)這個算子設(shè)置下圖像尺寸,以滿足相機(jī)分辨率,因?yàn)槟J(rèn)的是640*480尺寸


'HMI界面初始化函數(shù)

GLOBAL SUB hmi_init()

    grab_switch = 0              '停止采集

    main_task_state = 1          '主任務(wù)停止運(yùn)行

    ZV_RESETCLIPSIZE(1280, 960) '依據(jù)圖像分辨率設(shè)置區(qū)域的裁剪尺寸,此處圖像分辨率為1280x960

    ZV_LATCHSETSIZE(0, HMI_ConTROLSIZEX(10, 7), HMI_ConTROLSIZEY(10, 7)) '設(shè)置鎖存的大小

    init_detect_param()        '初始化測量參數(shù)

    ZV_SETSYSDBL("CamGetTimeout", 1000) '設(shè)置采集超時

    ZV_SETSYSINT("LineWidth",6)

    ZV_LATCHCLEAR(0)           '清空鎖存通道0

    

END SUB

image.png


7.在camera.bas文件中添加HMI運(yùn)行界面中采集相關(guān)按鈕響應(yīng)的函數(shù)并關(guān)聯(lián)動作函數(shù)。


圖片


相機(jī)操作相關(guān)按鈕


end


'主界面按下掃描相機(jī)按鈕時響應(yīng)的函數(shù)

GLOBAL SUB cam_scan_all()


    if(d_use_imgfile=1)then 

        ?"請先按下使用本地圖片按鈕關(guān)閉該功能"

    return 

    endif 

  

    ZV_SETSYSINT("LogLevel", 7)     '設(shè)置控制器信息

    ZV_SETSYSSTR("DataDir","")

      

    CAM_SCAN(CAMERA_TYPE)           '掃描相機(jī),CAMERA_TYPE="mvision"

    cam_num = CAM_COUNT()           '獲取掃描到的相機(jī)數(shù)量

    if (0 = cam_num) then           '如果相機(jī)數(shù)量=0,打印提示信息

         ? "未找到相機(jī)" 

        

    return                       '退出子函數(shù),不往下執(zhí)行

    endif

    ?"cam_num = " cam_num            '如果掃描到相機(jī),打印相機(jī)數(shù)量

  

    CAM_SEL(0)                       '選擇掃描到的第一個相機(jī)進(jìn)行操作

    CAM_SETEXPOSURE(5000)           '設(shè)置相機(jī)曝光時間為5000us      

    CAM_SETMODE(0)                   '設(shè)置軟件觸發(fā)模式

    CAM_START(0)                     '開啟相機(jī)  

  

END SUB


'主界面按下單次采集按鈕執(zhí)行的函數(shù)

GLOBAL SUB btn_grab()


    ''如果d_use_imgfile=1時使用讀取本地圖片功能,該功能只在使用仿真器時有效,使用控制器時請將此部分代碼注釋掉

    if (d_use_imgfile=1) then 

        if(d_index=3) then 

             d_index=0

        endif

        File_Name="圓定位"+TOSTR(d_index,1,0)+".bmp"   '.../flash/圓定位/目錄下的圖片所在的路徑名稱

        ZV_IMGREAD(grabImg,File_Name,0)

        ZV_LATCH(grabImg, 0) 

        d_index=d_index+1

    return   

    endif

    ''讀取本地圖片功能結(jié)束

  

    if cam_num = 0   then 

        ?"請先掃描相機(jī)!"

    return 

    endif

  

    CAM_SETPARAM("TriggerSoftware", 0)  '發(fā)送觸發(fā)指令

    CAM_GET(grabImg, 0)                 '獲取一幀圖像存放到grabImg變量中

    ZV_LATCH(grabImg, 0)                '將圖像顯示到鎖存通道0中

    

END SUB


'主界面按下連續(xù)采集按鈕響應(yīng)的函數(shù)

GLOBAL SUB btn_cgrab()

    if grab_switch =1 then                 '如果已經(jīng)處于連續(xù)執(zhí)行狀態(tài),打印提示信息并退出函數(shù)

       ?"正在連續(xù)運(yùn)行中,請勿重復(fù)操作!"

     return 

    endif

  

    if( d_use_imgfile =0) then 

        if cam_num = 0   then                  '如果相機(jī)數(shù)量=0,打印提示信息并退出函數(shù)        

             ?"請先掃描相機(jī)!"

        return 

        endif

    endif

  

    grab_switch = 1                         '采集任務(wù)開關(guān)置1

       if (1 = grab_switch) then

            if (0 = PROC_STATUS(grab_task_id)) then

                 RUNTASK  grab_task_id, grab_task    '開啟連續(xù)采集任務(wù)

            endif

       endif

  

END SUB


'采集任務(wù)實(shí)現(xiàn)函數(shù)

grab_task:

    while(1)

        if (0 = grab_switch) then        '如果采集任務(wù)開關(guān)=0即停止采集按鈕按下時

            exit while                   '退出循環(huán)

        endif

          

        '重復(fù)執(zhí)行以下操作

        btn_grab()

    wend

END


'主界面按下停止采集按鈕響應(yīng)的函數(shù)

GLOBAL SUB btn_stopCgrab()

    if grab_switch =0 then               '如果已經(jīng)處于停止采集狀態(tài),打印提示信息并退出函數(shù)

       ?"未開啟連續(xù)采集!"

    return 

    endif

  

    grab_switch = 0                       '將采集任務(wù)開關(guān)置0

    

END SUB

8.點(diǎn)擊“元件”→“新建窗口”,新建標(biāo)定界面窗口,并將《VPLC系列機(jī)器視覺運(yùn)動控制一體機(jī)快速入門(六)》中的標(biāo)定程序的界面拷貝到新建的窗口界面。


image.png


9.在main.bas文件中添加運(yùn)行界面按下【標(biāo)定】按鈕時的響應(yīng)函數(shù),以及標(biāo)定窗口界面按下【提取mark點(diǎn)】按鈕、【標(biāo)定】按鈕以及【返回】按鈕時響應(yīng)的函數(shù),可參考《VPLC系列機(jī)器視覺運(yùn)動控制一體機(jī)快速入門(六)》中的標(biāo)定程序。


'點(diǎn)擊運(yùn)行界面按下標(biāo)定按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_calib()

    '設(shè)置坐標(biāo)標(biāo)定窗口鎖存通道0的鎖存大小

    ZV_LATCHSETSIZE(0, HMI_ConTROLSIZEX(11, 91), HMI_ConTROLSIZEY(11, 91)) 

    if (d_use_imgfile=1) then   '如果使用本地圖片功能

    ZV_IMGREAD(grabImg,"圓定位calib.bmp",0)  '加載標(biāo)定圖片

    endif

    ZV_LATCHCLEAR(0)           '將鎖存通道0清空

    ZV_LATCH(grabImg, 0)       '顯示采集圖像顯示到鎖存通道0中

    HMI_SHOWWINDOW(11)         '彈出窗口號為11的坐標(biāo)標(biāo)定窗口界面

   

END SUB


'坐標(biāo)標(biāo)定界面按下提取mark點(diǎn)按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_ca_extract()

    for i=0 to 17           '初始化圓點(diǎn)矩陣像素坐標(biāo)    

       TABLE(81+i)=0

    next

  

    for i=0 to 17           '初始化圓點(diǎn)矩陣世界坐標(biāo)    

       TABLE(131+i)=0

    next

    TABLE(39)=0             '提取mark點(diǎn)狀態(tài)默認(rèn)為失敗

    ZVOBJECT inppts, ppts, wpts

    

    '根據(jù)提取像素參數(shù)提取像素坐標(biāo),存放到inppts矩陣中

    ZV_CALGETSCAPTS(grabImg, inppts, d_ca_param(1), d_ca_param(2), d_ca_param(3), d_ca_param(4))

    '獲取矩陣inppts中的數(shù)據(jù)信息,存放到table(56)中

    ZV_MATINFO (inppts, 56)

    

    DIM row,col

    row = TABLE(56)   '矩陣行數(shù)賦值給row變量

    col = TABLE(57)   '矩陣列數(shù)賦值給col變量

    if(row * col = 18) then '如果獲取到9個圓點(diǎn)的圓心位置坐標(biāo)x,y   

        TABLE(39) = 1 '窗口界面提示提取mark點(diǎn)成功

    else

        TABLE(39) = 0 '窗口界面提示提取mark點(diǎn)失敗

    return         '返回子函數(shù),不往下執(zhí)行

    endif

    

    '根據(jù)mrak點(diǎn)間距和像素坐標(biāo)計(jì)算世界坐標(biāo),存放到wpts矩陣

    ZV_CALGETPTSMAP(inppts,ppts,wpts,d_ca_param(5))

    '獲取矩陣ppts中的數(shù)據(jù)信息,存放到table(56)中

    ZV_MATINFO (ppts, 56)

    

    row = TABLE(56)  '矩陣行數(shù)賦值給row變量

    col = TABLE(57)  '矩陣列數(shù)賦值給col變量

    if(row * col = 18) then'如果獲取到9個圓點(diǎn)的圓心位置坐標(biāo)x,y 

        TABLE(39) = 1 '窗口界面提示提取mark點(diǎn)成功

    else

      TABLE(39) = 0 '窗口界面提示提取mark點(diǎn)失敗

    return         '返回子函數(shù),不往下執(zhí)行

    endif

     

    '像素坐標(biāo)和世界坐標(biāo)放入table中

    DIM i

    FOR i=0 TO row-1

        ZV_MATGETROW (ppts, i, col, 81 + i*col)'將像素坐標(biāo)存放到table81~table98中

        ZV_MATGETROW (wpts, i, col, 131 + i*col)'將世界坐標(biāo)存放到table131~table148中

    NEXT

    

    '將灰度圖轉(zhuǎn)成RGB圖像,作為結(jié)果圖像

    ZVOBJECT color

    ZV_GRAYTORGB(grabImg, color)

    

    '繪制mark點(diǎn)的十字架

    DIM j, pixNum 

    pixNum = 0

    FOR i=0 TO 2

        FOR j=0 TO 2

            '繪制mark標(biāo)記點(diǎn)

          ZV_MARKER(color, TABLE(81 + 2 * pixNum), TABLE(81 + 2 * pixNum + 1), 0, 40, C_GREEN)

          pixNum = pixNum + 1

        NEXT

    NEXT

    

    '用文本繪制mark點(diǎn)的序號,顯示在圖像界面中

    FOR i=0 TO 8

        ZV_TEXT (color, TOSTR(i,1,0), TABLE(81+2*i)-20, TABLE(81+2*i +1)-40, 80, C_RED)

    NEXT

  

    ZV_LATCH(color, 0)'顯示結(jié)果圖像

  

END SUB


'坐標(biāo)標(biāo)定界面按下標(biāo)定按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_ca_calib()

    ZV_IMGINFO(grabImg,0)  '獲取采集圖像信息

    '根據(jù)像素坐標(biāo)數(shù)據(jù)組和世界坐標(biāo)數(shù)據(jù)組執(zhí)行標(biāo)定,獲得標(biāo)定系數(shù)ca_param

    ZV_CALCAM(ppts,wpts,ca_param,TABLE(0),TABLE(1),d_ca_param(0))

    is_ca_success=1 '標(biāo)定成功標(biāo)志置1

    

    ZV_CALERROR(ca_param, ppts, wpts, 0)'計(jì)算標(biāo)定誤差,并將結(jié)果存放在起始地址為0的數(shù)組中

    ca_min_err = TABLE(1) '將誤差結(jié)果賦值給變量,用于在界面中實(shí)時顯示誤差結(jié)果

    ca_max_err = TABLE(2)

    ca_avg_err = TABLE(0)

  

END SUB


'坐標(biāo)標(biāo)定界面按下返回按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_ca_param_rtn()

    ZV_LATCHCLEAR(0)           '將鎖存通道0清空

    ZV_LATCHSETSIZE(0, HMI_ConTROLSIZEX(10, 7), HMI_ConTROLSIZEY(10, 7)) '設(shè)置鎖存的大小

    btn_grab()

    HMI_CLOSEWINDOW(11)   '關(guān)閉窗口號為13的坐標(biāo)標(biāo)定窗口界面

  

END SUB

10.在main.bas文件中添加HMI運(yùn)行界面按下測試按鈕響應(yīng)的函數(shù),并關(guān)聯(lián)動作函數(shù)名。


'HMI界面按下測試按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_test()

    TABLE(6)=0   '檢測前先將結(jié)果數(shù)據(jù)清0

    d_detect_time=0

    for i=0 to 17

        d_circle_rst(i)=0

    next

  

    TICKS=0

    '定義變量,依次為白色像素連通區(qū)域,掩模區(qū)域,黑色像素連通區(qū)域,連通區(qū)域結(jié)果列表,小圓斑點(diǎn)區(qū)域,圓測量器,中間結(jié)果變量

    ZVOBJECT regionWhite, regionMask, regionBlack,re_connecte,circle_connect,mr,tmp

    

     '生成全圖像區(qū)域

    ZV_REGENFULLIMG(grabImg,regionMask)

  

    '二值化處理

    if d_detect_param(0) = 0 then    '如果選擇手動閾值模式

          '根據(jù)低閾值和高閾值參數(shù)生成白色像素圖像regionWhite

        ZV_RETHRESH(grabImg, regionMask, regionWhite, d_detect_param(1), d_detect_param(2))

        '對白色像素區(qū)域進(jìn)行一次1*1的開運(yùn)算

        ZV_REOPENING(regionWhite,regionWhite,d_deal_value(0),d_deal_value(0))

        '對白色像素區(qū)域進(jìn)行一次1*1的閉運(yùn)算

        ZV_RECLOSING(regionWhite,regionWhite,d_deal_value(1),d_deal_value(1))

    

    else                             '如果選擇自動閾值模式

    

        Dim autoThresh               '定義自動閾值模式下的二值化閾值

        '在grabImg圖像中的指定區(qū)域內(nèi)對圖像進(jìn)行自動二值化處理,輸出二值化區(qū)域regionWhite 

        ZV_REAUTOTHRESH(grabImg, regionMask, regionWhite, 0)

        '對白色像素區(qū)域進(jìn)行一次1*1的開運(yùn)算

        ZV_REOPENING(regionWhite,regionWhite,d_deal_value(0),d_deal_value(0))

        '對白色像素區(qū)域進(jìn)行一次1*1的閉運(yùn)算

        ZV_RECLOSING(regionWhite,regionWhite,d_deal_value(1),d_deal_value(1))

        autoThresh = TABLE(0)

        ? "autoThresh = " autoThresh  '打印提示信息,當(dāng)前二值化閾值

      

    endif

    

    '計(jì)算BLOB面積

    

    ZV_REAREA(regionWhite, 2)              '計(jì)算regionWhite亮區(qū)域的面積,存放到table(2)中

      

    if(TABLE(2)>0) then '如果獲取到的白色像素?cái)?shù)量大于0                 

         ZV_REConNECT(regionWhite,re_connecte)     '計(jì)算區(qū)域的連通區(qū)域,存放到re_connecte列表中

         zv_refilter(re_connecte,0,d_detect_param(3),d_detect_param(4),0)'對區(qū)域列表中的區(qū)域進(jìn)行過濾,保留面積在 d_detect_param(3) 到 d_detect_param(4) 的區(qū)域,面積不在此范圍的區(qū)域?qū)⒈贿^濾掉

         zv_refilter(re_connecte,20,0.8,1.3,0)'對區(qū)域列表中的區(qū)域進(jìn)行過濾,保留最小外接矩形高寬比在0.9 到 1.1 的區(qū)域,面積不在此范圍的區(qū)域?qū)⒈贿^濾掉

         ZV_RESORT(re_connecte,1,1)          '對區(qū)域列表中的區(qū)域按照重心X的數(shù)據(jù)進(jìn)行升序排序

         ZV_LISTCOUNT(re_connecte,6)     '獲取列表中的連通區(qū)域的數(shù)量,存放到table(6)中 

    endif  

    

    '繪制效果圖

    Dim width, height

    ZV_IMGINFO (grabImg, 20)'獲取grabImg的圖像信息

    width = TABLE(20)

    height = TABLE(21)

    

    ZV_GRAYTORGB(grabImg,disImg)'將灰度圖轉(zhuǎn)換到RGB圖像,用于繪制檢測結(jié)果圖像

    

    ZV_REGION(disImg, regionMask, 0, ZV_COLOR(0,0,0))      '在disImg中繪制黑色的regionMask區(qū)域

    ZV_REGION(disImg, regionWhite, 0, ZV_COLOR(255,255,255))'在disImg中繪制白色的regionWhite區(qū)域

    

    for i=0 to TABLE(6)-1     '循環(huán)獲取小圓斑點(diǎn)的位置XY信息生成圓測量器,檢測圓心位置

          ZV_LISTGET(re_connecte,circle_connect,i)   '獲取列表中序號為i的元素,即依次獲取列表中小圓斑點(diǎn)的連通區(qū)域

          ZV_REAREACENTER(circle_connect,40)  '計(jì)算斑點(diǎn)區(qū)域的面積與中心位置,將位置放入TABLE(40)中

            ZV_MRGENCIRCLE(mr,TABLE(41),TABLE(42),70,50,0,360,1,10,8) '生成圓測量區(qū)域

            '設(shè)置測量參數(shù),包括濾波尺寸、邊緣閾值、邊緣極性和邊緣位置

          ZV_MRSETADV(mr,5, 50, 1,0)

          

          TABLE( 46, 0, 0, 0)'初始化結(jié)果數(shù)組

          '測量圓,并將結(jié)果賦值給起始地址為46的數(shù)組

          ZV_MRCIRCLE(mr, grabImg, tmp, 46)

           

          ZV_CIRCLE(disImg,TABLE(46),TABLE(47),TABLE(48),zv_color(0,255,0))'繪制小圓結(jié)果

          ShowString=TOSTR(i,1,0)   '將BLOB的數(shù)量轉(zhuǎn)換成字符串變量

          ZV_TEXT(disImg,ShowString,TABLE(46),TABLE(47),55,ZV_COLOR(0,0,255)) '顯示結(jié)果文本  

          ZV_MARKER(disImg,TABLE(46),TABLE(47),0,50,zv_color(0,255,0))   '在圖像img中繪制十字

          

          if is_ca_success=1 AND d_use_calib=1 then 

              ZV_CALTRANSW(ca_param, TABLE(46)+TABLE(48),TABLE(47),49) '圓心加半徑的坐標(biāo)

              ZV_CALTRANSW(ca_param, TABLE(46),TABLE(47),46) '使用標(biāo)定系數(shù)將圖像坐標(biāo)轉(zhuǎn)換成世界坐標(biāo)

              d_circle_rst(i*3+0)=TABLE(46)'將測量圓的結(jié)果賦值給圓心變量,顯示到界面中

              d_circle_rst(i*3+1)=TABLE(47)

              d_circle_rst(i*3+2)=ZV_DISTPP(TABLE(46),TABLE(47),TABLE(49),TABLE(50))

          else 

              d_circle_rst(i*3+0)=TABLE(46)'將測量圓的結(jié)果賦值給圓心變量,顯示到界面中

              d_circle_rst(i*3+1)=TABLE(47)

              d_circle_rst(i*3+2)=TABLE(48)

     endif      

     next

     ZV_LATCH(disImg, 0)     '在鎖存通道0中顯示結(jié)果圖像

     d_detect_time=ABS(TICKS)'計(jì)算檢測消耗時間

    

END SUB

image.png


11.在main.bas文件中添加HMI運(yùn)行界面按下運(yùn)行按鈕響應(yīng)的函數(shù),并關(guān)聯(lián)動作函數(shù)名。


'HMI界面按下運(yùn)行按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_run()

    if(2 = main_task_state) then           '如果主任務(wù)處于運(yùn)行狀態(tài),打印提示信息并退出函數(shù)

     ?"已經(jīng)開啟連續(xù)運(yùn)行任務(wù),請勿重復(fù)操作!"

    return 

    endif

   

    if (1 = main_task_state) then          '如果主任務(wù)處于停止?fàn)顟B(tài)

        if (0 = PROC_STATUS(main_task_id)) then '如果任務(wù)未開啟

            main_task_state = 2            '主任務(wù)狀態(tài)設(shè)置為2,表示正在執(zhí)行連續(xù)任務(wù)

            RUNTASK  main_task_id, main_task  '開啟主任務(wù)

        endif

    endif


END SUB


'主任務(wù)實(shí)現(xiàn)函數(shù)

main_task:

    while(1)

        if (3 = main_task_state) then      '如果主任務(wù)狀態(tài)處于3即按下停止按鈕時

            main_task_state = 1             '將主任務(wù)狀態(tài)置為1

            exit while                     '退出循環(huán)

        endif

        

        '重復(fù)執(zhí)行采集和檢測函數(shù)

        btn_grab()

        btn_test()     

    wend

END

image.png


12.在main.bas文件中添加HMI運(yùn)行界面按下停止按鈕響應(yīng)的函數(shù),并關(guān)聯(lián)動作函數(shù)名。


'HMI界面按下停止按鈕時響應(yīng)的函數(shù)

GLOBAL SUB btn_stop()

    if (2 = main_task_state) then   '如果主任務(wù)狀態(tài)處于3即正在連續(xù)執(zhí)行任務(wù)時

        main_task_state = 3           '將主任務(wù)狀態(tài)置為3,退出循環(huán)

    endif  

END SUB

image.png


image.png


image.png


image.png


仿真演示效果4


本次,正運(yùn)動技術(shù)機(jī)器視覺運(yùn)動控制一體機(jī)應(yīng)用例程(三) BLOB分析的多圓定位,就分享到這里。


更多精彩內(nèi)容請關(guān)注“正運(yùn)動小助手”公眾號,需要相關(guān)開發(fā)環(huán)境與例程代碼,請咨詢正運(yùn)動技術(shù)銷售工程師:400-089-8936。


本文由正運(yùn)動技術(shù)原創(chuàng),歡迎大家轉(zhuǎn)載,共同學(xué)習(xí),一起提高中國智能制造水平。文章版權(quán)歸正運(yùn)動技術(shù)所有,如有轉(zhuǎn)載請注明文章來源。


下一篇: PLC、DCS、FCS三大控

上一篇: 機(jī)器視覺運(yùn)動控制一體

推薦產(chǎn)品

更多
中文字幕第二一区_久久久久在线视频_精品国产自在现线看久久_亚洲精品一区二区三区电影网

      9000px;">

          欧美高清激情brazzers| 日韩一区二区三区免费观看| 亚洲国产精品一区二区尤物区| 久久久精品黄色| 一二三四社区欧美黄| 国产精品香蕉一区二区三区| 91久久人澡人人添人人爽欧美| 欧美日韩精品免费| 亚洲视频在线一区观看| 日韩欧美国产高清| 亚洲一区二区三区四区五区黄| 蜜臀久久99精品久久久久久9 | 亚洲电影在线免费观看| 日日夜夜免费精品视频| 国产精品中文字幕日韩精品| 欧美图片一区二区三区| 久久精品一区二区三区不卡| 亚洲sss视频在线视频| 99国产精品久久久久| 国产欧美一区二区在线| 捆绑紧缚一区二区三区视频| 色综合久久综合| 国产亚洲精品福利| 99久久精品国产一区二区三区| 中文字幕欧美日韩一区| 9i看片成人免费高清| 一区二区三区美女视频| 欧美日韩久久久一区| 秋霞影院一区二区| 精品捆绑美女sm三区| 成人黄色综合网站| 久久成人免费日本黄色| 日韩伦理av电影| 93久久精品日日躁夜夜躁欧美| 久久日一线二线三线suv| 国产一区二区三区免费播放| 国产农村妇女毛片精品久久麻豆 | 欧美日本一区二区三区四区| 久久毛片高清国产| 六月丁香婷婷久久| 欧美一级一区二区| 国产一区二区福利| 亚洲欧洲日韩在线| 日韩亚洲国产中文字幕欧美| 国产成人精品网址| 一个色妞综合视频在线观看| 日韩一区二区三区电影在线观看| 日产国产高清一区二区三区| 日韩欧美一区二区不卡| 欧美精品一区二区三区高清aⅴ| 国产精品久久久久久户外露出| 亚洲色欲色欲www| 欧美天天综合网| 精品一区二区三区影院在线午夜| 国产欧美1区2区3区| 日韩欧美久久久| 欧美三级在线看| 欧美主播一区二区三区美女| 免费成人结看片| 蜜桃视频在线观看一区| 首页国产欧美久久| 亚洲国产视频a| 亚洲综合成人在线| 亚洲综合激情小说| 国产精品欧美久久久久无广告| 欧美tk—视频vk| 精品国内二区三区| 色综合久久久久综合体桃花网| 日韩精品久久理论片| 亚洲bt欧美bt精品777| 亚洲欧洲日韩av| 亚洲精品乱码久久久久久| 亚洲一区二区欧美日韩| 综合自拍亚洲综合图不卡区| 亚洲激情成人在线| 久久综合五月天婷婷伊人| 亚洲成人激情综合网| 五月婷婷激情综合| 美女在线一区二区| 成人av网址在线| 色视频成人在线观看免| 91久久精品日日躁夜夜躁欧美| 成人精品国产福利| 51久久夜色精品国产麻豆| 久久久久久免费毛片精品| 国产精品成人免费| 日本欧美肥老太交大片| 国产精品一品二品| 欧美精品三级日韩久久| 久久久久久99久久久精品网站| 亚洲老司机在线| 国产一区二区精品久久99| 色婷婷综合在线| 欧美日韩的一区二区| 国产精品看片你懂得| 久久精品国产久精国产| 日本道在线观看一区二区| 精品国产伦理网| 粉嫩一区二区三区性色av| 日韩欧美国产麻豆| 日本伊人精品一区二区三区观看方式| 久久99久国产精品黄毛片色诱| 色噜噜夜夜夜综合网| 国产精品久久久久久久久图文区 | 国产精品丝袜在线| 中文字幕在线不卡国产视频| 久久久久久久久久久久久女国产乱 | 日韩电影在线观看电影| 国产一区二区剧情av在线| 538在线一区二区精品国产| 亚洲综合成人在线| 在线观看国产91| 美脚の诱脚舐め脚责91| av在线不卡免费看| 久久综合色之久久综合| 91在线你懂得| 喷水一区二区三区| 中文字幕中文在线不卡住| 一本色道a无线码一区v| 欧美色偷偷大香| 国产高清视频一区| 有码一区二区三区| 欧美一三区三区四区免费在线看| 国产一区二区精品在线观看| 亚洲动漫第一页| 亚洲精品一区二区三区精华液 | 人人精品人人爱| 中文字幕在线观看不卡| 欧美天堂一区二区三区| 午夜视频一区二区| 欧美一区二区网站| 91精品国产美女浴室洗澡无遮挡| jizzjizzjizz欧美| 国产1区2区3区精品美女| 日本亚洲视频在线| 麻豆精品精品国产自在97香蕉| 欧美激情综合在线| 久久久av毛片精品| 国产欧美精品一区二区三区四区| 欧美一区二视频| 欧美人与性动xxxx| 日韩欧美你懂的| 日韩一区二区三区三四区视频在线观看| 久久99精品久久久久久| 亚洲欧美日韩一区| 一区二区视频免费在线观看| 亚洲精品videosex极品| 亚洲综合在线视频| 午夜精品aaa| 美女任你摸久久 | 色哟哟一区二区| 欧美一卡二卡三卡四卡| 国产精品无码永久免费888| 午夜av一区二区三区| 国产成人免费高清| 日韩欧美黄色影院| 免费人成在线不卡| 欧美日韩极品在线观看一区| 久久久久久99久久久精品网站| 亚洲一区二区三区四区在线免费观看| 国产乱码精品一区二区三区av| va亚洲va日韩不卡在线观看| 色丁香久综合在线久综合在线观看| 欧美电影免费观看高清完整版在线| 欧美美女黄视频| 日本午夜一区二区| 国产午夜亚洲精品不卡| 日本成人在线电影网| 91精品欧美久久久久久动漫| 一区二区久久久久久| 欧美tickling挠脚心丨vk| 亚洲va韩国va欧美va| 久久久久免费观看| 欧美唯美清纯偷拍| 麻豆国产精品视频| 日韩欧美一区中文| 国产成人精品亚洲777人妖| 国产精品国产三级国产有无不卡| 成人一道本在线| 2023国产一二三区日本精品2022| 国产最新精品精品你懂的| 国产清纯美女被跳蛋高潮一区二区久久w| 国模无码大尺度一区二区三区| 国产精品免费人成网站| 91精品综合久久久久久| 91在线porny国产在线看| 国内不卡的二区三区中文字幕 | 国产成人精品综合在线观看| 亚洲人成小说网站色在线| 精品第一国产综合精品aⅴ| 色综合久久综合中文综合网| 国产精品一区二区三区网站| 亚洲精品成人悠悠色影视| 国产日韩欧美麻豆| 精品电影一区二区| 国产精品久久久久7777按摩 | 国产伦精一区二区三区| 免费成人美女在线观看| 黑人精品欧美一区二区蜜桃| 国产精品系列在线播放|