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);
复制代码

 

 

 

 

 

 

posted @   天子骄龙  阅读(1691)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
历史上的今天:
2019-03-05 数组
点击右上角即可分享
微信分享提示

目录导航