From bf3977c9f92be2172130cec3b9885dad60dd559d Mon Sep 17 00:00:00 2001 From: abv Date: Thu, 7 May 2015 08:53:38 +0300 Subject: [PATCH] 0026146: Visualization, Select3D_ISensitivePointSet - eliminate crash when clearing selections [only with TBB] Remove classes Select3D_ISensitivePointSet and Select3D_BoundarySensitivePointSet; use Select3D_SensitivePoly directly for boundary selection. Make last argument in Select3D_SensitiveFace non-default to ensure that value is always explicitly specified by the caller. Inherit SelectMgr_FrustumBuilder from Standard_Transient to use normal Handle instead of NCollection_Handle. Add test case bugs/vis/bug26146. --- src/AIS/AIS_PlaneTrihedron.cxx | 2 - src/AIS/AIS_Trihedron.cxx | 1 - src/MeshVS/MeshVS_Mesh.cxx | 2 +- src/Select3D/FILES | 3 - src/Select3D/Select3D.cdl | 2 - .../Select3D_BoundarySensitivePointSet.cxx | 85 ------------------- .../Select3D_BoundarySensitivePointSet.hxx | 62 -------------- src/Select3D/Select3D_ISensitivePointSet.hxx | 70 --------------- .../Select3D_InteriorSensitivePointSet.cxx | 27 ++---- .../Select3D_InteriorSensitivePointSet.hxx | 16 ++-- src/Select3D/Select3D_SensitiveFace.cxx | 19 ++++- src/Select3D/Select3D_SensitiveFace.hxx | 18 ++-- src/SelectMgr/SelectMgr_BaseFrustum.cxx | 2 +- src/SelectMgr/SelectMgr_BaseFrustum.hxx | 15 ++-- src/SelectMgr/SelectMgr_Frustum.hxx | 1 - src/SelectMgr/SelectMgr_FrustumBuilder.cxx | 3 + src/SelectMgr/SelectMgr_FrustumBuilder.hxx | 11 ++- tests/bugs/vis/bug26146 | 12 +++ 18 files changed, 64 insertions(+), 287 deletions(-) delete mode 100644 src/Select3D/Select3D_BoundarySensitivePointSet.cxx delete mode 100644 src/Select3D/Select3D_BoundarySensitivePointSet.hxx delete mode 100644 src/Select3D/Select3D_ISensitivePointSet.hxx create mode 100644 tests/bugs/vis/bug26146 diff --git a/src/AIS/AIS_PlaneTrihedron.cxx b/src/AIS/AIS_PlaneTrihedron.cxx index b9b57955f7..7ea3d8a131 100644 --- a/src/AIS/AIS_PlaneTrihedron.cxx +++ b/src/AIS/AIS_PlaneTrihedron.cxx @@ -47,8 +47,6 @@ #include #include -#include - void ExtremityPoints(TColgp_Array1OfPnt& PP,const Handle(Geom_Plane)& myPlane,const Handle(Prs3d_Drawer)& myDrawer); //======================================================================= diff --git a/src/AIS/AIS_Trihedron.cxx b/src/AIS/AIS_Trihedron.cxx index 52f5630b3c..aa75b760a7 100644 --- a/src/AIS/AIS_Trihedron.cxx +++ b/src/AIS/AIS_Trihedron.cxx @@ -19,7 +19,6 @@ #include #include #include -#include #include #include #include diff --git a/src/MeshVS/MeshVS_Mesh.cxx b/src/MeshVS/MeshVS_Mesh.cxx index 883fb47eab..315d2b911b 100644 --- a/src/MeshVS/MeshVS_Mesh.cxx +++ b/src/MeshVS/MeshVS_Mesh.cxx @@ -361,7 +361,7 @@ void MeshVS_Mesh::ComputeSelection ( const Handle(SelectMgr_Selection)& theSelec aSharedNodes.Add( aElemNodes( i ) ); } - anEnt = new Select3D_SensitiveFace( myWholeMeshOwner, Points ); + anEnt = new Select3D_SensitiveFace( myWholeMeshOwner, Points, Select3D_TOS_INTERIOR); theSelection->Add( anEnt ); } } diff --git a/src/Select3D/FILES b/src/Select3D/FILES index 9ca3ccf929..493377cb5a 100755 --- a/src/Select3D/FILES +++ b/src/Select3D/FILES @@ -1,14 +1,11 @@ Select3D_Pnt.hxx Select3D_Macro.hxx Select3D_PointData.hxx -Select3D_BoundarySensitivePointSet.hxx -Select3D_BoundarySensitivePointSet.cxx Select3D_BndBox3d.hxx Select3D_BVHPrimitiveContent.hxx Select3D_BVHPrimitiveContent.cxx Select3D_InteriorSensitivePointSet.hxx Select3D_InteriorSensitivePointSet.cxx -Select3D_ISensitivePointSet.hxx Select3D_EntitySequence.hxx Select3D_SensitiveBox.hxx Select3D_SensitiveBox.cxx diff --git a/src/Select3D/Select3D.cdl b/src/Select3D/Select3D.cdl index 981d712d9c..9527ac8818 100644 --- a/src/Select3D/Select3D.cdl +++ b/src/Select3D/Select3D.cdl @@ -44,10 +44,8 @@ uses is imported BndBox3d; - imported BoundarySensitivePointSet; imported BVHPrimitiveContent; imported InteriorSensitivePointSet; - imported ISensitivePointSet; imported EntitySequence; imported Pnt; imported PointData; diff --git a/src/Select3D/Select3D_BoundarySensitivePointSet.cxx b/src/Select3D/Select3D_BoundarySensitivePointSet.cxx deleted file mode 100644 index 8a5b6a232d..0000000000 --- a/src/Select3D/Select3D_BoundarySensitivePointSet.cxx +++ /dev/null @@ -1,85 +0,0 @@ -// Created on: 2014-11-10 -// Created by: Varvara POSKONINA -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -//======================================================================= -// function : Select3D_BoundarySensitivePointSet -// purpose : Creates new instance of Select3D_SensitivePoly with BVH tree -// required and initializes it with the given array of points -//======================================================================= -Select3D_BoundarySensitivePointSet::Select3D_BoundarySensitivePointSet (const Handle(SelectBasics_EntityOwner)& OwnerId, - const TColgp_Array1OfPnt& ThePoints) - : Select3D_SensitivePoly (OwnerId, ThePoints, Standard_True) -{} - -//======================================================================= -// function : Matches -// purpose : Checks whether the point set overlaps current selecting -// volume -//======================================================================= -Standard_Boolean Select3D_BoundarySensitivePointSet::Matches (SelectBasics_SelectingVolumeManager& theMgr, - SelectBasics_PickResult& thePickResult) -{ - return Select3D_SensitivePoly::Matches (theMgr, thePickResult); -} - -//======================================================================= -// function : GetPoints -// purpose : Initializes the given array theHArrayOfPnt by 3d -// coordinates of vertices of the point set -//======================================================================= -void Select3D_BoundarySensitivePointSet::GetPoints (Handle(TColgp_HArray1OfPnt)& theHArrayOfPnt) -{ - Points3D (theHArrayOfPnt); -} - -//======================================================================= -// function : BoundingBox -// purpose : Returns bounding box of the point set. If location transformation -// is set, it will be applied -//======================================================================= -Select3D_BndBox3d Select3D_BoundarySensitivePointSet::BoundingBox() -{ - return Select3D_SensitivePoly::BoundingBox(); -} - -//======================================================================= -// function : CenterOfGeometry -// purpose : Returns center of the point set. If location transformation -// is set, it will be applied -//======================================================================= -gp_Pnt Select3D_BoundarySensitivePointSet::CenterOfGeometry() const -{ - return Select3D_SensitivePoly::CenterOfGeometry(); -} - -//======================================================================= -// function : BVH -// purpose : Builds BVH tree for the point set -//======================================================================= -void Select3D_BoundarySensitivePointSet::BVH() -{ - Select3D_SensitivePoly::BVH(); -} - -//======================================================================= -// function : NbSubElements -// purpose : Returns the amount of points in set -//======================================================================= -Standard_Integer Select3D_BoundarySensitivePointSet::NbSubElements() -{ - return Select3D_SensitivePoly::NbSubElements(); -} diff --git a/src/Select3D/Select3D_BoundarySensitivePointSet.hxx b/src/Select3D/Select3D_BoundarySensitivePointSet.hxx deleted file mode 100644 index 12188110e8..0000000000 --- a/src/Select3D/Select3D_BoundarySensitivePointSet.hxx +++ /dev/null @@ -1,62 +0,0 @@ -// Created on: 2014-08-15 -// Created by: Varvara POSKONINA -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Select3D_BoundarySensitivePointSet_HeaderFile -#define _Select3D_BoundarySensitivePointSet_HeaderFile - -#include -#include - -#include -#include - -class SelectBasics_EntityOwner; -class TColgp_Array1OfPnt; -class TColgp_HArray1OfPnt; - -//! This class handles the selection of arbitrary point set with boundary type of sensitivity. -class Select3D_BoundarySensitivePointSet : public Select3D_ISensitivePointSet, public Select3D_SensitivePoly -{ -public: - - //! Creates new instance of Select3D_SensitivePoly with BVH tree - //! required and initializes it with the given array of points - Standard_EXPORT Select3D_BoundarySensitivePointSet (const Handle(SelectBasics_EntityOwner)& OwnerId, - const TColgp_Array1OfPnt& ThePoints); - - //! Checks whether the point set overlaps current selecting volume - Standard_EXPORT virtual Standard_Boolean Matches (SelectBasics_SelectingVolumeManager& theMgr, - SelectBasics_PickResult& thePickResult) Standard_OVERRIDE; - - //! Initializes the given array theHArrayOfPnt by 3d coordinates - //! of vertices of the point set - Standard_EXPORT virtual void GetPoints (Handle(TColgp_HArray1OfPnt)& theHArrayOfPnt) Standard_OVERRIDE; - - //! Returns bounding box of the point set. If there is a - //! location transformation set, it will be applied - Standard_EXPORT virtual Select3D_BndBox3d BoundingBox() Standard_OVERRIDE; - - //! Returns center of the point set. If there is a - //! location transformation set, it will be applied - Standard_EXPORT virtual gp_Pnt CenterOfGeometry() const Standard_OVERRIDE; - - //! Builds BVH tree for the point set - Standard_EXPORT virtual void BVH() Standard_OVERRIDE; - - //! Returns the amount of points in set - Standard_EXPORT virtual Standard_Integer NbSubElements() Standard_OVERRIDE; -}; - -#endif // _Select3D_BoundarySensitivePointSet_HeaderFile diff --git a/src/Select3D/Select3D_ISensitivePointSet.hxx b/src/Select3D/Select3D_ISensitivePointSet.hxx deleted file mode 100644 index 7cb05642f1..0000000000 --- a/src/Select3D/Select3D_ISensitivePointSet.hxx +++ /dev/null @@ -1,70 +0,0 @@ -// Created on: 2014-08-15 -// Created by: Varvara POSKONINA -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Select3D_ISensitivePointSet_HeaderFile -#define _Select3D_ISensitivePointSet_HeaderFile - -#include -#include -#include -#include - -#include -#include -#include -#include -#include - -#include -#include - -class gp_Pnt; -class Standard_ConstructionError; -class Standard_OutOfRange; -class TColgp_Array1OfPnt; -class TColgp_HArray1OfPnt; -class TColgp_Array1OfPnt2d; -class TopLoc_Location; - -//! Interface class to unify the work with both internal and boundary -//! sensitive sets of points. -class Select3D_ISensitivePointSet -{ -public: - - //! Checks whether the point set overlaps current selecting volume - virtual Standard_Boolean Matches (SelectBasics_SelectingVolumeManager& theMgr, - SelectBasics_PickResult& thePickResult) = 0; - - //! Initializes the given array theHArrayOfPnt by 3d coordinates - //! of vertices of the point set - virtual void GetPoints (Handle(TColgp_HArray1OfPnt)& theHArrayOfPnt) = 0; - - //! Returns bounding box of the point set. If location - //! transformation is set, it will be applied - virtual Select3D_BndBox3d BoundingBox() = 0; - - //! Returns center of the point set. If location - //! transformation is set, it will be applied - virtual gp_Pnt CenterOfGeometry() const = 0; - - //! Builds BVH tree for the point set - virtual void BVH() = 0; - - //! Returns the amount of points in set - virtual Standard_Integer NbSubElements() = 0; -}; - -#endif // _Select3D_ISensitivePointSet_HeaderFile diff --git a/src/Select3D/Select3D_InteriorSensitivePointSet.cxx b/src/Select3D/Select3D_InteriorSensitivePointSet.cxx index b86c23cac8..b2e8dd4deb 100644 --- a/src/Select3D/Select3D_InteriorSensitivePointSet.cxx +++ b/src/Select3D/Select3D_InteriorSensitivePointSet.cxx @@ -21,6 +21,8 @@ #include +namespace { + // Internal class for creation of planar polygons class Select3D_Plane { @@ -74,6 +76,11 @@ private: Standard_Boolean myIsInitialized; }; +} // anonymous namespace + +IMPLEMENT_STANDARD_HANDLE (Select3D_InteriorSensitivePointSet, Select3D_SensitiveSet) +IMPLEMENT_STANDARD_RTTIEXT(Select3D_InteriorSensitivePointSet, Select3D_SensitiveSet) + // ======================================================================= // function : Select3D_InteriorSensitivePointSet // purpose : Splits the given point set thePoints onto planar convex @@ -171,17 +178,6 @@ Select3D_InteriorSensitivePointSet::Select3D_InteriorSensitivePointSet (const Ha } } -// ======================================================================= -// function : Matches -// purpose : Checks whether the point set overlaps current selecting -// volume -// ======================================================================= -Standard_Boolean Select3D_InteriorSensitivePointSet::Matches (SelectBasics_SelectingVolumeManager& theMgr, - SelectBasics_PickResult& thePickResult) -{ - return Select3D_SensitiveSet::Matches (theMgr, thePickResult); -} - // ======================================================================= // function : GetPoints // purpose : Initializes the given array theHArrayOfPnt by 3d @@ -320,15 +316,6 @@ gp_Pnt Select3D_InteriorSensitivePointSet::CenterOfGeometry() const return myCOG; } -//======================================================================= -// function : BVH -// purpose : Builds BVH tree for the point set -//======================================================================= -void Select3D_InteriorSensitivePointSet::BVH() -{ - BVH(); -} - //======================================================================= // function : NbSubElements // purpose : Returns the amount of points in set diff --git a/src/Select3D/Select3D_InteriorSensitivePointSet.hxx b/src/Select3D/Select3D_InteriorSensitivePointSet.hxx index b9fd3e878c..054e487902 100644 --- a/src/Select3D/Select3D_InteriorSensitivePointSet.hxx +++ b/src/Select3D/Select3D_InteriorSensitivePointSet.hxx @@ -22,7 +22,6 @@ #include #include -#include #include #include @@ -37,7 +36,7 @@ typedef NCollection_Vector Select3D_VectorOfHPol //! This class handles the selection of arbitrary point set with internal type of sensitivity. //! The main principle is to split the point set given onto planar convex polygons and search //! for the overlap with one or more of them through traverse of BVH tree. -class Select3D_InteriorSensitivePointSet : public Select3D_ISensitivePointSet, public Select3D_SensitiveSet +class Select3D_InteriorSensitivePointSet : public Select3D_SensitiveSet { public: @@ -45,13 +44,9 @@ public: Standard_EXPORT Select3D_InteriorSensitivePointSet (const Handle(SelectBasics_EntityOwner)& theOwnerId, const TColgp_Array1OfPnt& thePoints); - //! Checks whether the point set overlaps current selecting volume - Standard_EXPORT virtual Standard_Boolean Matches (SelectBasics_SelectingVolumeManager& theMgr, - SelectBasics_PickResult& thePickResult) Standard_OVERRIDE; - //! Initializes the given array theHArrayOfPnt by 3d coordinates of vertices of the //! whole point set - Standard_EXPORT virtual void GetPoints (Handle(TColgp_HArray1OfPnt)& theHArrayOfPnt) Standard_OVERRIDE; + Standard_EXPORT virtual void GetPoints (Handle(TColgp_HArray1OfPnt)& theHArrayOfPnt); //! Returns the length of vector of planar convex polygons Standard_EXPORT virtual Standard_Integer Size() const Standard_OVERRIDE; @@ -76,12 +71,11 @@ public: //! transformation is set, it will be applied Standard_EXPORT virtual gp_Pnt CenterOfGeometry() const Standard_OVERRIDE; - //! Builds BVH tree for the point set - Standard_EXPORT virtual void BVH() Standard_OVERRIDE; - //! Returns the amount of points in set Standard_EXPORT virtual Standard_Integer NbSubElements() Standard_OVERRIDE; + DEFINE_STANDARD_RTTI(Select3D_InteriorSensitivePointSet) + protected: //! Checks whether the planar convex polygon with index theIdx @@ -106,4 +100,6 @@ protected: Select3D_BndBox3d myBndBox; //!< Bounding box of the point set }; +DEFINE_STANDARD_HANDLE(Select3D_InteriorSensitivePointSet, Select3D_SensitiveSet) + #endif // _Select3D_InteriorSensitivePointSet_HeaderFile diff --git a/src/Select3D/Select3D_SensitiveFace.cxx b/src/Select3D/Select3D_SensitiveFace.cxx index 630f6d1c07..5fe5d00c25 100644 --- a/src/Select3D/Select3D_SensitiveFace.cxx +++ b/src/Select3D/Select3D_SensitiveFace.cxx @@ -19,6 +19,9 @@ //Modif on jul-21-97 : changement en harray1 pour eventuelles connexions ... #include +#include +#include + #include #include @@ -41,7 +44,7 @@ Select3D_SensitiveFace::Select3D_SensitiveFace (const Handle(SelectBasics_Entity } else { - myFacePoints = new Select3D_BoundarySensitivePointSet (theOwnerId, thePoints); + myFacePoints = new Select3D_SensitivePoly (theOwnerId, thePoints, Standard_True); } } @@ -61,7 +64,7 @@ Select3D_SensitiveFace::Select3D_SensitiveFace (const Handle(SelectBasics_Entity } else { - myFacePoints = new Select3D_BoundarySensitivePointSet (theOwnerId, thePoints->Array1()); + myFacePoints = new Select3D_SensitivePoly (theOwnerId, thePoints->Array1(), Standard_True); } } @@ -72,7 +75,15 @@ Select3D_SensitiveFace::Select3D_SensitiveFace (const Handle(SelectBasics_Entity //======================================================================= void Select3D_SensitiveFace::GetPoints (Handle(TColgp_HArray1OfPnt)& theHArrayOfPnt) { - myFacePoints->GetPoints (theHArrayOfPnt); + if (myFacePoints->IsKind(STANDARD_TYPE(Select3D_SensitivePoly))) + { + Handle(Select3D_SensitivePoly)::DownCast (myFacePoints)->Points3D (theHArrayOfPnt); + } + else + { + Handle(Select3D_InteriorSensitivePointSet)::DownCast (myFacePoints)->GetPoints (theHArrayOfPnt); + } + } //======================================================================= @@ -102,7 +113,7 @@ Handle(Select3D_SensitiveEntity) Select3D_SensitiveFace::GetConnected() { // Create a copy of this Handle(TColgp_HArray1OfPnt) aPoints; - myFacePoints->GetPoints (aPoints); + GetPoints (aPoints); Handle(Select3D_SensitiveEntity) aNewEntity = new Select3D_SensitiveFace (myOwnerId, aPoints, mySensType); diff --git a/src/Select3D/Select3D_SensitiveFace.hxx b/src/Select3D/Select3D_SensitiveFace.hxx index 82e08caa0d..9d72a2d1c6 100644 --- a/src/Select3D/Select3D_SensitiveFace.hxx +++ b/src/Select3D/Select3D_SensitiveFace.hxx @@ -21,14 +21,10 @@ #ifndef _Select3D_SensitiveFace_HeaderFile #define _Select3D_SensitiveFace_HeaderFile -#include - -#include #include -#include #include -#include +#include #include #include #include @@ -36,10 +32,6 @@ #include #include -#include -#include -#include - class Standard_ConstructionError; class Standard_OutOfRange; class SelectBasics_EntityOwner; @@ -61,7 +53,7 @@ public: //! The array of points is the outer polygon of the geometric face. Standard_EXPORT Select3D_SensitiveFace (const Handle(SelectBasics_EntityOwner)& theOwnerId, const TColgp_Array1OfPnt& thePoints, - const Select3D_TypeOfSensitivity theType = Select3D_TOS_INTERIOR); + const Select3D_TypeOfSensitivity theType); //! Constructs a sensitive face object defined by the //! owner theOwnerId, the array of points thePoints, and @@ -69,7 +61,7 @@ public: //! The array of points is the outer polygon of the geometric face. Standard_EXPORT Select3D_SensitiveFace (const Handle(SelectBasics_EntityOwner)& theOwnerId, const Handle(TColgp_HArray1OfPnt)& thePoints, - const Select3D_TypeOfSensitivity theType = Select3D_TOS_INTERIOR); + const Select3D_TypeOfSensitivity theType); //! Initializes the given array theHArrayOfPnt by 3d //! coordinates of vertices of the face @@ -99,8 +91,8 @@ public: private: - Select3D_TypeOfSensitivity mySensType; //!< Type of sensitivity: interior or boundary - NCollection_Handle myFacePoints; //!< Wrapper for overlap detection created depending on sensitivity type + Select3D_TypeOfSensitivity mySensType; //!< Type of sensitivity: interior or boundary + Handle(Select3D_SensitiveSet) myFacePoints; //!< Wrapper for overlap detection created depending on sensitivity type }; DEFINE_STANDARD_HANDLE(Select3D_SensitiveFace, Select3D_SensitiveEntity) diff --git a/src/SelectMgr/SelectMgr_BaseFrustum.cxx b/src/SelectMgr/SelectMgr_BaseFrustum.cxx index 858b24ac2d..62d6de3de9 100644 --- a/src/SelectMgr/SelectMgr_BaseFrustum.cxx +++ b/src/SelectMgr/SelectMgr_BaseFrustum.cxx @@ -86,7 +86,7 @@ void SelectMgr_BaseFrustum::SetWindowSize (const Standard_Integer theWidth, cons // function : SetBuilder // purpose : //======================================================================= -void SelectMgr_BaseFrustum::SetBuilder (const NCollection_Handle& theBuilder) +void SelectMgr_BaseFrustum::SetBuilder (const Handle(SelectMgr_FrustumBuilder)& theBuilder) { myBuilder.Nullify(); myBuilder = theBuilder; diff --git a/src/SelectMgr/SelectMgr_BaseFrustum.hxx b/src/SelectMgr/SelectMgr_BaseFrustum.hxx index 0aa9c18ba4..0efa02be3b 100644 --- a/src/SelectMgr/SelectMgr_BaseFrustum.hxx +++ b/src/SelectMgr/SelectMgr_BaseFrustum.hxx @@ -25,7 +25,6 @@ #include #include -#include #include #include @@ -47,7 +46,7 @@ public: //! orthographic camera and empty frustum builder SelectMgr_BaseFrustum(); - virtual ~SelectMgr_BaseFrustum() {}; + virtual ~SelectMgr_BaseFrustum() {} //! Passes camera projection and orientation matrices to builder void SetCamera (const Handle(Graphic3d_Camera)& theCamera); @@ -68,23 +67,23 @@ public: const Standard_Real theHeight); //! Nullifies the builder created in the constructor and copies the pointer given - void SetBuilder (const NCollection_Handle& theBuilder); + void SetBuilder (const Handle(SelectMgr_FrustumBuilder)& theBuilder); //! Builds volume according to the point and given pixel tolerance - virtual void Build (const gp_Pnt2d& /*thePoint*/) {}; + virtual void Build (const gp_Pnt2d& /*thePoint*/) {} //! Builds volume according to the selected rectangle virtual void Build (const gp_Pnt2d& /*theMinPt*/, - const gp_Pnt2d& /*theMaxPt*/) {}; + const gp_Pnt2d& /*theMaxPt*/) {} //! Builds volume according to the triangle given virtual void Build (const gp_Pnt2d& /*theP1*/, const gp_Pnt2d& /*theP2*/, - const gp_Pnt2d& /*theP3*/) {}; + const gp_Pnt2d& /*theP3*/) {} //! Builds selecting volumes set according to polyline points - virtual void Build (const TColgp_Array1OfPnt2d& /*thePoints*/) {}; + virtual void Build (const TColgp_Array1OfPnt2d& /*thePoints*/) {} virtual NCollection_Handle Transform (const gp_Trsf& /*theTrsf*/) { return NULL; } @@ -142,7 +141,7 @@ protected: Standard_Real myPixelTolerance; //!< Pixel tolerance Standard_Boolean myIsOrthographic; //!< Defines if current camera is orthographic - NCollection_Handle myBuilder; //!< A tool implementing methods for volume build + Handle(SelectMgr_FrustumBuilder) myBuilder; //!< A tool implementing methods for volume build }; #endif // _SelectMgr_BaseFrustum_HeaderFile diff --git a/src/SelectMgr/SelectMgr_Frustum.hxx b/src/SelectMgr/SelectMgr_Frustum.hxx index 1ba4a35adb..e5f9e1c8f2 100644 --- a/src/SelectMgr/SelectMgr_Frustum.hxx +++ b/src/SelectMgr/SelectMgr_Frustum.hxx @@ -19,7 +19,6 @@ #include #include #include -#include #include #include diff --git a/src/SelectMgr/SelectMgr_FrustumBuilder.cxx b/src/SelectMgr/SelectMgr_FrustumBuilder.cxx index 904bbd90a8..91be420ac2 100644 --- a/src/SelectMgr/SelectMgr_FrustumBuilder.cxx +++ b/src/SelectMgr/SelectMgr_FrustumBuilder.cxx @@ -18,6 +18,9 @@ #define DOT(A, B) (A.x() * B.x() + A.y() * B.y() + A.z() * B.z()) #define LENGTH(A) (std::sqrt (A.x() * A.x() + A.y() * A.y() + A.z() * A.z())) +IMPLEMENT_STANDARD_HANDLE (SelectMgr_FrustumBuilder, Standard_Transient) +IMPLEMENT_STANDARD_RTTIEXT(SelectMgr_FrustumBuilder, Standard_Transient) + //======================================================================= // function : SelectMgr_FrustumBuilder // purpose : Creates new frustum builder with empty matrices diff --git a/src/SelectMgr/SelectMgr_FrustumBuilder.hxx b/src/SelectMgr/SelectMgr_FrustumBuilder.hxx index 1d4cd80574..8480454cea 100644 --- a/src/SelectMgr/SelectMgr_FrustumBuilder.hxx +++ b/src/SelectMgr/SelectMgr_FrustumBuilder.hxx @@ -16,22 +16,21 @@ #ifndef _SelectMgr_FrustumBuilder_HeaderFile #define _SelectMgr_FrustumBuilder_HeaderFile +#include + #include -#include #include #include //! The purpose of this class is to provide unified interface for building //! selecting frustum depending on current camera projection and orientation //! matrices, window size and viewport parameters. -class SelectMgr_FrustumBuilder +class SelectMgr_FrustumBuilder : public Standard_Transient { public: //! Creates new frustum builder with empty matrices SelectMgr_FrustumBuilder(); - ~SelectMgr_FrustumBuilder() {}; - //! Stores current orientation matrix void SetOrientation (const Graphic3d_Mat4d& theOrientation); @@ -62,6 +61,8 @@ public: const Standard_Real& theY, const Standard_Real& theZ) const; + DEFINE_STANDARD_RTTI(SelectMgr_FrustumBuilder) + private: //! Unprojects point from NDC coords to 3d world space @@ -77,4 +78,6 @@ private: Standard_Boolean myIsViewportSet; }; +DEFINE_STANDARD_HANDLE(SelectMgr_FrustumBuilder, Standard_Transient) + #endif // _SelectMgr_FrustumBuilder_HeaderFile diff --git a/tests/bugs/vis/bug26146 b/tests/bugs/vis/bug26146 new file mode 100644 index 0000000000..b9dd6bf05b --- /dev/null +++ b/tests/bugs/vis/bug26146 @@ -0,0 +1,12 @@ +puts "===========" +puts "Test for issue #26146" +puts "===========" +puts "==================================" +puts "Select3D_ISensitivePointSet: Crash when clearing selections (only with TBB)" +puts "==================================" + +restore [locate_data_file crash_compound.brep] + +vinit +vdisplay crash_compound +vremove crash_compound ;# crashed here