X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_IModule.h;h=5787ccfb09989d5aa62afee6753a0117fc91b384;hb=7981678231adaa3ef7468d7564fef427cffdaf50;hp=ae652617e9f8a4f5ae7d39576d6fc0bd3f37f1ea;hpb=1ae46761293cceffc4e65b851da944b0de81ef8e;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_IModule.h b/src/ModuleBase/ModuleBase_IModule.h index ae652617e..5787ccfb0 100644 --- a/src/ModuleBase/ModuleBase_IModule.h +++ b/src/ModuleBase/ModuleBase_IModule.h @@ -1,20 +1,33 @@ #ifndef ModuleBase_IModule_H #define ModuleBase_IModule_H +#include "ModuleBase.h" +#include "ModuleBase_IWorkshop.h" + #include #include + class QAction; -class XGUI_Workshop; +class QMouseEvent; +class QKeyEvent; class Config_WidgetAPI; class ModuleBase_ModelWidget; +class ModuleBase_Operation; +class ModuleBase_IWorkshop; /** -* Interface to a module -*/ -class ModuleBase_IModule: public QObject + * Interface to a module + */ +class MODULEBASE_EXPORT ModuleBase_IModule : public QObject { -public: + Q_OBJECT + public: + + ModuleBase_IModule(ModuleBase_IWorkshop* theParent); + + virtual ~ModuleBase_IModule() {} + /// Reads description of features from XML file virtual void createFeatures() = 0; @@ -23,25 +36,70 @@ public: /// Creates an operation and send it to loop /// \param theCmdId the operation name - virtual void launchOperation(const QString& theCmdId) = 0; + virtual void launchOperation(const QString& theCmdId); /// Called when it is necessary to update a command state (enable or disable it) //virtual bool isFeatureEnabled(const QString& theCmdId) const = 0; /// Creates custom widgets for property panel - virtual QWidget* createWidgetByType(const std::string& theType, QWidget* theParent, - Config_WidgetAPI* theWidgetApi, QList& theModelWidgets) + virtual QWidget* createWidgetByType(const std::string& theType, QWidget* theParent, + Config_WidgetAPI* theWidgetApi, + QList& theModelWidgets) { return 0; } - virtual ~ModuleBase_IModule() {}; + ModuleBase_IWorkshop* workshop() const { return myWorkshop; } + +protected slots: + + /// Called on selection changed event + virtual void onSelectionChanged() {} + + /// SLOT, that is called by mouse press in the viewer. + /// The mouse released point is sent to the current operation to be processed. + /// \param theEvent the mouse event + virtual void onMousePressed(QMouseEvent* theEvent) {} + + /// SLOT, that is called by mouse release in the viewer. + /// The mouse released point is sent to the current operation to be processed. + /// \param theEvent the mouse event + virtual void onMouseReleased(QMouseEvent* theEvent) {} + + /// SLOT, that is called by mouse move in the viewer. + /// The mouse moved point is sent to the current operation to be processed. + /// \param theEvent the mouse event + virtual void onMouseMoved(QMouseEvent* theEvent) {} + + /// SLOT, that is called by the mouse double click in the viewer. + /// \param theEvent the mouse event + virtual void onMouseDoubleClick(QMouseEvent* theEvent) {} + + /// SLOT, that is called by the key in the viewer is clicked. + /// \param theEvent the mouse event + virtual void onKeyRelease(QKeyEvent* theEvent) {} + + protected: + /// Sends the operation for launching + /// \param theOperation the operation + void sendOperation(ModuleBase_Operation* theOperation); + + /// Creates a new operation + /// \param theCmdId the operation name + /// \param theFeatureKind a kind of feature to get the feature xml description + virtual ModuleBase_Operation* createOperation(const std::string& theCmdId, + const std::string& theFeatureKind = "") = 0; + + +protected: + + ModuleBase_IWorkshop* myWorkshop; + }; //! This function must return a new module instance. -extern "C" -{ -typedef ModuleBase_IModule* (*CREATE_FUNC)(XGUI_Workshop*); +extern "C" { +typedef ModuleBase_IModule* (*CREATE_FUNC)(ModuleBase_IWorkshop*); } #define CREATE_MODULE "createModule"