X-Git-Url: https://vaikene.ee/gitweb/pswgen11.html?a=blobdiff_plain;ds=sidebyside;f=src%2Fplugins%2FSdiWindow%2Fsdiwindow.h;h=4c46eea83617e083813905eae322f5e80cbcbe63;hb=0c61450fcffcb36a6e23ca5b083c26543d956084;hp=0032bc6dafd5986daabb74cc8b11d4f3e4800056;hpb=8e0779e2e5a9f947f79c28e2ff121f6ffdd78b3f;p=evaf
diff --git a/src/plugins/SdiWindow/sdiwindow.h b/src/plugins/SdiWindow/sdiwindow.h
index 0032bc6..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