From ab943560bd2d41e7b8fa81cb20a59a1a34b44b0e Mon Sep 17 00:00:00 2001 From: bugmaster <> Date: Thu, 28 Apr 2011 16:31:41 +0000 Subject: [PATCH] Merge OCC22357, OCC22199 and replacing french comments by englih one --- src/AIS/AIS_InteractiveContext_2.cxx | 37 +++++++++++----------------- src/AIS/AIS_LocalContext.cxx | 31 +++++++++++++---------- src/AIS/AIS_TexturedShape.cxx | 6 +++-- 3 files changed, 36 insertions(+), 38 deletions(-) diff --git a/src/AIS/AIS_InteractiveContext_2.cxx b/src/AIS/AIS_InteractiveContext_2.cxx index 0823bc05ec..b87b46a03a 100755 --- a/src/AIS/AIS_InteractiveContext_2.cxx +++ b/src/AIS/AIS_InteractiveContext_2.cxx @@ -20,8 +20,6 @@ #include #include - -static TColStd_ListIteratorOfListOfInteger ItL; //======================================================================= //function : OpenLocalContext //purpose : @@ -63,21 +61,13 @@ OpenLocalContext(const Standard_Boolean UseDisplayedObjects, UseDisplayedObjects, AllowShapeDecomposition, AcceptEraseOfTemporary); - - // rob 16/04/97 Problems of asynchronous orders - if(myLocalContexts.Extent()>0){ - const Select3D_Projector& Prj = myLocalContexts(untilnow)->MainSelector()->Projector(); - NewLocal->MainSelector()->Set(Prj); - } - else{ - const Select3D_Projector& Prj = myMainSel->Projector(); - NewLocal->MainSelector()->Set(Prj); - } - - NewLocal->MainSelector()->UpdateConversion(); - - myLocalContexts.Bind(myCurLocalIndex,NewLocal); + NewLocal->MainSelector()->Set ((myLocalContexts.Extent() > 0) + ? myLocalContexts (untilnow)->MainSelector()->Projector() + : myMainSel->Projector()); + NewLocal->MainSelector()->UpdateConversion(); + + myLocalContexts.Bind(myCurLocalIndex,NewLocal); #ifdef DEB cout<<"\tOpen Local Context No "<SelectionModes()); ItL.More(); ItL.Next()){ @@ -311,9 +301,9 @@ void AIS_InteractiveContext:: ActivatedModes(const Handle(AIS_InteractiveObject)& anIObj, TColStd_ListOfInteger& theList) const { + TColStd_ListIteratorOfListOfInteger ItL; if(!HasOpenedContext()){ if(myObjects.IsBound(anIObj)){ - //ItL is a static variable... for(ItL.Initialize(myObjects(anIObj)->SelectionModes()); ItL.More(); ItL.Next()) @@ -392,6 +382,7 @@ SubIntensityOn(const Handle(AIS_InteractiveObject)& anIObj, if(myObjects.IsBound(anIObj)){ const Handle(AIS_GlobalStatus)& STAT = myObjects(anIObj); STAT->SubIntensityOn(); + TColStd_ListIteratorOfListOfInteger ItL; for (ItL.Initialize(STAT->DisplayedModes());ItL.More();ItL.Next()) myMainPM->Color(anIObj,mySubIntensity,ItL.Value()); } @@ -445,6 +436,7 @@ SubIntensityOff(const Handle(AIS_InteractiveObject)& anIObj, if(myObjects.IsBound(anIObj)){ const Handle(AIS_GlobalStatus)& STAT = myObjects(anIObj); STAT->SubIntensityOff(); + TColStd_ListIteratorOfListOfInteger ItL; for (ItL.Initialize(STAT->DisplayedModes());ItL.More();ItL.Next()) myMainPM->Unhighlight(anIObj,ItL.Value()); if(STAT->IsHilighted()) @@ -488,11 +480,10 @@ void AIS_InteractiveContext::SubIntensityOn(const Standard_Boolean updateviewer) //======================================================================= void AIS_InteractiveContext::SubIntensityOff(const Standard_Boolean updateviewer) { - if(!HasOpenedContext()) return; - + AIS_DataMapIteratorOfDataMapOfIOStatus It (myObjects); - + TColStd_ListIteratorOfListOfInteger ItL; for(;It.More();It.Next()){ const Handle(AIS_GlobalStatus)& STAT = It.Value(); if(STAT->IsSubIntensityOn()) @@ -500,7 +491,7 @@ void AIS_InteractiveContext::SubIntensityOff(const Standard_Boolean updateviewer for(ItL.Initialize(STAT->DisplayedModes());ItL.More();ItL.Next()) myMainPM->Unhighlight(It.Key()); } - + if(updateviewer) myMainVwr->Update(); } @@ -876,7 +867,7 @@ void AIS_InteractiveContext::ResetOriginalState(const Standard_Boolean updatevie { Standard_Boolean upd_main(Standard_False),upd_col(Standard_False); TColStd_ListIteratorOfListOfInteger itl; - + for (AIS_DataMapIteratorOfDataMapOfIOStatus it(myObjects);it.More();it.Next()){ const Handle(AIS_InteractiveObject)& iobj = it.Key(); const Handle(AIS_GlobalStatus)& STAT = it.Value(); diff --git a/src/AIS/AIS_LocalContext.cxx b/src/AIS/AIS_LocalContext.cxx index 21c06ce5bb..1269634a78 100755 --- a/src/AIS/AIS_LocalContext.cxx +++ b/src/AIS/AIS_LocalContext.cxx @@ -463,6 +463,8 @@ Standard_Boolean AIS_LocalContext::Remove(const Handle(AIS_InteractiveObject)& a for(It.Initialize(Att->SelectionModes());It.More();It.Next()){ mySM->Deactivate(aSelectable,It.Value(),myMainVS); } +// pop : si je laisses cela plantes dans les elements de construction +// alors a toi de jouer ROB // RemoveSelected(aSelectable); if(IsSelected(aSelectable)) @@ -656,22 +658,25 @@ void AIS_LocalContext::RemoveFilter(const Handle(SelectMgr_Filter)& aFilter) -Standard_Boolean AIS_LocalContext::HasSameProjector(const Select3D_Projector& aPrj) const +Standard_Boolean AIS_LocalContext::HasSameProjector(const Handle(Select3D_Projector)& thePrj) const { - const Select3D_Projector& CurPrj = myMainVS->Projector(); - if(CurPrj.Perspective()!=aPrj.Perspective()) return Standard_False; - if(CurPrj.Perspective()) - if(CurPrj.Focus()!=aPrj.Focus()) return Standard_False; - gp_GTrsf CurTrsf(CurPrj.Transformation()); - gp_GTrsf PrjTrsf(aPrj.Transformation()); - - for(Standard_Integer i=1;i<=3;i++){ - for(Standard_Integer j=1;j<=3;j++){ - if(CurTrsf.Value(i,j)!=PrjTrsf.Value(i,j)) - return Standard_False; + const Handle(Select3D_Projector)& aCurPrj = myMainVS->Projector(); + if (aCurPrj->Perspective() != thePrj->Perspective()) + return Standard_False; + if (aCurPrj->Perspective() && aCurPrj->Focus() != thePrj->Focus()) + return Standard_False; + const gp_GTrsf& aCurTrsf = aCurPrj->Transformation(); + const gp_GTrsf& aPrjTrsf = thePrj->Transformation(); + + for (Standard_Integer i = 1; i <= 3; ++i) + { + for (Standard_Integer j = 1; j <= 3 ; ++j) + { + if (aCurTrsf.Value (i, j) != aPrjTrsf.Value (i, j)) + return Standard_False; } } - + return Standard_True; } diff --git a/src/AIS/AIS_TexturedShape.cxx b/src/AIS/AIS_TexturedShape.cxx index eff32ca614..11a9f42998 100755 --- a/src/AIS/AIS_TexturedShape.cxx +++ b/src/AIS/AIS_TexturedShape.cxx @@ -342,8 +342,10 @@ void AIS_TexturedShape::Compute(const Handle(PrsMgr_PresentationManager3d)& /*aP BRepTools::Update(myshape); Handle(Graphic3d_StructureManager) aStrucMana = GetContext()->MainPrsMgr()->StructureManager(); - - myAspect = (new Prs3d_ShadingAspect())->Aspect(); + { + Handle(Prs3d_ShadingAspect) aPrs3d_ShadingAspect = new Prs3d_ShadingAspect; + myAspect = aPrs3d_ShadingAspect->Aspect(); + } if (!DoMapTexture) { myAspect->SetTextureMapOff();