geom/src/GEOMGUI/GEOM_Displayer.h

305 lines
12 KiB
C
Raw Normal View History

2014-02-18 12:44:41 +06:00
// Copyright (C) 2007-2014 CEA/DEN, EDF R&D, OPEN CASCADE
2004-12-01 15:39:14 +05:00
//
2012-08-09 13:58:02 +06:00
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//
2012-08-09 13:58:02 +06:00
// 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
2014-02-18 12:44:41 +06:00
// version 2.1 of the License, or (at your option) any later version.
//
2012-08-09 13:58:02 +06:00
// 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.
//
2012-08-09 13:58:02 +06:00
// 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
//
2012-08-09 13:58:02 +06:00
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
2004-12-01 15:39:14 +05:00
//
2012-08-09 13:58:02 +06:00
2009-02-13 17:16:39 +05:00
// GEOM GEOMGUI : GUI for Geometry component
// File : GEOM_Displayer.h
// Author : Vadim SANDLER, Open CASCADE S.A.S. (vadim.sandler@opencascade.com)
2004-12-01 15:39:14 +05:00
//
2009-02-13 17:16:39 +05:00
#ifndef GEOM_DISPLAYER_H
#define GEOM_DISPLAYER_H
2004-12-01 15:39:14 +05:00
2009-02-13 17:16:39 +05:00
#include "GEOM_GEOMGUI.hxx"
2004-12-01 15:39:14 +05:00
2009-02-13 17:16:39 +05:00
#include <SALOME_InteractiveObject.hxx>
2013-02-12 17:35:16 +06:00
class GEOM_Actor;
2009-02-13 17:16:39 +05:00
class SALOME_ListIO;
class SALOME_View;
class SALOME_Prs;
class SALOME_OCCPrs;
class SALOME_VTKPrs;
class SALOME_OCCViewType;
2004-12-01 15:39:14 +05:00
#include <TopoDS_Shape.hxx>
#include <Quantity_Color.hxx>
#include <LightApp_Displayer.h>
2012-08-09 13:58:02 +06:00
#include <LightApp_Study.h>
#include <Aspect_TypeOfMarker.hxx>
#include <TCollection_AsciiString.hxx>
#include <Basics_OCCTVersion.hxx>
2009-02-13 17:16:39 +05:00
#include <QList>
2004-12-01 15:39:14 +05:00
#include <list>
#include <SALOMEconfig.h>
#include CORBA_CLIENT_HEADER(GEOM_Gen)
#define GEOM_ALLOBJECTS -1 // Selection of all objects is activated
#define GEOM_PREVIEW -2 // Definition for preview selection
#define GEOM_ALLSHAPES -3 // Selection of all shapes is activated
#define GEOM_ALLGEOM -4 // Selection of all geom objects is activated
typedef std::list<GEOM::GEOM_Object_ptr> ObjectList;
class TColStd_MapOfInteger;
class LightApp_SelectionMgr;
class SalomeApp_Study;
2005-11-14 18:53:44 +05:00
class SalomeApp_Application;
class SUIT_SelectionFilter;
2013-02-12 17:35:16 +06:00
class Handle_GEOM_AISShape;
2014-01-15 15:27:18 +06:00
class gp_Ax3;
//class SALOME_Selection;
2005-11-14 18:53:44 +05:00
class GEOMGUI_EXPORT GEOM_Displayer : public LightApp_Displayer
2004-12-01 15:39:14 +05:00
{
2004-12-01 15:39:14 +05:00
public:
/* Constructor */
2005-11-14 18:53:44 +05:00
GEOM_Displayer( SalomeApp_Study* app );
2004-12-01 15:39:14 +05:00
/* Destructor */
virtual ~GEOM_Displayer();
virtual bool canBeDisplayed( const QString& /*entry*/, const QString& /*viewer_type*/ ) const;
2004-12-01 15:39:14 +05:00
/* Display/Erase object methods */
2004-12-01 15:39:14 +05:00
void Display ( const Handle(SALOME_InteractiveObject)& theIO,
const bool updateViewer = true,
2012-08-09 13:58:02 +06:00
SALOME_View* theViewFrame = 0 );
2004-12-01 15:39:14 +05:00
// This overloaded Display() method can be useful for operations
// not using dialog boxes.
void Display ( GEOM::GEOM_BaseObject_ptr theObj,
2012-08-09 13:58:02 +06:00
const bool updateViewer = true );
2004-12-01 15:39:14 +05:00
void Redisplay ( const Handle(SALOME_InteractiveObject)& theIO,
const bool updateViewer = true,
const bool checkActiveViewer = true );
2004-12-01 15:39:14 +05:00
2014-01-15 15:27:18 +06:00
void Redisplay ( const Handle(SALOME_InteractiveObject)& theIO,
const bool theUpdateViewer,
SALOME_View* theViewFrame );
2004-12-01 15:39:14 +05:00
void Erase ( const Handle(SALOME_InteractiveObject)& theIO,
const bool forced = false,
const bool updateViewer = true,
2012-08-09 13:58:02 +06:00
SALOME_View* theViewFrame = 0 );
2004-12-01 15:39:14 +05:00
void Erase ( GEOM::GEOM_BaseObject_ptr theObj,
2004-12-01 15:39:14 +05:00
const bool forced = false,
const bool updateViewer = true,
SALOME_View* theViewFrame = 0);
2004-12-01 15:39:14 +05:00
2012-08-09 13:58:02 +06:00
void EraseWithChildren(const Handle(SALOME_InteractiveObject)& theIO,
2013-06-17 18:15:50 +06:00
const bool eraseOnlyChildren = false);
2012-08-09 13:58:02 +06:00
2004-12-01 15:39:14 +05:00
/* Display/Erase list of objects methods */
2004-12-01 15:39:14 +05:00
void Display ( const SALOME_ListIO& theIOList,
const bool updateViewer = true );
2004-12-01 15:39:14 +05:00
void Erase ( const SALOME_ListIO& theIOList,
const bool forced = false,
const bool updateViewer = true );
2004-12-01 15:39:14 +05:00
void Redisplay ( const SALOME_ListIO& theIOList,
const bool updateViewer = true,
const bool checkActiveViewer = true );
2004-12-01 15:39:14 +05:00
2014-01-15 15:27:18 +06:00
void Redisplay ( const SALOME_ListIO& theIOList,
const bool theUpdateViewer,
SALOME_View* theViewFrame );
2004-12-01 15:39:14 +05:00
/* build presentation accordint to the current viewer type*/
SALOME_Prs* BuildPrs ( GEOM::GEOM_Object_ptr );
SALOME_Prs* BuildPrs ( const TopoDS_Shape& );
/* Set color for shape displaying. If it is equal -1 then default color is used.
Available values are from Quantity_NameOfColor enumeration */
void SetColor ( const int );
void UnsetColor();
int GetColor () const;
bool HasColor () const;
void SetTransparency ( const double );
void UnsetTransparency();
double GetTransparency () const;
bool HasTransparency () const;
2012-08-09 13:58:02 +06:00
/* Set texture for shape displaying. */
void SetTexture ( const std::string& );
bool HasTexture () const;
std::string GetTexture () const;
2004-12-01 15:39:14 +05:00
/* Set width for shape displaying. If it is equal -1 then default width is used. */
void SetWidth ( const double );
void UnsetWidth();
double GetWidth () const;
bool HasWidth () const;
2012-08-09 13:58:02 +06:00
/* Set width for iso-lines displaying. If it is equal -1 then default width is used. */
void SetIsosWidth ( const int );
int GetIsosWidth () const;
bool HasIsosWidth () const;
/* Set display mode shape displaying. If it is equal -1 then display mode is used. */
int SetDisplayMode( const int );
int GetDisplayMode() const;
int UnsetDisplayMode();
2013-02-12 17:35:16 +06:00
bool HasDisplayMode() const;
2004-12-01 15:39:14 +05:00
/* Sets name - for temporary objects only */
2005-11-14 18:53:44 +05:00
void SetName( const char* theName );
void UnsetName();
2004-12-01 15:39:14 +05:00
/* Reimplemented from SALOME_Displayer */
virtual void Update( SALOME_OCCPrs* );
virtual void Update( SALOME_VTKPrs* );
2012-08-09 13:58:02 +06:00
virtual void BeforeDisplay( SALOME_View*, const SALOME_OCCPrs* );
virtual void AfterDisplay ( SALOME_View*, const SALOME_OCCPrs* );
#if OCC_VERSION_LARGE > 0x06070000
virtual void BeforeErase ( SALOME_View*, const SALOME_OCCPrs* );
#endif
virtual void AfterErase ( SALOME_View*, const SALOME_OCCPrs* );
2004-12-01 15:39:14 +05:00
/* This methos is used for activisation/deactivisation of objects to be displayed*/
void SetToActivate( const bool );
bool ToActivate() const;
/* Activate/Deactivate selection*/
void LocalSelection( const Handle(SALOME_InteractiveObject)&, const int );
void LocalSelection( const SALOME_ListIO& theIOList, const int );
void GlobalSelection( const int = GEOM_ALLOBJECTS, const bool = false );
2009-02-13 17:16:39 +05:00
void GlobalSelection( const TColStd_MapOfInteger&, const bool = false, const QList<int>* = 0 );
2004-12-01 15:39:14 +05:00
2005-11-14 18:53:44 +05:00
SalomeApp_Study* getStudy() const;
2004-12-01 15:39:14 +05:00
2009-02-13 17:16:39 +05:00
static SALOMEDS::Color getUniqueColor( const QList<SALOMEDS::Color>& );
2012-10-08 17:16:36 +06:00
static SALOMEDS::Color getPredefinedUniqueColor();
2012-08-09 13:58:02 +06:00
/*Get color of the geom object*/
static SALOMEDS::Color getColor(GEOM::GEOM_Object_var aGeomObject, bool& hasColor);
/* Get minimum or maximum enclosed shape type */
static int getMinMaxShapeType( const TopoDS_Shape& shape, bool ismin );
/* Check if the object is a vertex or a compound of vertices */
static bool isCompoundOfVertices( const TopoDS_Shape& theShape );
/* Builds presentation of not published object */
virtual SALOME_Prs* buildSubshapePresentation(const TopoDS_Shape& aShape,
const QString&,
SALOME_View* = 0);
/* Update visibility and parameters of the currently selected field step's color scale */
void UpdateColorScale( const bool theIsRedisplayFieldSteps = false, const bool updateViewer = true );
2004-12-01 15:39:14 +05:00
protected:
/* internal methods */
2012-08-09 13:58:02 +06:00
/* Builds presentation according to the current viewer type */
2005-09-27 12:32:15 +06:00
virtual SALOME_Prs* buildPresentation( const QString&, SALOME_View* = 0 );
2004-12-01 15:39:14 +05:00
/* Sets interactive object */
2005-11-14 18:53:44 +05:00
void setIO( const Handle(SALOME_InteractiveObject)& theIO );
2004-12-01 15:39:14 +05:00
/* Sets shape */
2005-11-14 18:53:44 +05:00
void setShape( const TopoDS_Shape& theShape );
/* Sets field step information */
void setFieldStepInfo( const GEOM::field_data_type theFieldDataType,
const int theFieldDimension,
const QList<QVariant>& theFieldStepData,
const TCollection_AsciiString& theFieldStepName,
const double theFieldStepRangeMin,
const double theFieldStepRangeMax );
2004-12-01 15:39:14 +05:00
/* Resets internal data */
void internalReset();
void clearTemporary( LightApp_SelectionMgr* theSelMgr );
2004-12-01 15:39:14 +05:00
SUIT_SelectionFilter* getFilter( const int theMode );
2009-02-13 17:16:39 +05:00
SUIT_SelectionFilter* getComplexFilter( const QList<int>* );
2013-02-12 17:35:16 +06:00
Quantity_Color qColorFromResources( const QString&, const QColor& );
QColor colorFromResources( const QString&, const QColor& );
void updateShapeProperties( const Handle(GEOM_AISShape)&, bool );
void updateActorProperties( GEOM_Actor*, bool );
2014-01-15 15:27:18 +06:00
void updateDimensions( const Handle(SALOME_InteractiveObject)&, SALOME_OCCPrs*, const gp_Ax3& );
2013-02-12 17:35:16 +06:00
PropMap getObjectProperties( SalomeApp_Study*, const QString&, SALOME_View* = 0 );
PropMap getDefaultPropertyMap();
/* Methods for reading the field step information */
void readFieldStepInfo( GEOM::GEOM_FieldStep_var theGeomFieldStep );
QList<QVariant> groupFieldData( const QList<QVariant>& theFieldStepData,
const int theFieldNbComponents,
const bool theIsString,
double& theFieldStepRangeMin,
double& theFieldStepRangeMax );
// Note: the method is copied from Aspect_ColorScale class
static Standard_Integer HueFromValue( const Standard_Integer aValue,
const Standard_Integer aMin,
const Standard_Integer aMax );
// Note: the method is copied from Aspect_ColorScale class
static Standard_Boolean FindColor( const Standard_Real aValue,
const Standard_Real aMin,
const Standard_Real aMax,
const Standard_Integer ColorsCount,
Quantity_Color& aColor );
2004-12-01 15:39:14 +05:00
protected:
Handle(SALOME_InteractiveObject) myIO;
TopoDS_Shape myShape;
GEOM::field_data_type myFieldDataType;
int myFieldDimension;
QList<QVariant> myFieldStepData;
TCollection_AsciiString myFieldStepName;
double myFieldStepRangeMin;
double myFieldStepRangeMax;
2009-02-13 17:16:39 +05:00
std::string myName;
2012-08-09 13:58:02 +06:00
std::string myTexture;
2004-12-01 15:39:14 +05:00
int myType;
SALOME_View* myViewFrame;
2004-12-01 15:39:14 +05:00
// Attributes
Quantity_Color myShadingColor;
int myColor;
double myWidth;
2012-08-09 13:58:02 +06:00
int myIsosWidth;
2004-12-01 15:39:14 +05:00
bool myToActivate;
int myDisplayMode;
2013-02-12 17:35:16 +06:00
bool myHasDisplayMode;
Aspect_TypeOfMarker myTypeOfMarker;
double myScaleOfMarker;
double myTransparency;
private:
2005-11-14 18:53:44 +05:00
SalomeApp_Application* myApp;
2013-02-12 17:35:16 +06:00
friend class GEOM_Swig;
2004-12-01 15:39:14 +05:00
};
2009-02-13 17:16:39 +05:00
#endif // GEOM_DISPLAYER_H
2004-12-01 15:39:14 +05:00