X-Git-Url: https://vaikene.ee/gitweb/pswgen11.html?a=blobdiff_plain;ds=inline;f=src%2Fplugins%2FSdiWindow%2Fsdiwindow.h;h=4c46eea83617e083813905eae322f5e80cbcbe63;hb=a81a943bee20df3c7eb34bafb3e3fe878facfe4e;hp=b2c3bc6c2fbdd69a1120d997091dd1bd586e489c;hpb=1cac301bb12de664bd7e7ec59b78e7dfaf04f6d1;p=evaf
diff --git a/src/plugins/SdiWindow/sdiwindow.h b/src/plugins/SdiWindow/sdiwindow.h
index b2c3bc6..4c46eea 100644
--- a/src/plugins/SdiWindow/sdiwindow.h
+++ b/src/plugins/SdiWindow/sdiwindow.h
@@ -23,11 +23,14 @@
#include "isdiwindow.h"
#include
+#include
#include
#include
#include
#include
+#include
+#include
class QVBoxLayout;
@@ -36,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:
@@ -48,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
@@ -68,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;
};
/**
@@ -115,6 +125,7 @@ private: // Members
class SdiWindowPlugin : public Plugins::iPlugin
{
Q_OBJECT
+ Q_INTERFACES(eVaf::Plugins::iPlugin)
public:
@@ -132,7 +143,7 @@ public:
private:
/// iSdiWindow interface implementation
- SdiWindowImpl * mWindow;
+ MainWindow * mWindow;
};
} // namespace eVaf::SdiWindow::Internal