博客
关于我
关于如何在Qt Creater 中调用已经写好的 C++ 程序
阅读量:720 次
发布时间:2019-03-21

本文共 1732 字,大约阅读时间需要 5 分钟。

如何在 Qt Creator 中调用已写好的 C++ 程序?——一个 OpenCV 开发者的 Qt 界面尝试

作为一名 OpenCV 开发者,我尝试在 Qt 应用中集成已有的 OpenCV 函数。然而,这个过程并非一帆风顺,最终还是不得不临时使用 VS 来编写相关部分代码。这一做法虽然能快速实现需求,但也暴露出了一些问题。

项目背景与需求我的目标是为 OpenCV 函数添加 Qt 界面。为了实现这一目标,我需要在 Qt 应用中调用一个已有的 OpenCV 程序。这段程序用于调用相机,并通过 exe 文件进行数据传输和处理。因此,我需要确保在 Qt 项目中正确调用与该程序相关的 exe 文件。

解决方案探索为了在 Qt 应用中启动外部程序,我在应用的核心逻辑中添加了两种方法:

第一种方法是使用 QProcess::startDetached。这种方法可以在后台启动目标程序,并且不会影响到主程序的运行。其代码实现如下:

QProcess::startDetached("D:/Qt_Unit/QT_Documentation/OpencvTest0/OpenCVTest.exe");

这种方式能够正确启动 OpenCV 调用相机的程序。

第二种方法是借助 cmd 脚本通过 taskkill 指令终止进程。这种方法需要以下步骤:

  • 创建一个包含 cmd 指令的字符串列表:
  • QStringList Stop;Stop << "/c" << "taskkill" << "-f" << "-im" << "OpenCVTest.exe";
    1. 创建一个 QProcess 对象并启动 cmd 程序:
    2. QProcess process;process.start("cmd.exe", Stop);process.waitForFinished();process.close();

      这种方法可以确保即使在使用 QProcess::startDetached 启动的外部程序仍在运行时,能够在合适的时候正确终止它。

      完整代码示例为了更详细地展示解决方案,我提供了完整的 main.cpp 文件内容:

      #include "widget.h"#include "ui_widget.h"#include 
      #include
      #include
      Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget){ ui->setupUi(this); connect(ui->pushButton, &QPushButton::clicked, []("){ QProcess::startDetached("D:/Qt_Unit/QT_Documentation/OpencvTest0/OpenCVTest.exe"); }); connect(ui->pushButton_2, &QPushButton::clicked, []((){ QStringList Stop; Stop << "/c" << "taskkill" << "-f" << "-im" << "OpenCVTest.exe"; QProcess process; process.start("cmd.exe", Stop); process.waitForFinished(); process.close(); }));}Widget::~Widget(){ delete ui;}

      该代码实现了两个功能:

    3. 启动 OpenCV 程序;
    4. 通过 cmd 脚本终止相关进程。
    5. 总结通过以上方法,我成功在 Qt 应用中集成并管理外部 C++ 程序。在实际开发中,需要确保所调用程序的路径正确并对进程管理有足够的了解。如果你有类似的项目需求,希望这篇指南对你有所帮助。

    转载地址:http://kbwgz.baihongyu.com/

    你可能感兴趣的文章
    mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
    查看>>
    MySQL5.7.18主从复制搭建(一主一从)
    查看>>
    MySQL5.7.19-win64安装启动
    查看>>
    mysql5.7性能调优my.ini
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>
    mysql8的安装与卸载
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump备份时忽略某些表
    查看>>
    mysqldump实现数据备份及灾难恢复
    查看>>
    mysqlreport分析工具详解
    查看>>
    MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
    查看>>
    MYSQL一直显示正在启动
    查看>>
    MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
    查看>>