****************************
*本節主要是圖像增強和圖像平滑、去噪實現
*1.直方圖均衡
*2.增強對比度
*3.處理失焦圖像
*4.均值濾波
*5.中值濾波
*6.高斯濾波
*7.光照不均勻處理
******************************
*1.直方圖均衡
read_image (board, 'D:/halcon_prj/halcon學習/code/data/boardEqu')
*直方圖均衡化
rgb1_to_gray (board, GrayImage)
equ_histo_image (GrayImage, ImageEquHisto)
*顯示直方圖
gray_histo (board, board, AbsoluteHisto, RelativeHisto)
gray_histo (ImageEquHisto, ImageEquHisto, AbsoluteHisto1, RelativeHisto1)
dev_open_window (0, 0, 512, 512, 'black', WindowHandle)
dev_set_color ('red')
gen_region_histo (histol1, AbsoluteHisto, 255, 5, 1)
dev_set_color ('green')
gen_region_histo (histol2, AbsoluteHisto1, 255, 450, 1)
*2.增強對比度
read_image (text, 'D:/halcon_prj/halcon學習/code/data/text')
*對比度算子
emphasize (text, ImageEmphasize, 10, 10, 1.5)
dev_display (ImageEmphasize)
*還可以使用其他算子
scale_image_max (text, ImageScaleMax)
dev_display (ImageScaleMax)
*3.處理失焦圖像
*如果圖片的並沒有對上焦距,其畫面是模糊不清的,因此需要一些增強方法,如各種銳化算子,Sobel算子、Canny算子、Laplace算子等
*這里使用沖擊濾波器,其原理在圖像的邊緣形成一些沖擊,以此對邊緣進行增強
read_image (test,'D:/halcon_prj/halcon學習/code/data/defocusComponnet')
*該算子對應halcon的例子在shock_filter.hdev
shock_filter (test, SharpenedImage, 0.5, 20, 'canny', 2.5)
dev_display (SharpenedImage)
*4.均值濾波
read_image (Image, 'D:/halcon_prj/halcon學習/code/data/marker')
mean_image (Image, ImageMean, 9, 9)
dev_display (ImageMean)
*5.中值濾波
read_image (Image, 'D:/halcon_prj/halcon學習/code/data/marker')
median_image (Image, ImageMedian, 'circle', 3, 'continued')
*6.高斯濾波
read_image (Image, 'D:/halcon_prj/halcon學習/code/data/marker')
gauss_filter (Image, ImageGauss, 7)
dev_display (ImageGauss)
*7.光照不均勻處理
*這里如果是灰度圖像可以通過圖像增強和直方圖均衡化進行處理
*彩色圖像的處理可以通過顏色三通道進行處理,這里主要是彩色處理
read_image (Image, 'D:/halcon_prj/halcon學習/code/data/label')
decompose3 (Image, ImageRed, ImageGreen, ImageBlue)
*把分離出的三張照片分別通過濾波和均衡化進行處理,然后子合成彩色圖片
mean_image (ImageRed, ImageMean1, 9, 9)
*圖像增強
emphasize (ImageMean1, ImageEmphasize1, 7, 7, 1)
*照射增強對比。圖像中非常暗的部分被強烈“照亮”,非常亮的部分被“暗化”
illuminate (ImageEmphasize1, ImageIlluminate, 20, 20, 0.55)
equ_histo_image (ImageGreen, ImageEquHisto1)
equ_histo_image (ImageBlue, ImageEquHisto2)
compose3 (ImageIlluminate, ImageEquHisto1, ImageEquHisto2, MultiChannelImage)
dev_display (MultiChannelImage)