Qt 插件总结

1、 接口的定义

//step 1 定义接口
class RegExpInterface
{
public:
    virtual ~RegExpInterface() {}
    virtual QString regexp(const QString &message) = 0;
};

// step 2
// 声明接口
// 使用 Q_DECLARE_INTERFACE 宏,是为了让Qt元对象系统知道该接口,这样以来,在运行时便可以识别实现接口的插件。
// Q_DECLARE_INTERFACE(接口类名, 接口标识),第二个参数(RegExpInterface_iid)是一个标识接口的字符串,必须唯一。

#define RegExpInterface_iid "org.qter.Examples.myplugin.RegExpInterface"
Q_DECLARE_INTERFACE(RegExpInterface,RegExpInterface_iid )
#endif // REGEXPINTERFACE_H

2、接口的实现

//step 3  实现接口
class REGEXPLUGINSHARED_EXPORT RegexPlugin : public QObject,RegExpInterface
{
    Q_OBJECT

    //Q_PLUGIN_METADATA宏用于描述插件元数据,第一个参数为插件的 IID,与接口定义的IID相同
    //第二个参数FILE是可选的,指定一个本地json文件,该文件中可以描述插件的相关数据信息
    Q_PLUGIN_METADATA(IID RegExpInterface_iid FILE "regexplugindata.json")

    //Q_INTERFACES 宏用于告诉 Qt 该类实现的接口。
    Q_INTERFACES(RegExpInterface)
public:
    RegexPlugin();

    // RegExpInterface interface
public:
    QString regexp(const QString &message);
};

3、接口的使用

    // 进入插件目录
    QDir pluginsDir(qApp->applicationDirPath());
    pluginsDir.cd("bin");
    // 遍历插件目录
    foreach (QString fileName, pluginsDir.entryList(QDir::Files)) {
        QPluginLoader pluginLoader(pluginsDir.absoluteFilePath(fileName));
        QObject *plugin = pluginLoader.instance();
        if (plugin) {
            //取回json文件的内容
            QJsonObject w = pluginLoader.metaData().value("MetaData").toObject();
            qDebug()<<w;
            regexpInterface = qobject_cast<RegExpInterface *>(plugin);
            if (regexpInterface)
                return true;
        }
    }
    return false;

源码链接
https://download.csdn.net/download/u011370855/10698561

猜你喜欢

转载自blog.csdn.net/u011370855/article/details/82913701