X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_Workshop.h;h=37ae6a8a2be07ea5265ba5463d38f4670c141f45;hb=eb860f799eab680975365d8ce18cec6e04a6f391;hp=7af135fc8ba7c165fd1d0954cfee97b59a2cc42d;hpb=e65bf14e2ff3cf853884bf8998fadcece6e3b34c;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_Workshop.h b/src/XGUI/XGUI_Workshop.h old mode 100755 new mode 100644 index 7af135fc8..37ae6a8a2 --- a/src/XGUI/XGUI_Workshop.h +++ b/src/XGUI/XGUI_Workshop.h @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// Copyright (C) 2014-2019 CEA/DEN, EDF R&D // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -12,10 +12,9 @@ // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ or -// email : webmaster.salome@opencascade.com +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #ifndef XGUI_WORKSHOP_H @@ -25,6 +24,7 @@ #include #include +#include #include #include @@ -36,6 +36,7 @@ #include #include #include +#include #ifndef HAVE_SALOME class AppElements_Command; @@ -185,7 +186,7 @@ Q_OBJECT bool canMoveFeature(); /// Move selected features to be after the current feature - void moveObjects(); + void moveObjects(const bool theSplit); /// Returns true if the object can be shaded. If the object is a compsolid result, the method /// checks subobjects of the result @@ -233,11 +234,11 @@ Q_OBJECT /// Returns current module ModuleBase_IModule* module() const { return myModule; } - /// Returns current directory which contains data files - QString currentDataDir() const { return myCurrentDir; } + /// Returns current file + QString currentDataFile() const { return myCurrentFile; } - /// Returns current directory which contains data files - void setCurrentDataDir(const QString& theDir) { myCurrentDir = theDir; } + /// Returns current file + void setCurrentDataFile(const QString& theDir) { myCurrentFile = theDir; } /// Save the current document into a directory /// \param theName - path to the directory @@ -281,12 +282,12 @@ Q_OBJECT /// Has to be called in order to display objects from a specifed group /// with visibility status = true /// \param theDoc the document for objects synchronisation - /// \param theGroup the group name /// \param theUpdateViewer update viewer flag void synchronizeGroupInViewer(const DocumentPtr& theDoc, - const std::string& theGroup, bool theUpdateViewer); + void synchronizeResultTree(const ResultBodyPtr& theRes, bool theUpdateViewer); + #endif /// Update the property panel content by the XML description of the operation and set the panel /// into the operation @@ -315,10 +316,20 @@ Q_OBJECT /// A constant string used for "Move to end" command definition /// It is used for specific processing of Undo/Redo for this command. static QString MOVE_TO_END_COMMAND; + /// A constant string used for "Move to end and split" command definition + /// It is used for specific processing of Undo/Redo for this command. + static QString MOVE_TO_END_SPLIT_COMMAND; /// Closes all in the current session and load the directory /// \param theDirectory a path to directory - void openDirectory(const QString& theDirectory); + void openFile(const QString& theDirectory); + + void updateAutoComputeState(); + + void deactivateCurrentSelector(); + + /// The method updates a Color Scale object in the viewer + void updateColorScaleVisibility(); signals: /// Emitted when selection happens in Salome viewer @@ -387,6 +398,12 @@ signals: /// Create a new document void onNew(); + /// Import part structure from a file + void onImportPart(); + + /// Export features to a file + void onExportPart(); + #ifndef HAVE_SALOME /// Exit application void onExit(); @@ -395,15 +412,15 @@ signals: void onPreferences(); #endif + /// A slot calleon toggle of auto-compute button + void onAutoApply(); + /// Activates/deactivates the trihedron in the viewer AIS context void onTrihedronVisibilityChanged(bool theState); /// Apply the current transparency value if preview in transparency dialog is switched on void onTransparencyValueChanged(); - /// Switch on/off preview of transparency change - void onPreviewStateChanged(); - protected: /// Sets the granted operations for the parameter operation. Firstly, it finds the nested features /// and set them into the operation. Secondly, it asks the module about ids of granted operations. @@ -466,6 +483,12 @@ private: /// compute preview. void onPreviewActionClicked(); + /// Called on help button clicked in the property panel. + void onHelpActionClicked(); + + //! The slot is called only once on resizing of Object Browser + void onDockSizeChanged(); + private: /// Init menu void initMenu(); @@ -488,7 +511,7 @@ private: void createDockWidgets(); /// Extends undo/redo toolbutton's with history menu - /// \param theObject - in the OpenParts it is a QToolButton by itself, + /// \param theObject - in the CADBuilder it is a QToolButton by itself, /// in salome mode - QAction that creates a button. /// \param theSignal - void "updateUndoHistory" or "updateRedoHistory" SIGNAL; /// \param theSlot - onUndo(int) or onRedo(int) SLOT @@ -502,6 +525,13 @@ private: /// \param theTimes number of applies the given action void processUndoRedo(const ModuleBase_ActionType theActionType, int theTimes); + /// Clear content of temporary directory + void clearTemporaryDir(); + + /// Set current point of view normal to selected planar face + /// \param toInvert invert the normal vector + void setNormalView(bool toInvert = false); + private: #ifndef HAVE_SALOME AppElements_MainWindow* myMainWindow; ///< desktop window @@ -525,10 +555,11 @@ private: XGUI_ContextMenuMgr* myContextMenuMgr; ///< manager of context menu build XGUI_ModuleConnector* myModuleConnector; ///< implementation of ModuleBase_IWorkshop XGUI_WorkshopListener* myEventsListener; ///< processing of events - QString myCurrentDir; ///< cached the last open directory + QString myCurrentFile; ///< cached the last open directory QIntList myViewerSelMode; ///< selection modes set in the viewer Config_DataModelReader* myDataModelXMLReader; ///< XML reader of data model XGUI_InspectionPanel* myInspectionPanel; ///< container of feature attributes widgets + QTemporaryDir myTmpDir; ///< a direcory for uncompressed files }; #endif