*關(guān)閉當(dāng)前顯示窗口,清空屏幕
dev_close_window ()
*讀取測(cè)試圖像
read_image (Image_display, 'data/display.jpg')
*將圖像轉(zhuǎn)化為灰度圖像
rgb1_to_gray (Image_display, GrayImage)
*獲取圖像的尺寸
get_image_size(Image_display,imageWidth, imageHeight)
*新建顯示窗口,適應(yīng)圖像尺寸
dev_open_window (0, 0, imageWidth, imageHeight, 'black', WindowHandle1)
dev_display (GrayImage)
*初始化角點(diǎn)坐標(biāo)
YCoordCorners := []
*閾值處理,提取較暗的區(qū)域
threshold(GrayImage,DarkRegion,0, 80)
*分離不相連的區(qū)域
connection (DarkRegion, ConnectedRegions)
*選擇面積最大的暗色區(qū)域,即屏幕區(qū)域
select_shape_std (ConnectedRegions, displayRegion, 'max_area', 70)
*裁剪屏幕區(qū)域
reduce_domain (GrayImage, displayRegion, displayImage)
*創(chuàng)建邊緣輪廓
gen_contour_region_xld (displayRegion, Contours, 'border')
*將輪廓分割為邊
segment_contours_xld (Contours, ContoursSplit, 'lines', 5, 4, 2)
*獲取邊的數(shù)量
count_obj (ContoursSplit, Number)
*存儲(chǔ)每條邊的起點(diǎn)位置
for index:=1 to Number by 1
select_obj(ContoursSplit, ObjectCurrent, index)
*擬合每條邊
fit_line_contour_xld (ObjectCurrent, 'tukey', -1, 0, 5, 2, RowBegin, ColBegin, RowEnd, ColEnd, Nr, Nc, Dist)
*存儲(chǔ)每條邊的頂點(diǎn)x坐標(biāo)
tuple_concat (XCoordCorners, RowBegin, XCoordCorners)
*存儲(chǔ)每條邊的頂點(diǎn)y坐標(biāo)
tuple_concat (YCoordCorners, ColBegin, YCoordCorners)
endfor
* 投影變換給四個(gè)特征點(diǎn)與校正后的坐標(biāo)建立關(guān)聯(lián)
XOff:= 100
YOff:= 100*imageHeight/imageWidth
hom_vector_to_proj_hom_mat2d (XCoordCorners, YCoordCorners, [1,1,1,1], [YOff,YOff,imageHeight-YOff,imageHeight-YOff], [XOff,imageWidth-XOff,imageWidth-XOff,XOff], [1,1,1,1], 'normalized_dlt', HomMat2D)
*投影變換
projective_trans_image (Image_display, Image_rectified, HomMat2D, 'bilinear', 'false', 'false')
* 顯示校正結(jié)果
dev_display (Image_rectified)
審核編輯:劉清
-
存儲(chǔ)器
+關(guān)注
關(guān)注
38文章
7531瀏覽量
164426 -
RGB
+關(guān)注
關(guān)注
4文章
801瀏覽量
58745 -
dev
+關(guān)注
關(guān)注
0文章
7瀏覽量
3328
原文標(biāo)題:Halcon 圖像糾正編程
文章出處:【微信號(hào):gh_a8b121171b08,微信公眾號(hào):機(jī)器人及PLC自動(dòng)化應(yīng)用】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
labview聯(lián)合Halcon,實(shí)時(shí)采集的圖像應(yīng)該如何傳入?
halcon與LabVIEW Vision混合編程接口問(wèn)題
Labview里面使用Halcon的函數(shù)。 方式為:直接。運(yùn)行后綴為hdev 的Halcon程序
求助:labview與halcon之間的對(duì)象轉(zhuǎn)換
labview調(diào)用halcon程序如何傳入?yún)?shù)?
基于HALCON與圖像拼接的文物修復(fù)系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)
糾正10個(gè)有關(guān)編程的常見(jiàn)誤區(qū)
HALCON項(xiàng)目應(yīng)使用哪種編程語(yǔ)言
HALCON機(jī)器視覺(jué)軟件有哪些優(yōu)點(diǎn)?
labview聯(lián)合halcon的編程方法
如何用halcon和C#進(jìn)行聯(lián)合開(kāi)發(fā)
![如何用<b class='flag-5'>halcon</b>和C#進(jìn)行聯(lián)合開(kāi)發(fā)](https://file1.elecfans.com/web2/M00/88/84/wKgaomRrEUKAZkNjAABBKQPjcQ8545.png)
基于Halcon圖像處理的表面缺陷檢測(cè)方案
![基于<b class='flag-5'>Halcon</b><b class='flag-5'>圖像</b>處理的表面缺陷檢測(cè)方案](https://file1.elecfans.com/web2/M00/8C/A5/wKgaomSvfCKAXtTfAAANTpPtIDg167.jpg)
評(píng)論