diff --git a/src/AIS/AIS_InteractiveContext.cxx b/src/AIS/AIS_InteractiveContext.cxx index 85547fd57c..bc7c438cc8 100755 --- a/src/AIS/AIS_InteractiveContext.cxx +++ b/src/AIS/AIS_InteractiveContext.cxx @@ -149,6 +149,9 @@ myIsAutoActivateSelMode( Standard_True ) void AIS_InteractiveContext::Delete() const { + //Clear the static current selection. Else the memory + //is not release + AIS_Selection::ClearCurrentSelection(); #ifdef OCC172 // to avoid an exception if ( AIS_Selection::Find( mySelectionName.ToCString() ) ) diff --git a/src/AIS/AIS_Selection.cdl b/src/AIS/AIS_Selection.cdl index ae5fea78da..4dd866eb27 100755 --- a/src/AIS/AIS_Selection.cdl +++ b/src/AIS/AIS_Selection.cdl @@ -87,6 +87,8 @@ is ---Purpose: returns mutable Selection from AIS; + ClearCurrentSelection(myclass); + ---Purpose: Clears selection. Select(myclass); ---Purpose: removes all the object of the currentselection. diff --git a/src/AIS/AIS_Selection.cxx b/src/AIS/AIS_Selection.cxx index a9d4b02d19..754a6f57fa 100755 --- a/src/AIS/AIS_Selection.cxx +++ b/src/AIS/AIS_Selection.cxx @@ -50,9 +50,10 @@ #define MaxSizeOfResult 100000 #endif +//current selection (handle) +static Handle(AIS_Selection) theCurrentSelection; static void AIS_Sel_CurrentSelection (Handle(AIS_Selection)& InputSel) { - static Handle(AIS_Selection) theCurrentSelection; if(!InputSel.IsNull()) theCurrentSelection = InputSel; else @@ -418,6 +419,11 @@ void AIS_Selection::Remove(const Standard_CString aName) #endif AIS_Sel_GetSelections().Remove(I); } - +} + +// clean the static current selection handle +void AIS_Selection::ClearCurrentSelection() +{ + theCurrentSelection.Nullify(); } diff --git a/src/Visual3d/Visual3d_ViewManager.cxx b/src/Visual3d/Visual3d_ViewManager.cxx index 6ffaf78fcc..c3f0bfa10d 100755 --- a/src/Visual3d/Visual3d_ViewManager.cxx +++ b/src/Visual3d/Visual3d_ViewManager.cxx @@ -1061,6 +1061,19 @@ Standard_Integer Visual3d_ViewManager::Identification (const Handle(Visual3d_Vie void Visual3d_ViewManager::UnIdentification (const Standard_Integer aViewId) { + Visual3d_SetIteratorOfSetOfView MyIterator(MyDefinedView); + while (MyIterator.More()) + { + if ((MyIterator.Value())->Identification () == aViewId) + { + const Handle(Visual3d_View)& theView = MyIterator.Value(); + //remove the view from the list + MyDefinedView.Remove(theView); + break; + } + // go to next + MyIterator.Next (); + } MyViewGenId.Free(aViewId); }