X-Git-Url: https://vaikene.ee/gitweb/pswgen11.html?a=blobdiff_plain;f=src%2Fplugins%2FSdiWindow%2Fsdiwindow.h;h=f88425554319b872fc52fdb9e38ccae724f21497;hb=54f282ee6797c05e60993632218875092362bdf7;hp=d886cca5d842914472e0e92b939abb7e7e04e78c;hpb=06f9c5336ba8a2200b68f636520707693eb5ada7;p=evaf
diff --git a/src/plugins/SdiWindow/sdiwindow.h b/src/plugins/SdiWindow/sdiwindow.h
index d886cca..f884255 100644
--- a/src/plugins/SdiWindow/sdiwindow.h
+++ b/src/plugins/SdiWindow/sdiwindow.h
@@ -23,21 +23,27 @@
#include "isdiwindow.h"
#include
+#include
#include
#include
#include
+#include
+#include
+
+class QVBoxLayout;
namespace eVaf {
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:
@@ -45,9 +51,13 @@ public:
virtual ~MainWindow();
- bool init();
+ virtual bool init(QString const & args);
+
+ virtual void done();
- void done();
+ virtual bool isReady() { return mReady; }
+
+ virtual void addWindow(Gui::Window * window);
private: // Methods
@@ -57,28 +67,6 @@ private: // Methods
void saveSettings();
void restoreSettings();
-};
-
-/**
- * iSdiWindow interface implementation
- */
-class SdiWindowImpl : public iSdiWindow
-{
- Q_OBJECT
-
-public:
-
- SdiWindowImpl();
-
- virtual ~SdiWindowImpl();
-
- bool init(const QString & args);
-
- void done();
-
- bool isReady() const { return mReady; }
-
- virtual QWidget * widget() const { return wWindow; }
private: // Members
@@ -86,8 +74,12 @@ private: // Members
/// Ready flag
bool mReady;
- /// The main window widget
- MainWindow * wWindow;
+ /// The layout of the main window
+ QVBoxLayout * mLayout;
+
+ /// eVaf GUI window implementing the main window
+ QWeakPointer mWindow;
+
};
/**
@@ -96,6 +88,7 @@ private: // Members
class SdiWindowPlugin : public Plugins::iPlugin
{
Q_OBJECT
+ Q_INTERFACES(eVaf::Plugins::iPlugin)
public:
@@ -113,7 +106,7 @@ public:
private:
/// iSdiWindow interface implementation
- SdiWindowImpl * mWindow;
+ MainWindow * mWindow;
};
} // namespace eVaf::SdiWindow::Internal