X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_IModule.h;h=5787ccfb09989d5aa62afee6753a0117fc91b384;hb=7981678231adaa3ef7468d7564fef427cffdaf50;hp=6a4401f765e27efa2f7c1b83576ce313564595f9;hpb=12621bb509825d0eb1fb0847a7f9c8011021ca5a;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_IModule.h b/src/ModuleBase/ModuleBase_IModule.h index 6a4401f76..5787ccfb0 100644 --- a/src/ModuleBase/ModuleBase_IModule.h +++ b/src/ModuleBase/ModuleBase_IModule.h @@ -1,18 +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; @@ -21,18 +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; + //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) + { + return 0; + } + + 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; - virtual ~ModuleBase_IModule() {}; }; //! 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"