X-Git-Url: https://vaikene.ee/gitweb/highlight.css?a=blobdiff_plain;f=src%2Fplugins%2FSdiWindow%2Fsdiwindow.h;h=4c46eea83617e083813905eae322f5e80cbcbe63;hb=a81a943bee20df3c7eb34bafb3e3fe878facfe4e;hp=31b311d60454d8a4c4d04efa640f5fb88bf7b4b4;hpb=f443e47f50a5d12f592aaae6a4e553e4a125ee1c;p=evaf diff --git a/src/plugins/SdiWindow/sdiwindow.h b/src/plugins/SdiWindow/sdiwindow.h index 31b311d..4c46eea 100644 --- a/src/plugins/SdiWindow/sdiwindow.h +++ b/src/plugins/SdiWindow/sdiwindow.h @@ -23,12 +23,14 @@ #include "isdiwindow.h" #include +#include #include #include #include #include -#include +#include +#include class QVBoxLayout; @@ -37,11 +39,12 @@ namespace SdiWindow { namespace Internal { /** - * Main window widget + * Main window widget implementing the iSdiWindow interface */ -class MainWindow : public QWidget +class MainWindow : public QWidget, public iSdiWindow { Q_OBJECT + Q_INTERFACES(eVaf::SdiWindow::iSdiWindow) public: @@ -49,13 +52,24 @@ public: virtual ~MainWindow(); - bool init(); + virtual bool init(QString const & args); - void done(); + virtual void done(); + + virtual bool isReady() { return mReady; } + + virtual void addPanel(QString const & name, Gui::Panel * panel); + + virtual Gui::Panel * panel(QString const & name) const; + + virtual bool showPanel(QString const & name); + + virtual void changeEvent(QEvent * e); - void addWidget(QWidget * widget); + virtual void closeEvent(QCloseEvent * e); - void addLayout(QLayout * layout); + +protected: // Methods private: // Methods @@ -69,45 +83,40 @@ private: // Methods private: // Members - /// The layout of the window - QVBoxLayout * mLayout; - - /// Widgets and layouts added to the main window - QList > mItemsAdded; - -}; + /// Ready flag + bool mReady; -/** - * iSdiWindow interface implementation - */ -class SdiWindowImpl : public iSdiWindow -{ - Q_OBJECT + /// The layout of the main window + QVBoxLayout * mLayout; -public: + /// Name of the main panel that becomes part of this window + QString mMainPanelName; - SdiWindowImpl(); + /// List of GUI::Panel objects added to the manager + QList mPanels; - virtual ~SdiWindowImpl(); + /// List of minimized GUI::Panel objects + QVector mMinimizedPanels; - bool init(const QString & args); + /// Hash with panel names + QHash mPanelNames; - void done(); + /// Current main panel added to this window + Gui::Panel * mMainPanel; - bool isReady() const { return mReady; } - virtual void addWidget(QWidget * widget) { wWindow->addWidget(widget); } +private: // Methods - virtual void addLayout(QLayout * layout) { wWindow->addLayout(layout); } + /// Gets the main panel name from module attributes + QString getMainPanelName(QString const & args) const; -private: // Members +private slots: - /// Ready flag - bool mReady; + /// Panel destroyed signal. We need to remove the panel from all the + /// lists. + void panelDestroyed(QObject * obj = 0); - /// The main window widget - MainWindow * wWindow; }; /** @@ -116,6 +125,7 @@ private: // Members class SdiWindowPlugin : public Plugins::iPlugin { Q_OBJECT + Q_INTERFACES(eVaf::Plugins::iPlugin) public: @@ -133,7 +143,7 @@ public: private: /// iSdiWindow interface implementation - SdiWindowImpl * mWindow; + MainWindow * mWindow; }; } // namespace eVaf::SdiWindow::Internal