目录
The Simple Style Plugin Profile
前言
文档中给的现象图是这样的:
但在本人Qt5.8 Windows 7端 MinGW编译器中 没有官方实例的现象,这里修改成如下的现象:
详情请看这个连接:
https://blog.csdn.net/qq78442761/article/details/86577171
Style Plugin Example
插件是Qt存储在类中的共享库,这个能够在运行的时候被QPluginLoader加载。插件是对应用程序的扩展。
写一个插件的逻辑:
1. 首先要继承插件的一个基础类(文档查base classes);
2. 重写函数,并且增加宏。
在Style Plugin Example这个例子中plugin为外观,这属于low-level,而high-level插件要看overview document。
plugin中,新风格继承了QStylePlugin类,通过Qt进行加载,通过QStyleFactory确保其插件可用;通过实现SimpleStylePlugin类使得Button的风格改变。
这个新风格在某种意义上是和平台无关的,使用QProxyStyle会改变当前应用程序的风格。
使用StyleWindow去测试插件。SimpleStyle和StyleWindow并不能加载所有类型的插件,他们的实现很简单。
这里要注意,pro文件对plugin很重要(本人自己总结的,好像是废话,pro对所有Qt程序都重要)
SimpleStylePlugin Class 定义
SimpleStylePlugin为QStylePlugin的子类,并且为一个接口类:
class SimpleStylePlugin : public QStylePlugin
{
Q_OBJECT
Q_PLUGIN_METADATA(IID "org.qt-project.Qt.QStyleFactoryInterface" FILE "simplestyle.json")
public:
SimpleStylePlugin() {}
QStringList keys() const;
QStyle *create(const QString &key) override;
};
keys()函数返回这个style的名称,create()函数的一个参数为string类型,返回QStyle的键值。这两个函数都是QStylePlugin中继承下来的纯虚函数,当应用程序需要创建一个SimpleStyle风格的实例时,插件将会被创建。
SimpleStylePlugin Class 实现
keys()函数的实现:
QStringList SimpleStylePlugin::keys() const
{
return QStringList() << "SimpleStyle";
}
返回值为这个类的名称SimpleStyle为QStringList类型。
下面是create()函数:
QStyle *SimpleStylePlugin::create(const QString &key)
{
if (key.toLower() == "simplestyle")
return new SimpleStyle;
return 0;
}
这里要注意大小写问题,采用key.toLower()这种方式可以有效的解决大小写。
main()函数
int main(int argv, char *args[])
{
QApplication app(argv, args);
QApplication::setStyle(QStyleFactory::create("simplestyle"));
StyleWindow window;
window.resize(200, 50);
window.show();
return app.exec();
}
当QApplication对象被初始化后,Qt将加载style插件。QStyleFactory类能识别所有style并且能生成对象(所有与style有个的接口都可这么做)。
The Simple Style Plugin Profile
styleplugin的pro文件如下:
TEMPLATE = lib
CONFIG += plugin
QT += widgets
HEADERS = simplestyle.h \
simplestyleplugin.h
SOURCES = simplestyle.cpp \
simplestyleplugin.cpp
TARGET = simplestyleplugin
这里要注意:
1. template要设置为lib而不是传统的app;
2. config设置为plugin,这样才能时dll中实现接口的给功能。