CTK插件框架学习3-第一个插件编写

CTK插件框架学习3-第一个插件编写前两章把CTK插件库编译好了,这里篇编写一个插件试一下,共需要创建两个小工程,一个是插件库,一个是测试程序。1.插件库编写1.1创建工程打开Qtcreator,新建一个EmputyqmakeProject,并给工程命名为ctk-plugin-first。Kits选择”DesktopQt5.12.3MSVC201764bit”。更改ctk-plugin-first.pro文…

大家好,又见面了,我是你们的朋友全栈君。

前两章把CTK插件库编译好了,这里篇编写一个插件试一下,共需要创建两个小工程,一个是插件库,一个是测试程序。

1. 插件库编写

1.1 创建工程

打开Qt creator,新建一个Emputy qmake Project,并给工程命名为ctk-plugin-first。Kits选择”Desktop Qt5.12.3 MSVC2017 64bit”。
在这里插入图片描述
更改ctk-plugin-first.pro文件,添加TARGET、CONFIG等参数,并添加头文件路径。需要注意的是,头文件路径需要添加两个位置,出了源码目录下,还要添加编译后生成文件的路径。这里以WIN64宏定义的方式区分MINGW编译器与MSVC编译器。

QT += core
QT -= gui

TARGET = ctk-plugin-first
TEMPLATE = lib
CONFIG += plugin

INCLUDEPATH += E:/lwks/CTK/Libs/Core \
            += E:/lwks/CTK/Libs/PluginFramework

if (contains(DEFINES,WIN64)){
# for msvc compiler
    INCLUDEPATH += E:/lwks/ctk-vsbuild/CTK-build/Libs/PluginFramework
    INCLUDEPATH += E:/lwks/ctk-vsbuild/CTK-build/Libs/Core
}else{
# for mingw compiler
    INCLUDEPATH += E:/lwks/ctk-superbuild/CTK-build/Libs/PluginFramework
    INCLUDEPATH += E:/lwks/ctk-superbuild/CTK-build/Libs/Core
}

1.2 创建插件类

在ctk-plugin-first工程中新建一个类,取名为FirstPluginActivator,程序源码如下。
firstpluginactivator.h

#ifndef FIRSTPLUGINACTIVATOR_H
#define FIRSTPLUGINACTIVATOR_H

#include <QObject>
#include "ctkPluginActivator.h"
#include "ctkPluginContext.h"

class FirstPluginActivator : public QObject, public ctkPluginActivator
{
    Q_OBJECT
    Q_PLUGIN_METADATA(IID "FirstPlugin")
    Q_INTERFACES(ctkPluginActivator)
public:
    FirstPluginActivator();
    void start(ctkPluginContext *context);
    void stop(ctkPluginContext *context);
};

#endif // FIRSTPLUGINACTIVATOR_H

firstpluginactivator.cpp

#include "firstpluginactivator.h"
#include <QDebug>

FirstPluginActivator::FirstPluginActivator()
{

}

void FirstPluginActivator::start(ctkPluginContext *context)
{
    qDebug() << "first plugin start: " << context;
}

void FirstPluginActivator::stop(ctkPluginContext *context)
{
    qDebug() << "first plugin stop: " << context;
}

这个类的功能比较简单,仅仅实现了插件的start与stop服务。

1.3 创建资源文件

在工程中添加资源文件,名称可以随便取,我这里命名为resource。在资源文件中添加prefix,命名为/ctk-plugin-first/META-INF,注意这个prefix的命名,命名形式为”/工程名/META-INF“,这个不能随意更改。在该prefix下新建一个文件,命名为MANIFEST.MF,文件内容如下。

Plugin-SymbolicName:FirstPlugin
Plugin-Version:1.0.0

MANIFEST.MF文件是插件库的清单文件,可以在里面设置插件库名称、版本号等属性,也可以添加一些自定义属性,后面测试程序中可以读取这些属性值。
整个插件库工程创建完毕,工程文件结构如下图所示。
在这里插入图片描述
编译工程,正常情况下,会在”build-ctk-plugin-first-Desktop_Qt_5_12_3_MSVC2017_64bit-Debug/debug”目录下生成ctk-plugin-first.dll文件,该文件是下面测试程序运行时需要加载的插件库文件。

2. 测试程序编写

2.1 创建工程

打开Qt Creator,新建一个Qt Console Applciation工程,工程名随便取,我这里设置的是MainTest,kits同样选用Qt5.12.3 MSVC2017 64bit”。新建的控制台应用,工程文件结构图应如下图所示,包含.pro文件与main.cpp文件。
在这里插入图片描述
修改.pro工程文件,添加CTK库的头文件路径以及库文件的路径。注意它与插件库工程的.pro文件配置不同的是,添加了LIBS的配置,-L指向了编译CTK工程的输出文件路径中,并指定链接CTKCore库以及CTKPluginFramework库。

QT -= gui

CONFIG += console
CONFIG -= app_bundle

INCLUDEPATH += E:/lwks/CTK/Libs/Core \
            += E:/lwks/CTK/Libs/PluginFramework

if (contains(DEFINES,WIN64)){
# for msvc compiler
    INCLUDEPATH += E:/lwks/ctk-vsbuild/CTK-build/Libs/PluginFramework
    INCLUDEPATH += E:/lwks/ctk-vsbuild/CTK-build/Libs/Core
    LIBS += -LE:/lwks/ctk-vsbuild/CTK-build/bin/Debug -lCTKCore -lCTKPluginFramework
}else{
# for mingw compiler
    INCLUDEPATH += E:/lwks/ctk-superbuild/CTK-build/Libs/PluginFramework
    INCLUDEPATH += E:/lwks/ctk-superbuild/CTK-build/Libs/Core
    LIBS += -LE:/lwks/ctk-superbuild/CTK-build/bin -lCTKCore -lCTKPluginFramework
}

DEFINES += QT_DEPRECATED_WARNINGS
SOURCES += \
        main.cpp

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

2.2 编写测试程序

在main.cpp中,首先初始化插件框架,然后获取插件服务的context,用插件contex进行安装插件,并启动插件,代码如下。

#include <QCoreApplication>
#include <ctkPluginFrameworkFactory.h>
#include <ctkPluginFramework.h>
#include <ctkPluginException.h>
#include <ctkPluginContext.h>
#include <QtDebug>
#include <QUrl>

#ifdef __MINGW32__
    // 使用mingw编译器时的定义
    QString static firstPlugin_filePath = "E:/lwks/build-ctk-plugin-first-Desktop_Qt_5_12_3_MinGW_64_bit-Debug/debug/ctk-plugin-first.dll";
#else
    // 使用msvc编译器时的定义
    QString static firstPlugin_filePath = "E:/lwks/build-ctk-plugin-first-Desktop_Qt_5_12_3_MSVC2017_64bit-Debug/debug/ctk-plugin-first.dll";
#endif

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    ctkPluginFrameworkFactory frameworkFactory;
    QSharedPointer<ctkPluginFramework> framework = frameworkFactory.getFramework();

    // 初始化并启动插件框架
    try {
        framework->init();
        framework->start();
        qDebug() << "CTK plugin framework start...";
    } catch (const ctkPluginException &e) {
        qDebug() << "CTK plugin framework init err: " << e.what();
        return -1;
    }

    // 获取插件服务的contex
    ctkPluginContext* pluginContext = framework->getPluginContext();
    try {
        // 安装插件
        QSharedPointer<ctkPlugin> plugin = pluginContext->installPlugin(QUrl::fromLocalFile(firstPlugin_filePath));
        qDebug() << QString("Plugin[%1_%2] installed...").arg(plugin->getSymbolicName()).arg(plugin->getVersion().toString());
        // 启动插件
        plugin->start(ctkPlugin::START_TRANSIENT);
        qDebug() << "Plugin start...";
    } catch (const ctkPluginException &e) {
        qDebug() << QString("Failed install or run plugin: ") << e.what();
        return -2;
    }

    return a.exec();
}

2.3 运行测试

编译并运行MainTest工程,程序运行结果如下。可以看出,在加载启动ctk-plugin-first插件后,该插件的start函数被调用执行。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/144928.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • LSTM模型结构讲解[通俗易懂]

    LSTM模型结构讲解[通俗易懂]人类并不是每时每刻都从一片空白的大脑开始他们的思考。在你阅读这篇文章时候,你都是基于自己已经拥有的对先前所见词的理解来推断当前词的真实含义。我们不会将所有的东西都全部丢弃,然后用空白的大脑进行思考。我们的思想拥有持久性。传统的神经网络并不能做到这点,看起来也像是一种巨大的弊端。例如,假设你希望对电影中的每个时间点的时间类型进行分类。传统的神经网络应该很难来处理这个问题——使用电影中先前的事件推…

  • c++禁止隐式转换_无法将int隐式转换为类

    c++禁止隐式转换_无法将int隐式转换为类C++有一个很方便的功能—隐式转换,比如有一个函数voidfunc(doublef);调用它的时候func(5);func(5.0);都是有效的。但有时候,这个功能就很麻烦了。比如:classA{public:A(conststring&amp;v){///…}}void…

    2022年10月11日
  • Java:利用递归实现分形[通俗易懂]

    Java:利用递归实现分形[通俗易懂]Java:利用递归实现分形分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的几何形状,可以分成数个部分,且每一部分都(至少近似地)是整体缩小后的形状”,即具有自相似的性质。例如谢尔宾斯基三角形、谢尔宾斯基地毯、康托尔三分集。如何实现分形根据分形的定义我们知道,图形可被分成数个部分,每一部分都是完整图形的缩小版。以康托尔三分集为例,第一条线段被分成三部分,左右两边的部分又继续被分成三部分,如此循环下去。因此

  • 项目范围管理计划模板[通俗易懂]

    项目范围管理计划模板[通俗易懂]XX项目项目范围管理计划     文档编号:文档信息:文档名称:文档类别:工程类密   级:内部基准:版本信息:1.0建立日期:创建人:批准人:批准日期: 保管人:存放位置:配置库编辑软件:MicrosoftOffice2007中文版     文档修订记录

  • 文本相似度计算_文本相似度分析算法

    文本相似度计算_文本相似度分析算法这篇文档简单介绍一下Simhash算法一.Simhash计算文档相似度的算法,比如用在搜索引擎的爬虫系统中,收录重复的网页是毫无意义的,只会造成存储和计算资源的浪费。有时候我们需要处理类似的文档,比如新闻,很多不同新闻网的新闻内容十分相近,标题略有相似。如此问题,便可以应用Simhash文档相似度算法,查看两篇文档相似程度,删去相似度高的web文档。二.

  • 学大数据要学哪些算法_学习大数据需要掌握哪些知识?[通俗易懂]

    学大数据要学哪些算法_学习大数据需要掌握哪些知识?[通俗易懂]大数据已经成为时代发展的趋势,很多人纷纷选择学习大数据,想要进入大数据行业。大数据技术体系庞大,包括的知识较多,系统的学习大数据可以让你全面掌握大数据技能。学习大数据需要掌握哪些知识?怎样进行大数据学习的快速入门?学大数据课程之前要先学习一种计算机编程语言。Java是大数据学习需要的编程语言基础,因为大数据的开发基于常用的高级语言。而且不论是学习hadoop,还是数据挖掘,都需要有编程语言作为基础…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号