• qt配置halcon环境实现读入图像显示


    首先,在Halcon里面写流程。

    1. *读入图像
    2. read_image (Image, 'cat')
    3. *获取图片大小
    4. get_image_size (Image, Width, Height)
    5. *设置适应大小显示
    6. dev_set_part (0, 0, Height-1, Width-1)
    7. *显示图像
    8. dev_display (Image)

    菜单栏文件->导出程序备用。

    QT新建工程,

    设置MSVC编译器,不选择MinGW编译器。

    编译一下。

    生成Debug文件夹。

    QT工程目录文件夹下添加库文件(halcon安装目录下的include和lib文件夹)

    在Qt工程文件中添加几个主要的库文件。

    mainwindow.h的头文件中,加上halcon相关头文件与命名空间。

    1. #include
    2. #include
    3. #include
    4. using namespace HalconCpp;

    在halcon安装目录下,找到halcon.dll和halconcpp.dll,hcanvas.dll,复制到项目debug文件夹下。

    做一个简单界面,一个做图像的显示,一个按钮读入图片。

    拖拽Graphics View控件到窗体,自定义控件名称。

    在button按钮里面添加点击事件。

    将Halcon中导出的C++代码引入进来。

    头文件定义全局变量。

    1. // Local iconic variables
    2. HObject ho_Image;
    3. // Local control variables
    4. HTuple hv_Width, hv_Height,hv_WindowHandle;

    在button按钮事件里面加入代码。

    1. Hlong WindID = (Hlong)ui->image_window->winId ();
    2. if (HDevWindowStack::IsOpen())
    3. CloseWindow(HDevWindowStack::Pop());
    4. SetWindowAttr("background_color","black");
    5. //这里用界面的控件显示图像。
    6. OpenWindow(0,0,ui->image_window->width (),ui->image_window->height (),WindID,"visible","",&hv_WindowHandle);
    7. HDevWindowStack::Push(hv_WindowHandle);
    8. //主体函数。打开对话框,获得打开图像的名称。
    9. QString path = QFileDialog::getOpenFileName(this,"Slect Image","","(*.png *.jpg)");
    10. if(path=="") return;
    11. //读入图像
    12. ReadImage(&ho_Image, HTuple(path.toStdString().c_str()));
    13. //获得图片大小
    14. GetImageSize(ho_Image, &hv_Width, &hv_Height);
    15. //设置适应大小显示
    16. SetPart(hv_WindowHandle, 0, 0, hv_Height-1, hv_Width-1);
    17. //显示图像
    18. DispObj(ho_Image, hv_WindowHandle);

    运行程序效果,点击读入图片,弹出对话框选择图片,显示图片。

  • 相关阅读:
    numpy矩阵画框框
    sendfile数据copy流程
    OPPO广告联盟战略升级,全面提升开发者变现效率
    基础 | JVM - [内存模型 & JMM]
    一文带你入门微服务,通俗易懂
    k8s 实战篇 - 镜像打包部署 - springboot&mysql - 3
    【Vue】v-if和v-show的区别
    【机器学习基础】无监督学习(3)——AutoEncoder
    Postgresql | 锁机制详解(表锁和行锁)
    昨天阅读量800多
  • 原文地址:https://blog.csdn.net/weixin_56423149/article/details/133946602