如何创建 Qt 插件?

简单三部曲

  1. 定义接口类或接口基类并使用 Q_DECLARE_INTERFACE 宏进行声明
  2. 所有的插件都需要继承该基类并继承 QObject(不带界面插件) or QWidget(带界面插件)
  3. 在插件类中添加 Q_PLUGIN_METADATA 导出元数据,使用 Q_INTERFACES 指定继承基类(该基类需要使用 Q_DECLARE_INTERFACE 声明过)

如何生成?

示例

*.pro 文件内容如下

# 插件依赖模块
QT += core gui widgets # 生成目标文件名称
TARGET = FlowWidget
TEMPLATE = lib
CONFIG += plugin # 插件输出目录
DESTDIR = $$[QT_INSTALL_PLUGINS]/generic DEFINES += QT_DEPRECATED_WARNINGS SOURCES += \
flowWidget.cpp HEADERS += \
flowWidget.h DISTFILES += FlowWidget.json include($$PWD/interface/interface.pri)

interface.pri 内容如下:

SOURCES += \

HEADERS += \
$$PWD/flowInterface.h INCLUDEPATH += $$PWD

纯接口类定义如下:

#include <QtPlugin>
class QImage;
class QString;
class QWidget;
class FlowInterface
{
public:
FlowInterface() {}
virtual ~FlowInterface() {}
virtual void process() = 0;
/*!
属性页
*/
virtual QWidget *propertyPage() = 0;
}; #define FlowInterface_iid "com.xiongwei.cheung.FlowInterface" Q_DECLARE_INTERFACE(FlowInterface, FlowInterface_iid)

注意:在插件类中我们需要实现接口中定义的纯虚函数

插件定义分为带界面和不带界面两种,采用多重继承的方式分别继承 QWidget 或 QObject 即可.

  1. 带界面插件定义如下:
class FlowWidget : public QWidget , FlowInterface
{
Q_OBJECT
Q_PLUGIN_METADATA(IID "com.xiongwei.cheung.FlowWidget" FILE "FlowWidget.json")
Q_INTERFACES(FlowInterface)
public:
explicit FlowWidget(QWidget *parent = nullptr);
void process();
QWidget *propertyPage();
signals: public slots: private: }; FlowWidget::FlowWidget(QWidget *parent) : QWidget(parent)
{ } void FlowWidget::process()
{
// to do something
} QWidget *FlowWidget::propertyPage()
{
return this;
}

FlowWidget.json 文件是可选的,可通过该文件实现密钥插件

{
"Keys" : [ "FlowWidget" ]
}
  1. 不带界面插件定义如下:
class FlowObject : public QObject , FlowInterface
{
Q_OBJECT
Q_PLUGIN_METADATA(IID "com.xiongwei.cheung.FlowObject")
Q_INTERFACES(FlowInterface)
public:
explicit FlowObject(QObject *parent = nullptr);
void process();
QWidget *propertyPage();
signals: public slots: private: }; FlowObject::FlowObject(QObject *parent) : QObject(parent)
{ } void FlowObject::process()
{
// to do something
} QWidget *FlowObject::propertyPage()
{
return nullptr;
}

如何使用?

main.cpp 文件中添加插件加载路径

QCoreApplication::applicationDirPath().append("\generic");

在工程文件中包含插件接口基类文件 flowInterface.h

#include <QPluginLoader>
#include "flowInterface.h" void load()
{
// 添加一个枚举目录所有动态库文件即可加载所有插件
QPluginLoader pluginLoader("FlowWidget.dll");
// 打印插件元数据,即 json 文件内容中的键值数据
qDebug() << pluginLoader.metaData();
// 加载该插件
QObject *plugin = pluginLoader.instance();
if (plugin) {
// 转换成接口基类指针
FlowInterface *p = qobject_cast<FlowInterface *>(plugin);
if (p){
// 显示界面
p->propertyPage()->show();
} }
}

注意一个插件类中只能存在一个 Q_PLUGIN_METADATA 宏,使用该宏会导出 qt_plugin_instanceqt_plugin_query_metadata 俩个函数。

显然如果使用 2 次 Q_PLUGIN_METADATA 宏会导致函数重定义.

实际上如果向导出多个插件的可以使用 QGenericPlugin 的手法根据 keys and `` 创建不同的对象.

如何创建 Qt 插件?的更多相关文章

  1. [Qt Creator 快速入门] 第9章 国际化、帮助系统和Qt插件

    一.国际化 国际化的英文表述为Internationalization,通常简写为I18N(首尾字母加中间的字符数),一个应用程序的国际化就是使该应用程序可以让其他国家的用户使用的过程. Qt支持现在 ...

  2. [Qt插件]-03创建Qt Designer自定义部件

    如何创建自定义部件并添加到Qt Designer来爽快的拖动部件可视化界面设计?   Qt Designer基于插件的架构使得它可以使用用户设计或者第三方提供的自定义部件,就像使用标准的Qt部件一样. ...

  3. [Qt插件]-02创建应用程序插件(插件化开发的一种思路)

    本篇是学习Qt Creator快速入门,插件开发的笔记   分为两部分 创建插件 使用插件的应用程序(测试插件)   插件是被使用的应用程序加载使用的. 是使用插件的应用程序定义接口,插件按照接口来实 ...

  4. VS2013中使用QT插件后每次重新编译问题

    环境 系统:win7 64位旗舰版 软件:VS2013.QT5.5.1-32位.Qt5 Visual Studio Add-in1.2.4 概述 使用QT Visual Studio插件打开pro项目 ...

  5. VS2017上在线和离线安装Qt插件(在线安装)

    版权声明:如需转载,请告知博主并声明出处 https://blog.csdn.net/CLinuxF/article/details/88816436文章目录前言在线安装离线安装(推荐)前言很多朋友喜 ...

  6. 【Win10+eclipse+MinGW+QT安装教程】已有eclipse环境下配置QT插件出错详解

    (纪念一下装了一整天濒临绝望的自己[/doge]) (以下所有下载项一律使用32位) step1:下载安装eclipse.适配的jdk.MinGW和QT 1.下载32位eclipse for c++以 ...

  7. 设置qt插件路径

    1.在Qt中使用 WebKit 浏览器核心 使用 QtWebKit 需要在工程文件(*.pro)中加入: QT +=webkitQT += network 2.QtWebKit的flash支持 QtW ...

  8. Qt 插件学习(一)

    插件是什么 注意:这儿暂时不考虑静态插件(潜意识中总觉得它根本就不算插件). 插件是一个动态库(共享库).动态库是一个独立的文件中的独立模块,可被多个程序访问. 先看动态库的两种用法 1. 程序链接时 ...

  9. [Qt插件]-01Qt插件&&提升部件(自定义控件)

    本篇的文档为:How to Create Qt Plugins https://doc.qt.io/qt-5/plugins-howto.html   前言 Qt插件(Qt Plugin)就是一个共享 ...

随机推荐

  1. ls 显示目录下的内容和文件相关属性信息

    1.命令功能 ls命令是“list directory contents”,显示当前目录下的内容和文件属性. 2.语法格式 ls  [option]  file ls  选项  文件名 3.选项说明 ...

  2. vue 概念与使用vue-cli脚手架快速构建项目

    vue 定义:是一套构建用户界面的渐进式框架,Vue 采用自底向上增量开发的设计.Vue 的核心库只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合. 数据渲染机制: 核心: 响应式数据绑定 ...

  3. java判断回文数

  4. phpstorm 调试时浏览器显示The requested resource / was not found on this server

    1.进入thinkphp项目的public 目录运行以下命令即可 root@jiang:/var/www/tp5# php -S localhost:8080 router.php PHP 7.2.2 ...

  5. 【HDOJ6665】Calabash and Landlord(dfs)

    题意:二维平面上有两个框,问平面被分成了几个部分 x,y<=1e9 思路:分类讨论可以 但数据范围实在太小了,离散化以后随便dfs一下 #include<bits/stdc++.h> ...

  6. 刚性方程 Stiff equation

    In mathematics, a stiff equation is a differential equation for which certain numerical methods for ...

  7. :nth-child 与 ;nth-of-child

    //:nth-child:是选择父元素下的第几个元素,不分标签类别,计数从1开始 //:nth-of-type:是选择父元素下的同类型元素的第几个元素.区分标签类别,计数从1开始

  8. leetcode 238. 除自身以外数组的乘积 (python)

    给定长度为 n 的整数数组 nums,其中 n > 1,返回输出数组 output ,其中 output[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积. 示例: 输入: [1 ...

  9. 初次打开jenkins页面一片空白的解决办法

    安装完成jenkins后,点击[使用admin账号继续]后,页面一片空白的解决办法: step1: Jenkins插件管理-高级设置界面==> http://localhost:8080/plu ...

  10. SqlServer 字段类型详解

    bit    整型 bit数据类型是整型,其值只能是0.1或空值.这种数据类型用于存储只有两种可能值的数据,如Yes 或No.True 或False .On 或Off. 注意:很省空间的一种数据类型, ...