halcon-gray_histo_range計算直方圖


在HDevelop中

dev_update_off()

read_image (Image, 'D:/bb/tu/ma.jpg')
rgb1_to_gray(Image,Image1)
*將RGB圖像轉換為灰度圖像

get_image_size (Image1, Width, Height)
dev_open_window(10,10,Width, Height,'black',WindowHandle)

get_domain (Image1, Domain)
gray_histo_range(Domain,Image1,0,255,256, Histo, BinSize)
*計算直方圖:指定區域和灰度值
*參數1:要計算直方圖的區域
*參數2:輸入圖像
*參數3:要計算的最小灰度值。默認值0
*參數4:要計算的最大灰度值。默認值255
*參數5:要計算的灰度值數量-->參數3到參數4分成多少份
*參數6:返回的直方圖
*參數7:返回每份的像素數量

gen_region_histo (Region, Histo, 255, 255, 1)
*將一個直方圖轉換為一個區域
*參數1:返回的區域
*參數2:輸入一個直方圖
*參數3:該直方圖中心y坐標
*參數4:該直方圖中心x坐標
*參數5:直方圖的比例因子


dev_display(Region)

 

在QtCreator中

    HObject  ho_Image, ho_Image1,ho_Disp, ho_Domain, ho_Region;
    HTuple  hv_Width, hv_Height, hv_WindowHandle;
    HTuple  hv_Histo, hv_BinSize;
    ReadImage(&ho_Image, "D:/bb/tu/ma.jpg");
    Rgb1ToGray(ho_Image, &ho_Image1);
    //將RGB圖像轉換為灰度圖像

    GetDomain(ho_Image1, &ho_Domain);
    GrayHistoRange(ho_Domain, ho_Image1, 0, 255, 256, &hv_Histo, &hv_BinSize);
    //計算直方圖:指定區域和灰度值
    //參數1:要計算直方圖的區域
    //參數2:輸入圖像
    //參數3:要計算的最小灰度值。默認值0
    //參數4:要計算的最大灰度值。默認值255
    //參數5:要計算的灰度值數量-->參數3到參數4分成多少份
    //參數6:返回的直方圖
    //參數7:返回每份的像素數量

    GenRegionHisto(&ho_Region, hv_Histo, 255, 255, 1);
    //將一個直方圖轉換為一個區域
    //參數1:返回的區域
    //參數2:輸入一個直方圖
    //參數3:該直方圖中心y坐標
    //參數4:該直方圖中心x坐標
    //參數5:直方圖的比例因子

    RegionToMean(ho_Region, ho_Image1, &ho_Disp);
      //區域轉圖像

    GetImageSize(ho_Disp, &hv_Width, &hv_Height);
    SetWindowAttr("background_color","black");
    OpenWindow(10,10,hv_Width,hv_Height,0,"visible","",&hv_WindowHandle);
    DispObj(ho_Disp, hv_WindowHandle);

 

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM