-// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
-
-
-#ifndef NewGeom_SalomeViewer_H
-#define NewGeom_SalomeViewer_H
-
-#include "NewGeom.h"
+// Copyright (C) 2014-2022 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
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// 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
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+
+#ifndef SHAPERGUI_SalomeViewer_H
+#define SHAPERGUI_SalomeViewer_H
+
+#include "SHAPER_SHAPERGUI.h"
#include <ModuleBase_IViewer.h>
#include <ModuleBase_IViewWindow.h>
class QMouseEvent;
class QKeyEvent;
-class NewGeom_OCCSelector;
+class SHAPERGUI_OCCSelector;
class OCCViewer_Viewer;
class SUIT_ViewManager;
+class AIS_TextLabel;
/**
* \ingroup Salome
-* A class for providing access of NewGeom functionality to
+* A class for providing access of SHAPERGUI functionality to
* SALOME view window functionality
*/
-class NewGeom_SalomeView: public ModuleBase_IViewWindow
+class SHAPERGUI_SalomeView: public ModuleBase_IViewWindow
{
public:
/// Constructor
/// \param theViewer a reference to a viewer
- NewGeom_SalomeView(OCCViewer_Viewer* theViewer);
+ SHAPERGUI_SalomeView(OCCViewer_Viewer* theViewer);
virtual Handle(V3d_View) v3dView() const;
/**
* \ingroup Salome
-* A class for providing access of NewGeom functionality to
+* A class for providing access of SHAPERGUI functionality to
* SALOME viewer functionality
*/
-class NewGeom_SalomeViewer : public ModuleBase_IViewer
+class SHAPERGUI_SalomeViewer : public ModuleBase_IViewer
{
Q_OBJECT
public:
/// Constructor
/// \param theParent a parent object
- NewGeom_SalomeViewer(QObject* theParent);
+ SHAPERGUI_SalomeViewer(QObject* theParent);
- ~NewGeom_SalomeViewer();
+ ~SHAPERGUI_SalomeViewer();
//! Returns AIS_InteractiveContext from current OCCViewer
virtual Handle(AIS_InteractiveContext) AISContext() const;
virtual bool enableDrawMode(bool isEnabled);
//! For some signals it disconnects the window from usual signal and connect it to the module ones
- void reconnectActions(SUIT_ViewWindow* theWindow, const bool theUseNewGeomSlot);
+ void reconnectActions(SUIT_ViewWindow* theWindow, const bool theUseSHAPERSlot);
//! Perfroms the fit all for the active view
virtual void fitAll();
+ //! Erases all presentations from the viewer
+ virtual void eraseAll();
+
//! Sets the view projection
/// \param theX the X projection value
/// \param theY the Y projection value
/// Set selector
/// \param theSel a selector instance
- void setSelector(NewGeom_OCCSelector* theSel);
+ void setSelector(SHAPERGUI_OCCSelector* theSel);
/// Add selection filter to the viewer
virtual void addSelectionFilter(const Handle(SelectMgr_Filter)& theFilter);
virtual void clearSelectionFilters();
/// Returns current selector
- NewGeom_OCCSelector* selector() const
+ SHAPERGUI_OCCSelector* selector() const
{
return mySelector;
}
/// Update current viewer
virtual void update();
- /// Method returns True if the viewer can process editing objects
+ /// Method returns True if the viewer can process editing objects
/// by mouse drugging. If this is impossible thet it has to return False.
virtual bool canDragByMouse() const;
/// \param toActivate - activation flag
void activateViewer(bool toActivate);
- // Fit all along Z (perpendicular to display)
- virtual void Zfitall();
+ // Methods for color scale management
+
+ //! Returns True if ColorScale is visible
+ virtual bool isColorScaleVisible() const;
+
+ //! Show/Hide ColorScale object
+ virtual void setColorScaleShown(bool on);
+
+ //! Set position of color scale
+ // \param theX is X position relative to current view width
+ // \param theY is Y position relative to current view heigth
+ virtual void setColorScalePosition(double theX, double theY);
+
+ //! Set size of color scale
+ // \param theW is width relative to current view width
+ // \param theh is height relative to current view heigth
+ virtual void setColorScaleSize(double theW, double theH);
+
+ //! Set range of color scale
+ // \param theMin is a minimal value
+ // \param theMax is a maximal value
+ virtual void setColorScaleRange(double theMin, double theMax);
+
+ //! Set number of intervals of color scale
+ // \param theNb is number of intervals
+ virtual void setColorScaleIntervals(int theNb);
+
+ //! Set text heigth of color scale
+ // \param theH is number of intervals
+ virtual void setColorScaleTextHeigth(int theH);
+
+ //! Set color of text of color scale
+ // \param theH is number of intervals
+ virtual void setColorScaleTextColor(const QColor& theColor);
+
+ //! Set title of color scale
+ // \param theText is a title
+ virtual void setColorScaleTitle(const QString& theText);
+
+ //! Sets the text displayed in right-top corner of the 3D view
+ //! \param theText the text to display, or empty string to erase presentation;
+ //! the first item is the font name and text color
+ //! \param theSize size of the text font
+ virtual void setText(const ModuleBase_IViewer::TextColor& theText, const int theSize);
+
+ virtual void setFitter(OCCViewer_Fitter* theFitter);
+ virtual OCCViewer_Fitter* fitter() const;
private slots:
void onMousePress(SUIT_ViewWindow*, QMouseEvent*);
void onSelectionChanged();
void onViewTransformed(OCCViewer_ViewWindow::OperationType);
- /// Emit signal about trihedron visiblity change because SALOME sets the trihedron visible by this signal.
+ /// Emit signal about trihedron visiblity change because SALOME sets
+ /// the trihedron visible by this signal.
/// It is necessary to activate the viewer trihedron in the current selection mode
void onViewPortMapped();
+ /// Signal called in order to apdate viewer transformed objects
+ void onAfterViewCreated();
+
private:
- NewGeom_OCCSelector* mySelector;
- NewGeom_SalomeView* myView;
+ SHAPERGUI_OCCSelector* mySelector;
+ SHAPERGUI_SalomeView* myView;
bool myIsSelectionChanged;
+ /// Presentation of names of all displayed SHAPER group results in 3D view,
+ /// a text in right-top corner of the view.
+ NCollection_List<Handle(AIS_TextLabel)> myText;
};