2014-02-20 18:25:37 +06:00
|
|
|
// Copyright (C) 2007-2014 CEA/DEN, EDF R&D, OPEN CASCADE
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
2005-06-07 19:22:20 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +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-20 18:25:37 +06:00
|
|
|
// version 2.1 of the License, or (at your option) any later version.
|
2005-06-07 19:22:20 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +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.
|
2005-06-07 19:22:20 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +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
|
2005-06-07 19:22:20 +06:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SMESH SMESHGUI : GUI for SMESH component
|
|
|
|
// File : SMESHGUI_VTKUtils.h
|
|
|
|
// Author : Open CASCADE S.A.S.
|
|
|
|
//
|
|
|
|
#ifndef SMESHGUI_VTKUTILS_H
|
|
|
|
#define SMESHGUI_VTKUTILS_H
|
2008-03-07 12:47:05 +05:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SMESH includes
|
2008-03-07 12:47:05 +05:00
|
|
|
#include "SMESH_SMESHGUI.hxx"
|
2014-07-10 17:50:08 +06:00
|
|
|
#include "SMESH_TypeDefs.hxx"
|
|
|
|
#include "SMDS_MeshNode.hxx"
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
#include "SMESHGUI_Utils.h"
|
2014-07-10 17:50:08 +06:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
#include <SMESH_Object.h>
|
2008-03-07 12:47:05 +05:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SALOME KERNEL includes
|
|
|
|
#include <SALOMEDSClient_definitions.hxx>
|
2008-03-07 12:47:05 +05:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
// SALOME GUI includes
|
|
|
|
#include <SALOME_InteractiveObject.hxx>
|
|
|
|
#include <VTKViewer_Filter.h>
|
2008-03-07 12:47:05 +05:00
|
|
|
|
|
|
|
class TColStd_IndexedMapOfInteger;
|
|
|
|
|
2005-06-07 19:22:20 +06:00
|
|
|
class SALOMEDSClient_Study;
|
|
|
|
|
|
|
|
class SUIT_ViewWindow;
|
|
|
|
class SUIT_ViewManager;
|
|
|
|
|
|
|
|
class SVTK_ViewWindow;
|
|
|
|
class SVTK_Selector;
|
|
|
|
|
2005-11-03 13:38:17 +05:00
|
|
|
class LightApp_SelectionMgr;
|
2008-03-07 12:47:05 +05:00
|
|
|
class SalomeApp_Module;
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
class SMESHGUI;
|
2004-12-01 15:48:31 +05:00
|
|
|
class SMESH_Actor;
|
2005-06-07 19:22:20 +06:00
|
|
|
class SALOME_Actor;
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2012-08-09 16:03:55 +06:00
|
|
|
class vtkActor;
|
2014-07-10 17:50:08 +06:00
|
|
|
class SMDS_Mesh;
|
|
|
|
class SMDS_MeshNode;
|
|
|
|
class gp_Pln;
|
|
|
|
class gp_Lin;
|
|
|
|
class gp_Dir;
|
|
|
|
class gp_Pnt2d;
|
|
|
|
class gp_Vec2d;
|
|
|
|
class Handle(Geom_Line);
|
|
|
|
class Handle(Geom_Plane);
|
2009-02-17 10:27:49 +05:00
|
|
|
namespace SMESH
|
|
|
|
{
|
2004-12-01 15:48:31 +05:00
|
|
|
//----------------------------------------------------------------------------
|
2009-02-17 10:27:49 +05:00
|
|
|
typedef std::pair<int,std::string> TKeyOfVisualObj;
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2012-08-09 16:03:55 +06:00
|
|
|
TVisualObjPtr GetVisualObj( int, const char*, bool nulData =false );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
|
|
|
void OnVisuException(); // PAL16631
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SVTK_ViewWindow* GetViewWindow( const SalomeApp_Module* = 0,
|
2012-08-09 16:03:55 +06:00
|
|
|
bool = false );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SVTK_ViewWindow* FindVtkViewWindow( SUIT_ViewManager*, SUIT_ViewWindow* );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SVTK_ViewWindow* GetVtkViewWindow( SUIT_ViewWindow* );
|
2008-03-07 12:47:05 +05:00
|
|
|
|
|
|
|
SMESHGUI_EXPORT
|
2005-06-07 19:22:20 +06:00
|
|
|
SVTK_ViewWindow* GetCurrentVtkView();
|
2005-01-20 11:25:54 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
SMESHGUI_EXPORT
|
|
|
|
void RepaintCurrentView();
|
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void RepaintViewWindow( SVTK_ViewWindow* );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void RenderViewWindow( SVTK_ViewWindow* );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
|
|
|
void FitAll();
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SMESH_Actor* FindActorByEntry( SUIT_ViewWindow*, const char* );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SMESH_Actor* FindActorByEntry( const char* );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SMESH_Actor* FindActorByObject( CORBA::Object_ptr );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SMESH_Actor* CreateActor( _PTR(Study), const char*, int = false );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void DisplayActor( SUIT_ViewWindow*, SMESH_Actor* );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void RemoveActor( SUIT_ViewWindow*, SMESH_Actor* );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void RemoveVisuData( int );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
2009-02-17 10:27:49 +05:00
|
|
|
enum EDisplaing { eDisplayAll, eDisplay, eDisplayOnly, eErase, eEraseAll };
|
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
bool UpdateView( SUIT_ViewWindow*, EDisplaing, const char* = "" );
|
2012-08-09 16:03:55 +06:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
bool UpdateView( EDisplaing, const char* = "" );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2004-12-01 15:48:31 +05:00
|
|
|
void UpdateView();
|
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2012-08-09 16:03:55 +06:00
|
|
|
bool UpdateNulData( const Handle(SALOME_InteractiveObject)& theIO, bool theDisplay);
|
|
|
|
|
|
|
|
SMESHGUI_EXPORT
|
|
|
|
bool Update( const Handle(SALOME_InteractiveObject)& theIO, bool theDisplay);
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void SetPointRepresentation( bool );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void SetPickable( SMESH_Actor* = 0 );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2005-06-14 12:25:33 +06:00
|
|
|
void UpdateSelectionProp( SMESHGUI* );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2013-02-12 20:37:44 +06:00
|
|
|
SMESHGUI_EXPORT
|
|
|
|
void UpdateFontProp( SMESHGUI* );
|
|
|
|
|
2004-12-01 15:48:31 +05:00
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
SVTK_Selector* GetSelector( SUIT_ViewWindow* = GetActiveWindow() );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void SetFilter( const Handle(VTKViewer_Filter)&, SVTK_Selector* = GetSelector() );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
Handle(VTKViewer_Filter) GetFilter( int, SVTK_Selector* = GetSelector() );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
bool IsFilterPresent( int, SVTK_Selector* = GetSelector() );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void RemoveFilter( int, SVTK_Selector* = GetSelector() );
|
2008-03-07 12:47:05 +05:00
|
|
|
|
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void RemoveFilters( SVTK_Selector* = GetSelector());
|
2005-02-02 18:54:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
bool IsValid( SALOME_Actor*, int, SVTK_Selector* = GetSelector() );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2014-07-10 17:50:08 +06:00
|
|
|
int GetNameOfSelectedSortedNodes( SMDSAbs_EntityType,
|
|
|
|
SVTK_Selector*,
|
|
|
|
SMESH_Actor*,
|
|
|
|
int,
|
|
|
|
QString& );
|
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetNameOfSelectedNodes( SVTK_Selector*,
|
2012-08-09 16:03:55 +06:00
|
|
|
const Handle(SALOME_InteractiveObject)&,
|
|
|
|
QString& );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetNameOfSelectedElements( SVTK_Selector*,
|
2012-08-09 16:03:55 +06:00
|
|
|
const Handle(SALOME_InteractiveObject)&,
|
|
|
|
QString& );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetEdgeNodes( SVTK_Selector*, const TVisualObjPtr&, int&, int& );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2005-06-07 19:22:20 +06:00
|
|
|
//----------------------------------------------------------------------------
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetNameOfSelectedNodes( LightApp_SelectionMgr*,
|
2012-08-09 16:03:55 +06:00
|
|
|
const Handle(SALOME_InteractiveObject)&,
|
|
|
|
QString& );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetNameOfSelectedNodes( LightApp_SelectionMgr*, QString& );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetNameOfSelectedElements( LightApp_SelectionMgr*,
|
2012-08-09 16:03:55 +06:00
|
|
|
const Handle(SALOME_InteractiveObject)&,
|
|
|
|
QString& );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetNameOfSelectedElements( LightApp_SelectionMgr*, QString& );
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetSelected( LightApp_SelectionMgr*, TColStd_IndexedMapOfInteger&,
|
2012-08-09 16:03:55 +06:00
|
|
|
const bool = true );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
int GetEdgeNodes( LightApp_SelectionMgr*, int&, int& );
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2008-03-07 12:47:05 +05:00
|
|
|
SMESHGUI_EXPORT
|
2009-02-17 10:27:49 +05:00
|
|
|
void SetControlsPrecision( const long );
|
2012-08-09 16:03:55 +06:00
|
|
|
|
|
|
|
#ifndef DISABLE_PLOT2DVIEWER
|
|
|
|
SMESHGUI_EXPORT
|
|
|
|
void ClearPlot2Viewers( SUIT_ViewWindow* theWindow );
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
SMESHGUI_EXPORT
|
|
|
|
bool ComputeClippingPlaneParameters( std::list<vtkActor*> theActorList,
|
2013-03-01 19:13:25 +06:00
|
|
|
double theNormal[3],
|
|
|
|
double theDist,
|
|
|
|
double theBounds[6],
|
|
|
|
double theOrigin[3] );
|
2013-10-16 18:56:06 +06:00
|
|
|
|
|
|
|
bool ComputeBounds( std::list<vtkActor*> theActorList,
|
|
|
|
double theBounds[6]);
|
|
|
|
|
|
|
|
void PositionToDistance( double theBounds[6],
|
|
|
|
double theDirection[3],
|
|
|
|
double thePos[3],
|
|
|
|
double& theDist );
|
2014-07-10 17:50:08 +06:00
|
|
|
typedef std::pair<SMESH_TNodeXYZ, double> TNodeOfDist;
|
|
|
|
typedef std::pair<SMESH_TNodeXYZ, std::pair<double, double> > TNodeOfAngleAndDist, TNodeOfDistToPlaneAndDist;
|
|
|
|
typedef std::pair<int, std::pair<double, double> > TIdOfDistToPlaneAndDist;
|
|
|
|
bool CreatePlaneOnThreePoints( const gp_Pnt& thePoint1,
|
|
|
|
const gp_Pnt& thePoint2,
|
|
|
|
const gp_Pnt& thePoint3,
|
|
|
|
gp_Pln& thePlane );
|
|
|
|
|
|
|
|
void FindNbLowestPoint( std::list<gp_Pnt2d> theList, gp_Pnt2d& theNode );
|
|
|
|
bool IsNotPlaneIntersection( std::vector<SMESH_TNodeXYZ>& theVector,
|
|
|
|
const gp_Pln& thePlane );
|
|
|
|
bool GetCorrectSequenceOfId( std::vector<SMESH_TNodeXYZ>& theVector );
|
|
|
|
void GetCorrectSequenceTwoPlaneOfId( std::vector<SMESH_TNodeXYZ>& thePlane1,
|
|
|
|
std::vector<SMESH_TNodeXYZ>& thePlane2,
|
|
|
|
std::list<int>& theResultListId );
|
|
|
|
void GetSortedNodesOnPolygon( std::vector<SMESH_TNodeXYZ>& theVectorOfNode,
|
|
|
|
std::list<int>& theResultListId );
|
|
|
|
void GetSortedNodesOnPyramid( std::vector<SMESH_TNodeXYZ>& theVectorOfNode,
|
|
|
|
std::list<int>& theResultListId );
|
|
|
|
void GetSortedNodesOnPrism( std::vector<SMESH_TNodeXYZ>& theVectorOfNode,
|
|
|
|
std::list<int>& theResultListId );
|
|
|
|
bool Get2BasePlane( std::vector<SMESH_TNodeXYZ>& theVector,
|
|
|
|
std::vector<SMESH_TNodeXYZ>& thePlane1,
|
|
|
|
std::vector<SMESH_TNodeXYZ>& thePlane2);
|
|
|
|
bool GetNextCombination ( std::vector<int> & theVector1,
|
|
|
|
std::vector<int> & theVector2,
|
|
|
|
int theNbPoint );
|
|
|
|
static bool CompareNodeOfAngleAndDist ( const TNodeOfAngleAndDist& first,
|
|
|
|
const TNodeOfAngleAndDist& second );
|
|
|
|
static bool CompareNodeOfDist ( const TNodeOfAngleAndDist& first,
|
|
|
|
const TNodeOfAngleAndDist& second );
|
|
|
|
static bool CompareDistOfPlane ( const TNodeOfDistToPlaneAndDist& first,
|
|
|
|
const TNodeOfDistToPlaneAndDist& second );
|
|
|
|
static bool CompareDistOfPlaneById ( const TIdOfDistToPlaneAndDist& first,
|
|
|
|
const TIdOfDistToPlaneAndDist& second );
|
|
|
|
static bool CompareDistForCorrectPlane ( const TNodeOfDist& first,
|
|
|
|
const TNodeOfDist& second );
|
|
|
|
|
2012-08-09 16:03:55 +06:00
|
|
|
SMESHGUI_EXPORT
|
|
|
|
void RemoveVisualObjectWithActors( const char* theEntry, bool fromAllViews = false );
|
2005-06-07 19:22:20 +06:00
|
|
|
};
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2009-02-17 10:27:49 +05:00
|
|
|
#endif // SMESHGUI_VTKUTILS_H
|