mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0028927: Visualization - Graphic3d_StructureManager destructor should invalidate its pointer in Graphic3d_Structure
Graphic3d_Structure::myFirstStructureManager - removed unused class field. ~Graphic3d_StructureManager() now removes displayed Structures explicitly.
This commit is contained in:
parent
983fd6c02b
commit
b4fd9d00c2
@ -41,8 +41,7 @@ IMPLEMENT_STANDARD_RTTIEXT(Graphic3d_Structure,Standard_Transient)
|
||||
//purpose :
|
||||
//=============================================================================
|
||||
Graphic3d_Structure::Graphic3d_Structure (const Handle(Graphic3d_StructureManager)& theManager)
|
||||
: myStructureManager (theManager.operator->()),
|
||||
myFirstStructureManager (theManager.operator->()),
|
||||
: myStructureManager(theManager.operator->()),
|
||||
myComputeVisual (Graphic3d_TOS_ALL),
|
||||
myOwner (NULL),
|
||||
myVisual (Graphic3d_TOS_ALL)
|
||||
@ -56,8 +55,7 @@ Graphic3d_Structure::Graphic3d_Structure (const Handle(Graphic3d_StructureManage
|
||||
//=============================================================================
|
||||
Graphic3d_Structure::Graphic3d_Structure (const Handle(Graphic3d_StructureManager)& theManager,
|
||||
const Handle(Graphic3d_Structure)& thePrs)
|
||||
: myStructureManager (theManager.operator->()),
|
||||
myFirstStructureManager (theManager.operator->()),
|
||||
: myStructureManager(theManager.operator->()),
|
||||
myComputeVisual (thePrs->myComputeVisual),
|
||||
myOwner (thePrs->myOwner),
|
||||
myVisual (thePrs->myVisual)
|
||||
@ -71,9 +69,9 @@ Graphic3d_Structure::Graphic3d_Structure (const Handle(Graphic3d_StructureManage
|
||||
//=============================================================================
|
||||
Graphic3d_Structure::~Graphic3d_Structure()
|
||||
{
|
||||
// as myFirstStructureManager can be already destroyed,
|
||||
// as myStructureManager can be already destroyed,
|
||||
// avoid attempts to access it
|
||||
myFirstStructureManager = NULL;
|
||||
myStructureManager = NULL;
|
||||
Remove();
|
||||
}
|
||||
|
||||
|
@ -440,7 +440,6 @@ private:
|
||||
protected:
|
||||
|
||||
Graphic3d_StructureManager* myStructureManager;
|
||||
Graphic3d_StructureManager* myFirstStructureManager;
|
||||
Graphic3d_TypeOfStructure myComputeVisual;
|
||||
|
||||
Handle(Graphic3d_CStructure) myCStructure;
|
||||
|
@ -42,6 +42,11 @@ Graphic3d_StructureManager::Graphic3d_StructureManager (const Handle(Graphic3d_G
|
||||
// ========================================================================
|
||||
Graphic3d_StructureManager::~Graphic3d_StructureManager()
|
||||
{
|
||||
for (Graphic3d_MapIteratorOfMapOfStructure anIt (myDisplayedStructure); anIt.More(); anIt.Next())
|
||||
{
|
||||
anIt.Value()->Remove();
|
||||
}
|
||||
|
||||
myDisplayedStructure.Clear();
|
||||
myHighlightedStructure.Clear();
|
||||
myDefinedViews.Clear();
|
||||
@ -66,6 +71,10 @@ void Graphic3d_StructureManager::Update (const Graphic3d_ZLayerId theLayerId) co
|
||||
void Graphic3d_StructureManager::Remove()
|
||||
{
|
||||
// clear all structures whilst views are alive for correct GPU memory management
|
||||
for (Graphic3d_MapIteratorOfMapOfStructure anIt (myDisplayedStructure); anIt.More(); anIt.Next())
|
||||
{
|
||||
anIt.Value()->Remove();
|
||||
}
|
||||
myDisplayedStructure.Clear();
|
||||
myHighlightedStructure.Clear();
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user