1. 程式人生 > >Qt外掛應用小結

Qt外掛應用小結

1. 當一個外掛具有多個Interface的時候,使用QPluginLoader得到外掛的Object後,可以將Object分別轉為各個介面型別

例如:Qt Example basictools(外掛) 和 plugandpaint(使用外掛),qt的兩個例子

class BasicToolsPlugin : public QObject,
                         public BrushInterface,
                         public ShapeInterface,
                         public FilterInterface
{
    Q_OBJECT
    Q_PLUGIN_METADATA(IID "org.qt-project.Qt.Examples.PlugAndPaint.BrushInterface" FILE "basictools.json")
    Q_INTERFACES(BrushInterface ShapeInterface FilterInterface)
public:
    ……
 }
app中載入外掛並且使用
QPluginLoader loader("BasicToolsPlugin");
QObject * object = loader.instance();
BrushInterface *brush = qobject_cast<BrushInterface *>(object);
if(brush){}
ShapeInterface *shape = qobject_cast<ShapeInterface *>(object);
if(shape){}
FilterInterface *filter = qobject_cast<FilterInterface *>(object);
if(filter){}

2. 使用QDesignerCustomWidgetInterface介面建立一個可以顯示的外掛

PS:這個介面屬於design模組,所以需要在.pro檔案中加入 QT += designer

class QDesignerCustomWidgetInterface
{
public:
    virtual ~QDesignerCustomWidgetInterface() {}

    virtual QString name() const = 0;
    virtual QString group() const = 0;
    virtual QString toolTip() const = 0;
    virtual QString whatsThis() const = 0;
    virtual QString includeFile() const = 0;
    virtual QIcon icon() const = 0;

    virtual bool isContainer() const = 0;

    virtual QWidget *createWidget(QWidget *parent) = 0;//需要重點實現的類,在這個類中建立外掛的窗體,並且返回。

    virtual bool isInitialized() const { return false; }
    virtual void initialize(QDesignerFormEditorInterface *core) { Q_UNUSED(core); }

    virtual QString domXml() const
    {
        return QString::fromUtf8("<widget class=\"%1\" name=\"%2\"/>")
            .arg(name()).arg(name().toLower());
    }

    virtual QString codeTemplate() const { return QString(); }
};

只要有了寫外掛的基礎,這個顯示類也非常容易理解。我們只需要重點實現createWidget(),在載入外掛後呼叫createWidget() 返回我們要顯示的外掛,大工告成。