From 6a24c6ded983e9c29899ccb9454de8868a1c0c12 Mon Sep 17 00:00:00 2001 From: kgv Date: Sun, 25 Sep 2016 19:09:23 +0300 Subject: [PATCH] 0027900: Coding rules - drop redundant Name parameter from V3d_Viewer constructor Removed unused methods AIS_InteractiveContext::DomainOfMainViewer(), V3d_Viewer::NextName(), V3d_Viewer::Domain(). NCollection_List - added methods Contains() and Remove() taking item value. V3d_Viewer now uses V3d_ListOfLight, V3d_ListOfView instead of V3d_ListOfTransient. Removed obsolete ZFit workaround from command XShow. --- samples/CSharp/OCCTProxy/OCCTProxy.cpp | 7 +- samples/CSharp/OCCTProxy_D3D/OCCTProxyD3D.cpp | 7 +- samples/java/jniviewer/jni/OcctJni_Viewer.cxx | 5 +- .../mfc/occtdemo/Common/WNT/OCCDemoDoc.cpp | 2 +- .../standard/01_Geometry/src/GeometryDoc.cpp | 3 +- samples/mfc/standard/08_HLR/src/HLRDoc.cpp | 10 +- .../standard/08_HLR/src/SelectionDialog.cpp | 2 +- .../09_Animation/src/AnimationDoc.cpp | 7 +- .../10_Convert/src/WNT/OCCDemoDoc.cpp | 4 +- samples/mfc/standard/Common/OCC_2dDoc.cpp | 8 +- samples/mfc/standard/Common/OCC_3dBaseDoc.cpp | 2 +- samples/qt/AndroidQt/AndroidQt.cxx | 5 +- samples/qt/Common/src/DocumentCommon.cxx | 21 +- src/AIS/AIS_ColorScale.cxx | 2 +- src/AIS/AIS_InteractiveContext.cxx | 23 +- src/AIS/AIS_InteractiveContext.hxx | 4 - src/AIS/AIS_InteractiveContext_2.cxx | 9 +- src/AIS/AIS_LocalContext_1.cxx | 19 +- src/DDocStd/DDocStd_ApplicationCommands.cxx | 9 +- src/NCollection/NCollection_List.hxx | 27 + src/PrsMgr/PrsMgr_PresentationManager.cxx | 8 +- src/V3d/FILES | 5 +- src/V3d/V3d_ListOfLight.hxx | 24 + src/V3d/V3d_ListOfTransient.hxx | 52 -- src/V3d/V3d_ListOfView.hxx | 24 + src/V3d/V3d_View.cxx | 11 +- src/V3d/V3d_View.hxx | 19 +- src/V3d/V3d_View_2.cxx | 68 +-- src/V3d/V3d_Viewer.cxx | 448 ++++++-------- src/V3d/V3d_Viewer.hxx | 547 +++++++++--------- src/V3d/V3d_Viewer_1.cxx | 84 --- src/V3d/V3d_Viewer_2.cxx | 126 ---- src/V3d/V3d_Viewer_3.cxx | 7 +- src/V3d/V3d_Viewer_4.cxx | 16 +- src/ViewerTest/ViewerTest.cxx | 4 +- src/ViewerTest/ViewerTest_ViewerCommands.cxx | 23 +- src/XDEDRAW/XDEDRAW.cxx | 19 +- 37 files changed, 666 insertions(+), 995 deletions(-) create mode 100644 src/V3d/V3d_ListOfLight.hxx delete mode 100644 src/V3d/V3d_ListOfTransient.hxx create mode 100644 src/V3d/V3d_ListOfView.hxx delete mode 100644 src/V3d/V3d_Viewer_1.cxx delete mode 100644 src/V3d/V3d_Viewer_2.cxx diff --git a/samples/CSharp/OCCTProxy/OCCTProxy.cpp b/samples/CSharp/OCCTProxy/OCCTProxy.cpp index f9a18c5236..7f07556246 100644 --- a/samples/CSharp/OCCTProxy/OCCTProxy.cpp +++ b/samples/CSharp/OCCTProxy/OCCTProxy.cpp @@ -72,12 +72,7 @@ public: return false; } - TCollection_ExtendedString a3DName("Visu3D"); - myViewer() = new V3d_Viewer (myGraphicDriver(), a3DName.ToExtString(),"", 1000.0, - V3d_XposYnegZpos, Quantity_NOC_GRAY30, - V3d_ZBUFFER,V3d_GOURAUD,V3d_WAIT, - Standard_True, Standard_False); - + myViewer() = new V3d_Viewer (myGraphicDriver()); myViewer()->SetDefaultLights(); myViewer()->SetLightOn(); myView() = myViewer()->CreateView(); diff --git a/samples/CSharp/OCCTProxy_D3D/OCCTProxyD3D.cpp b/samples/CSharp/OCCTProxy_D3D/OCCTProxyD3D.cpp index 8dc71cfc7d..12fb7adcc6 100644 --- a/samples/CSharp/OCCTProxy_D3D/OCCTProxyD3D.cpp +++ b/samples/CSharp/OCCTProxy_D3D/OCCTProxyD3D.cpp @@ -78,12 +78,7 @@ public: myGraphicDriver()->ChangeOptions().buffersNoSwap = true; //myGraphicDriver()->ChangeOptions().contextDebug = true; - TCollection_ExtendedString a3DName ("Visu3D"); - myViewer() = new V3d_Viewer (myGraphicDriver(), a3DName.ToExtString(), "", 1000.0, - V3d_XposYnegZpos, Quantity_NOC_GRAY30, - V3d_ZBUFFER, V3d_GOURAUD, V3d_WAIT, - Standard_True, Standard_False); - + myViewer() = new V3d_Viewer (myGraphicDriver()); myViewer()->SetDefaultLights(); myViewer()->SetLightOn(); myView() = myViewer()->CreateView(); diff --git a/samples/java/jniviewer/jni/OcctJni_Viewer.cxx b/samples/java/jniviewer/jni/OcctJni_Viewer.cxx index e1937b25e6..5dd6c0483a 100644 --- a/samples/java/jniviewer/jni/OcctJni_Viewer.cxx +++ b/samples/java/jniviewer/jni/OcctJni_Viewer.cxx @@ -194,9 +194,8 @@ bool OcctJni_Viewer::init() } // create viewer - myViewer = new V3d_Viewer (aDriver, TCollection_ExtendedString("Viewer").ToExtString(), "", 1000.0, - V3d_XposYnegZpos, Quantity_NOC_BLACK, V3d_ZBUFFER, V3d_GOURAUD, V3d_WAIT, - Standard_True, Standard_False); + myViewer = new V3d_Viewer (aDriver); + myViewer->SetDefaultBackgroundColor (Quantity_NOC_BLACK); myViewer->SetDefaultLights(); myViewer->SetLightOn(); diff --git a/samples/mfc/occtdemo/Common/WNT/OCCDemoDoc.cpp b/samples/mfc/occtdemo/Common/WNT/OCCDemoDoc.cpp index 31efa40129..3cc7d72815 100755 --- a/samples/mfc/occtdemo/Common/WNT/OCCDemoDoc.cpp +++ b/samples/mfc/occtdemo/Common/WNT/OCCDemoDoc.cpp @@ -46,7 +46,7 @@ COCCDemoDoc::COCCDemoDoc() Handle(Graphic3d_WNTGraphicDevice) theGraphicDevice = ((COCCDemoApp*)AfxGetApp())->GetGraphicDevice(); - myViewer = new V3d_Viewer(theGraphicDevice,(Standard_ExtString )"Visu3D"); + myViewer = new V3d_Viewer(theGraphicDevice); myViewer->SetDefaultLights(); myViewer->SetLightOn(); myViewer->SetDefaultBackgroundColor(Quantity_TOC_RGB, 0.,0.,0.); diff --git a/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp b/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp index 8d4514d9a9..bab3bb1ab5 100755 --- a/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp +++ b/samples/mfc/standard/01_Geometry/src/GeometryDoc.cpp @@ -148,8 +148,7 @@ CGeometryDoc::CGeometryDoc() myAISContext->DefaultDrawer()->VIsoAspect()->SetNumber(11); Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((OCC_App*)AfxGetApp())->GetGraphicDriver(); - TCollection_ExtendedString a2DName("Visu2D"); - myViewer2D = new V3d_Viewer(aGraphicDriver,a2DName.ToExtString()); + myViewer2D = new V3d_Viewer (aGraphicDriver); myViewer2D->SetCircularGridValues(0,0,1,8,0); myViewer2D->SetRectangularGridValues(0,0,1,1,0); diff --git a/samples/mfc/standard/08_HLR/src/HLRDoc.cpp b/samples/mfc/standard/08_HLR/src/HLRDoc.cpp index 3544beeb61..3a8f553401 100755 --- a/samples/mfc/standard/08_HLR/src/HLRDoc.cpp +++ b/samples/mfc/standard/08_HLR/src/HLRDoc.cpp @@ -49,20 +49,14 @@ CHLRDoc::CHLRDoc() ((CHLRApp*)AfxGetApp())->GetGraphicDriver(); // VIEWER 3D - TCollection_ExtendedString a3DName ("Visu3D"); - myViewer = new V3d_Viewer (theGraphicDriver, a3DName.ToExtString(), "", 1000.0, - V3d_XposYnegZpos, Quantity_NOC_GRAY30, - V3d_ZBUFFER, V3d_GOURAUD, V3d_WAIT, - Standard_True, Standard_False); - + myViewer = new V3d_Viewer (theGraphicDriver); myViewer->SetDefaultLights(); myViewer->SetLightOn(); myAISContext =new AIS_InteractiveContext (myViewer); // 2D VIEWER: exploit V3d viewer for 2D visualization - TCollection_ExtendedString a2DName ("Visu2D"); - my2DViewer = new V3d_Viewer (theGraphicDriver, a2DName.ToExtString()); + my2DViewer = new V3d_Viewer (theGraphicDriver); my2DViewer->SetCircularGridValues (0, 0, 10, 8, 0); my2DViewer->SetRectangularGridValues (0, 0, 10, 10, 0); diff --git a/samples/mfc/standard/08_HLR/src/SelectionDialog.cpp b/samples/mfc/standard/08_HLR/src/SelectionDialog.cpp index bbcb5fd108..a0a5a0982b 100644 --- a/samples/mfc/standard/08_HLR/src/SelectionDialog.cpp +++ b/samples/mfc/standard/08_HLR/src/SelectionDialog.cpp @@ -129,7 +129,7 @@ void CSelectionDialog::OnDisplay (bool isFit) Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((CHLRApp*)AfxGetApp())->GetGraphicDriver(); - myActiveViewer = new V3d_Viewer (aGraphicDriver, (Standard_ExtString )"Visu3D"); + myActiveViewer = new V3d_Viewer (aGraphicDriver); myActiveViewer->SetDefaultLights(); myActiveViewer->SetLightOn(); myActiveView = myActiveViewer->CreateView(); diff --git a/samples/mfc/standard/09_Animation/src/AnimationDoc.cpp b/samples/mfc/standard/09_Animation/src/AnimationDoc.cpp index 2f2e27805b..5381c7baf5 100755 --- a/samples/mfc/standard/09_Animation/src/AnimationDoc.cpp +++ b/samples/mfc/standard/09_Animation/src/AnimationDoc.cpp @@ -52,12 +52,7 @@ CAnimationDoc::CAnimationDoc() Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((CAnimationApp*)AfxGetApp())->GetGraphicDriver(); - TCollection_ExtendedString a3DName("Visu3D"); - myViewer = new V3d_Viewer(aGraphicDriver,a3DName.ToExtString(),"", 1000.0, - V3d_XposYnegZpos, Quantity_NOC_GRAY30, - V3d_ZBUFFER,V3d_GOURAUD,V3d_WAIT, - Standard_True, Standard_False); - + myViewer = new V3d_Viewer(aGraphicDriver); myViewer->SetDefaultLights(); myViewer->SetLightOn(); diff --git a/samples/mfc/standard/10_Convert/src/WNT/OCCDemoDoc.cpp b/samples/mfc/standard/10_Convert/src/WNT/OCCDemoDoc.cpp index 6f1b1fd448..4a22355cb4 100755 --- a/samples/mfc/standard/10_Convert/src/WNT/OCCDemoDoc.cpp +++ b/samples/mfc/standard/10_Convert/src/WNT/OCCDemoDoc.cpp @@ -46,10 +46,10 @@ COCCDemoDoc::COCCDemoDoc() Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((COCCDemoApp*)AfxGetApp())->GetGraphicDriver(); - myViewer = new V3d_Viewer(aGraphicDriver, (Standard_ExtString )"Visu3D"); + myViewer = new V3d_Viewer(aGraphicDriver); myViewer->SetDefaultLights(); myViewer->SetLightOn(); - myViewer->SetDefaultBackgroundColor(Quantity_TOC_RGB, 0.,0.,0.); + myViewer->SetDefaultBackgroundColor (Quantity_NOC_BLACK); myAISContext = new AIS_InteractiveContext(myViewer); myShowResult = FALSE; diff --git a/samples/mfc/standard/Common/OCC_2dDoc.cpp b/samples/mfc/standard/Common/OCC_2dDoc.cpp index d54ddae0f1..d6ae80c512 100755 --- a/samples/mfc/standard/Common/OCC_2dDoc.cpp +++ b/samples/mfc/standard/Common/OCC_2dDoc.cpp @@ -22,13 +22,7 @@ OCC_2dDoc::OCC_2dDoc() : OCC_BaseDoc() ((OCC_App*)AfxGetApp())->GetGraphicDriver(); // create the Viewer - TCollection_ExtendedString aName ("Viewer 2D"); - TCollection_AsciiString aDomain ("My Domain"); - - myViewer = new V3d_Viewer (aGraphicDriver, - aName.ToExtString(), - aDomain.ToCString()); - + myViewer = new V3d_Viewer (aGraphicDriver); myViewer->SetDefaultLights(); myViewer->SetLightOn(); myViewer->SetDefaultViewProj (V3d_Zpos); diff --git a/samples/mfc/standard/Common/OCC_3dBaseDoc.cpp b/samples/mfc/standard/Common/OCC_3dBaseDoc.cpp index fd8a98f3eb..9bcf11984e 100755 --- a/samples/mfc/standard/Common/OCC_3dBaseDoc.cpp +++ b/samples/mfc/standard/Common/OCC_3dBaseDoc.cpp @@ -67,7 +67,7 @@ OCC_3dBaseDoc::OCC_3dBaseDoc() Handle(Graphic3d_GraphicDriver) aGraphicDriver = ((OCC_App*)AfxGetApp())->GetGraphicDriver(); - myViewer = new V3d_Viewer (aGraphicDriver, Standard_ExtString("Visu3D") ); + myViewer = new V3d_Viewer (aGraphicDriver); myViewer->SetDefaultLights(); myViewer->SetLightOn(); myAISContext = new AIS_InteractiveContext (myViewer); diff --git a/samples/qt/AndroidQt/AndroidQt.cxx b/samples/qt/AndroidQt/AndroidQt.cxx index 927c6f01b1..016fc71b9a 100644 --- a/samples/qt/AndroidQt/AndroidQt.cxx +++ b/samples/qt/AndroidQt/AndroidQt.cxx @@ -261,9 +261,8 @@ bool AndroidQt::initViewer() } // create viewer - myViewer = new V3d_Viewer (aDriver, TCollection_ExtendedString("Viewer").ToExtString(), "", 1000.0, - V3d_XposYnegZpos, AndroidQt_UserInteractionParameters::BgColor.Name(), V3d_ZBUFFER, V3d_GOURAUD, V3d_WAIT, - Standard_True, Standard_False); + myViewer = new V3d_Viewer (aDriver); + myViewer->SetDefaultBackgroundColor (AndroidQt_UserInteractionParameters::BgColor.Name()); myViewer->SetDefaultLights(); myViewer->SetLightOn(); diff --git a/samples/qt/Common/src/DocumentCommon.cxx b/samples/qt/Common/src/DocumentCommon.cxx index 512d4bb4e0..871e087e73 100755 --- a/samples/qt/Common/src/DocumentCommon.cxx +++ b/samples/qt/Common/src/DocumentCommon.cxx @@ -19,8 +19,8 @@ // function : Viewer // purpose : // ======================================================================= -Handle(V3d_Viewer) DocumentCommon::Viewer (const Standard_ExtString theName, - const Standard_CString theDomain, +Handle(V3d_Viewer) DocumentCommon::Viewer (const Standard_ExtString , + const Standard_CString , const Standard_Real theViewSize, const V3d_TypeOfOrientation theViewProj, const Standard_Boolean theComputedMode, @@ -37,17 +37,12 @@ Handle(V3d_Viewer) DocumentCommon::Viewer (const Standard_ExtString theName, aGraphicDriver = new OpenGl_GraphicDriver (aDisplayConnection); } - return new V3d_Viewer (aGraphicDriver, - theName, - theDomain, - theViewSize, - theViewProj, - Quantity_NOC_GRAY30, - V3d_ZBUFFER, - V3d_GOURAUD, - V3d_WAIT, - theComputedMode, - theDefaultComputedMode); + Handle(V3d_Viewer) aViewer = new V3d_Viewer (aGraphicDriver); + aViewer->SetDefaultViewSize (theViewSize); + aViewer->SetDefaultViewProj (theViewProj); + aViewer->SetComputedMode (theComputedMode); + aViewer->SetDefaultComputedMode (theDefaultComputedMode); + return aViewer; } DocumentCommon::DocumentCommon( const int theIndex, ApplicationCommonWindow* app ) diff --git a/src/AIS/AIS_ColorScale.cxx b/src/AIS/AIS_ColorScale.cxx index 2a9767395d..c0c8b8a9fe 100644 --- a/src/AIS/AIS_ColorScale.cxx +++ b/src/AIS/AIS_ColorScale.cxx @@ -793,7 +793,7 @@ Standard_Integer AIS_ColorScale::TextHeight (const TCollection_ExtendedString& t //======================================================================= void AIS_ColorScale::TextSize (const TCollection_ExtendedString& theText, const Standard_Integer theHeight, Standard_Integer& theWidth, Standard_Integer& theAscent, Standard_Integer& theDescent) const { - const Handle(Graphic3d_CView)& aView = GetContext()->CurrentViewer()->ActiveView()->View(); + const Handle(Graphic3d_CView)& aView = GetContext()->CurrentViewer()->ActiveViewIterator().Value()->View(); Standard_ShortReal aWidth(10.0), anAscent(1.0), aDescent(1.0); TCollection_AsciiString aText (theText.ToExtString(), '?'); GetContext()->CurrentViewer()->Driver()->TextSize (aView, aText.ToCString(), (Standard_ShortReal)theHeight, aWidth, anAscent, aDescent); diff --git a/src/AIS/AIS_InteractiveContext.cxx b/src/AIS/AIS_InteractiveContext.cxx index 60404c11c6..fdcd290f44 100644 --- a/src/AIS/AIS_InteractiveContext.cxx +++ b/src/AIS/AIS_InteractiveContext.cxx @@ -135,18 +135,6 @@ void AIS_InteractiveContext::UpdateCurrentViewer() myMainVwr->Update(); } - -//======================================================================= -//function : DomainOfMainViewer -//purpose : -//======================================================================= - -Standard_CString AIS_InteractiveContext::DomainOfMainViewer() const -{ - return myMainVwr->Domain(); - -} - //======================================================================= //function : DisplayedObjects //purpose : @@ -2453,9 +2441,10 @@ void AIS_InteractiveContext::ClearGlobal (const Handle(AIS_InteractiveObject)& t myObjects.UnBind (theIObj); myMainVwr->StructureManager()->UnregisterObject (theIObj); - for (myMainVwr->InitDefinedViews(); myMainVwr->MoreDefinedViews(); myMainVwr->NextDefinedViews()) + + for (V3d_ListOfViewIterator aDefViewIter (myMainVwr->DefinedViewIterator()); aDefViewIter.More(); aDefViewIter.Next()) { - myMainVwr->DefinedView()->View()->ChangeHiddenObjects()->Remove (theIObj.get()); + aDefViewIter.Value()->View()->ChangeHiddenObjects()->Remove (theIObj.get()); } if (!myLastinMain.IsNull() && myLastinMain->Selectable() == theIObj) @@ -2944,9 +2933,9 @@ void AIS_InteractiveContext::SetTransformPersistence (const Handle(AIS_Interacti const Standard_Integer aLayerId = myObjects.Find (theObject)->GetLayerIndex(); const Handle(V3d_Viewer)& aCurViewer = CurrentViewer(); - for (aCurViewer->InitActiveViews(); aCurViewer->MoreActiveViews(); aCurViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (aCurViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - aCurViewer->ActiveView()->View()->InvalidateBVHData (aLayerId); - aCurViewer->ActiveView()->View()->InvalidateZLayerBoundingBox (aLayerId); + anActiveViewIter.Value()->View()->InvalidateBVHData (aLayerId); + anActiveViewIter.Value()->View()->InvalidateZLayerBoundingBox (aLayerId); } } diff --git a/src/AIS/AIS_InteractiveContext.hxx b/src/AIS/AIS_InteractiveContext.hxx index 5ea8735162..7840794ddd 100644 --- a/src/AIS/AIS_InteractiveContext.hxx +++ b/src/AIS/AIS_InteractiveContext.hxx @@ -1502,10 +1502,6 @@ public: //! Returns true if there is an open context. Standard_Boolean HasOpenedContext() const; - - //! Returns the domain name of the main viewer. - Standard_EXPORT Standard_CString DomainOfMainViewer() const; - //! This method is only intended for advanced operation, particularly with //! the aim to improve performance when many objects have to be selected diff --git a/src/AIS/AIS_InteractiveContext_2.cxx b/src/AIS/AIS_InteractiveContext_2.cxx index 442b39d323..f83461d332 100644 --- a/src/AIS/AIS_InteractiveContext_2.cxx +++ b/src/AIS/AIS_InteractiveContext_2.cxx @@ -758,14 +758,7 @@ Standard_Boolean AIS_InteractiveContext::EndImmediateDraw() return Standard_False; } - myMainVwr->InitActiveViews(); - if (!myMainVwr->MoreActiveViews()) - { - return Standard_False; - } - - Handle(V3d_View) aView = myMainVwr->ActiveView(); - return myLocalContexts (myCurLocalIndex)->EndImmediateDraw (aView->Viewer()); + return myLocalContexts (myCurLocalIndex)->EndImmediateDraw (myMainVwr); } diff --git a/src/AIS/AIS_LocalContext_1.cxx b/src/AIS/AIS_LocalContext_1.cxx index 5a866baacc..0fc721b2ed 100644 --- a/src/AIS/AIS_LocalContext_1.cxx +++ b/src/AIS/AIS_LocalContext_1.cxx @@ -184,9 +184,9 @@ AIS_StatusOfPick AIS_LocalContext::Select (const Standard_Boolean toUpdateViewer if (myAutoHilight) { const Handle(V3d_Viewer)& aViewer = myCTX->CurrentViewer(); - for (aViewer->InitActiveViews(); aViewer->MoreActiveViews(); aViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (aViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - Unhilight (anOwner, aViewer->ActiveView()); + Unhilight (anOwner, anActiveViewIter.Value()); } // advanced selection highlighting mechanism @@ -338,9 +338,9 @@ AIS_StatusOfPick AIS_LocalContext::ShiftSelect (const Standard_Boolean toUpdateV { myMainPM->ClearImmediateDraw(); const Handle(V3d_Viewer)& aViewer = myCTX->CurrentViewer(); - for (aViewer->InitActiveViews(); aViewer->MoreActiveViews(); aViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (aViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - Unhilight (anOwner, aViewer->ActiveView()); + Unhilight (anOwner, anActiveViewIter.Value()); } // advanced selection highlighting mechanism @@ -898,9 +898,9 @@ void AIS_LocalContext::ClearOutdatedSelection (const Handle(AIS_InteractiveObjec { aRemoveEntites.Append (anOwner); anOwner->SetSelected (Standard_False); - for (aViewer->InitActiveViews(); aViewer->MoreActiveViews(); aViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (aViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - Unhilight (anOwner, aViewer->ActiveView()); + Unhilight (anOwner, anActiveViewIter.Value()); } } } @@ -927,9 +927,9 @@ void AIS_LocalContext::ClearOutdatedSelection (const Handle(AIS_InteractiveObjec } else { - for (aViewer->InitActiveViews(); aViewer->MoreActiveViews(); aViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (aViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - Unhilight (anOwner, aViewer->ActiveView()); + Unhilight (anOwner, anActiveViewIter.Value()); } } } @@ -964,9 +964,8 @@ void AIS_LocalContext::ClearOutdatedSelection (const Handle(AIS_InteractiveObjec // Last detected owner was removed. First object from sequence become detected. // Pass any active view because in current implementation the highlighting is // synchronized in all view. - aViewer->InitActiveViews(); manageDetected (myMainVS->Picked (myDetectedSeq.First()), - aViewer->ActiveView(), + aViewer->ActiveViewIterator().Value(), Standard_False); } } diff --git a/src/DDocStd/DDocStd_ApplicationCommands.cxx b/src/DDocStd/DDocStd_ApplicationCommands.cxx index fe590e4fad..dce3786f98 100644 --- a/src/DDocStd/DDocStd_ApplicationCommands.cxx +++ b/src/DDocStd/DDocStd_ApplicationCommands.cxx @@ -329,9 +329,14 @@ static Standard_Integer DDocStd_Close (Draw_Interpretor& /*theDI*/, && !aDocViewer->GetInteractiveContext().IsNull()) { Handle(V3d_Viewer) aViewer = aDocViewer->GetInteractiveContext()->CurrentViewer(); - for (aViewer->InitDefinedViews(); aViewer->MoreDefinedViews(); aViewer->NextDefinedViews()) + V3d_ListOfView aViews; + for (V3d_ListOfViewIterator aViewIter (aDocViewer->GetInteractiveContext()->CurrentViewer()->DefinedViewIterator()); aViewIter.More(); aViewIter.Next()) { - Handle(V3d_View) aView = aViewer->DefinedView(); + aViews.Append (aViewIter.Value()); + } + for (V3d_ListOfViewIterator aViewIter (aViews); aViewIter.More(); aViewIter.Next()) + { + Handle(V3d_View) aView = aViewIter.Value(); ViewerTest::RemoveView (aView); } } diff --git a/src/NCollection/NCollection_List.hxx b/src/NCollection/NCollection_List.hxx index 39a4280d09..8719407879 100644 --- a/src/NCollection/NCollection_List.hxx +++ b/src/NCollection/NCollection_List.hxx @@ -199,6 +199,20 @@ public: PRemove (theIter, ListNode::delNode); } + //! Remove the first occurrence of the object. + Standard_Boolean Remove (const TheItemType& theObject) + { + for (Iterator anIter (*this); anIter.More(); anIter.Next()) + { + if (anIter.Value() == theObject) + { + Remove (anIter); + return Standard_True; + } + } + return Standard_False; + } + //! InsertBefore TheItemType& InsertBefore (const TheItemType& theItem, Iterator& theIter) @@ -270,6 +284,19 @@ public: void Reverse () { PReverse(); } + //! Return true if object is stored in the list. + Standard_Boolean Contains (const TheItemType& theObject) const + { + for (Iterator anIter (*this); anIter.More(); anIter.Next()) + { + if (anIter.Value() == theObject) + { + return Standard_True; + } + } + return Standard_False; + } + //! Destructor - clears the List virtual ~NCollection_List (void) { Clear(); } diff --git a/src/PrsMgr/PrsMgr_PresentationManager.cxx b/src/PrsMgr/PrsMgr_PresentationManager.cxx index ce0a0fdd54..6be9a18204 100644 --- a/src/PrsMgr/PrsMgr_PresentationManager.cxx +++ b/src/PrsMgr/PrsMgr_PresentationManager.cxx @@ -354,9 +354,9 @@ void PrsMgr_PresentationManager::ClearImmediateDraw() // ======================================================================= void PrsMgr_PresentationManager::displayImmediate (const Handle(V3d_Viewer)& theViewer) { - for (theViewer->InitActiveViews(); theViewer->MoreActiveViews(); theViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (theViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - const Handle(Graphic3d_CView)& aView = theViewer->ActiveView()->View(); + const Handle(Graphic3d_CView)& aView = anActiveViewIter.Value()->View(); for (PrsMgr_ListOfPresentations::Iterator anIter (myImmediateList); anIter.More(); anIter.Next()) { const Handle(Prs3d_Presentation)& aPrs = anIter.Value(); @@ -700,9 +700,9 @@ void PrsMgr_PresentationManager::UpdateHighlightTrsf (const Handle(V3d_Viewer)& if (!myViewDependentImmediateList.IsEmpty()) { - for (theViewer->InitActiveViews(); theViewer->MoreActiveViews(); theViewer->NextActiveViews()) + for (V3d_ListOfViewIterator anActiveViewIter (theViewer->ActiveViewIterator()); anActiveViewIter.More(); anActiveViewIter.Next()) { - const Handle(Graphic3d_CView)& aView = theViewer->ActiveView()->View(); + const Handle(Graphic3d_CView)& aView = anActiveViewIter.Value()->View(); Handle(Graphic3d_Structure) aViewDepParentPrs; if (aView->IsComputed (aParentId, aViewDepParentPrs)) { diff --git a/src/V3d/FILES b/src/V3d/FILES index 29439f7f4a..f0628aec17 100755 --- a/src/V3d/FILES +++ b/src/V3d/FILES @@ -11,7 +11,8 @@ V3d_DirectionalLight.hxx V3d_ImageDumpOptions.hxx V3d_Light.cxx V3d_Light.hxx -V3d_ListOfTransient.hxx +V3d_ListOfLight.hxx +V3d_ListOfView.hxx V3d_Parameter.hxx V3d_Plane.cxx V3d_Plane.hxx @@ -44,8 +45,6 @@ V3d_View_4.cxx V3d_View_5.cxx V3d_Viewer.cxx V3d_Viewer.hxx -V3d_Viewer_1.cxx -V3d_Viewer_2.cxx V3d_Viewer_3.cxx V3d_Viewer_4.cxx V3d_ViewerPointer.hxx diff --git a/src/V3d/V3d_ListOfLight.hxx b/src/V3d/V3d_ListOfLight.hxx new file mode 100644 index 0000000000..f314aea8f1 --- /dev/null +++ b/src/V3d/V3d_ListOfLight.hxx @@ -0,0 +1,24 @@ +// Copyright (c) 2016 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 _V3d_ListOfLight_HeaderFile +#define _V3d_ListOfLight_HeaderFile + +class V3d_Light; +#include +#include + +typedef NCollection_List V3d_ListOfLight; +typedef V3d_ListOfLight::Iterator V3d_ListOfLightIterator; + +#endif // _V3d_ListOfLight_HeaderFile diff --git a/src/V3d/V3d_ListOfTransient.hxx b/src/V3d/V3d_ListOfTransient.hxx deleted file mode 100644 index 001a2727d8..0000000000 --- a/src/V3d/V3d_ListOfTransient.hxx +++ /dev/null @@ -1,52 +0,0 @@ -// Created on: 1995-05-17 -// Created by: Mister rmi -// Copyright (c) 1995-1999 Matra Datavision -// Copyright (c) 1999-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 _V3d_ListOfTransient_HeaderFile -#define _V3d_ListOfTransient_HeaderFile - -#include -#include - -//! List of transient objects with methods to check presence and remove elements -class V3d_ListOfTransient: public TColStd_ListOfTransient -{ -public: - - //! Return true if theObject is stored in the list - Standard_Boolean Contains (const Handle(Standard_Transient)& theObject) const - { - for (TColStd_ListIteratorOfListOfTransient it (*this); it.More(); it.Next()) - { - if (it.Value() == theObject) - return Standard_True; - } - return Standard_False; - } - - //! Remove all elements equal to theObject from the list - void Remove (const Handle(Standard_Transient)& theObject) - { - for (TColStd_ListIteratorOfListOfTransient it (*this); it.More();) - { - if (it.Value() == theObject) - TColStd_ListOfTransient::Remove (it); - else - it.Next(); - } - } -}; - -#endif diff --git a/src/V3d/V3d_ListOfView.hxx b/src/V3d/V3d_ListOfView.hxx new file mode 100644 index 0000000000..36deb54c04 --- /dev/null +++ b/src/V3d/V3d_ListOfView.hxx @@ -0,0 +1,24 @@ +// Copyright (c) 2016 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 _V3d_ListOfView_HeaderFile +#define _V3d_ListOfView_HeaderFile + +class V3d_View; +#include +#include + +typedef NCollection_List V3d_ListOfView; +typedef V3d_ListOfView::Iterator V3d_ListOfViewIterator; + +#endif // _V3d_ListOfView_HeaderFile diff --git a/src/V3d/V3d_View.cxx b/src/V3d/V3d_View.cxx index a01ab03502..449cd2acb2 100644 --- a/src/V3d/V3d_View.cxx +++ b/src/V3d/V3d_View.cxx @@ -66,8 +66,6 @@ namespace //============================================================================= V3d_View::V3d_View (const Handle(V3d_Viewer)& theViewer, const V3d_TypeOfView theType) : MyViewer (theViewer.operator->()), - MyActiveLights(), - myActiveLightsIterator(), SwitchSetFront (Standard_False), myZRotation (Standard_False), MyTrsf (1, 4, 1, 4) @@ -117,8 +115,6 @@ V3d_View::V3d_View (const Handle(V3d_Viewer)& theViewer, const V3d_TypeOfView th //============================================================================= V3d_View::V3d_View (const Handle(V3d_Viewer)& theViewer, const Handle(V3d_View)& theView) : MyViewer (theViewer.operator->()), - MyActiveLights(), - myActiveLightsIterator(), SwitchSetFront(Standard_False), myZRotation (Standard_False), MyTrsf (1, 4, 1, 4) @@ -373,14 +369,11 @@ Standard_Boolean V3d_View::IsEmpty() const void V3d_View::UpdateLights() const { Graphic3d_ListOfCLight aLights; - - for (TColStd_ListIteratorOfListOfTransient anIt (MyActiveLights); anIt.More(); anIt.Next()) + for (V3d_ListOfLight::Iterator anActiveLightIter (myActiveLights); anActiveLightIter.More(); anActiveLightIter.Next()) { - aLights.Append (Handle(V3d_Light)::DownCast (anIt.Value())->Light()); + aLights.Append (anActiveLightIter.Value()->Light()); } - myView->SetLights (aLights); - Update(); } diff --git a/src/V3d/V3d_View.hxx b/src/V3d/V3d_View.hxx index 5771859362..9f79d2e101 100644 --- a/src/V3d/V3d_View.hxx +++ b/src/V3d/V3d_View.hxx @@ -67,7 +67,6 @@ #include #include -#include #include #include @@ -695,17 +694,19 @@ public: //! activated in this View. Standard_EXPORT Standard_Boolean IfMoreLights() const; + //! Return iterator for defined lights. + V3d_ListOfLightIterator ActiveLightIterator() const { return V3d_ListOfLightIterator (myActiveLights); } + //! initializes an iteration on the active Lights. - Standard_EXPORT void InitActiveLights(); + void InitActiveLights() { myActiveLightsIterator.Initialize (myActiveLights); } //! returns true if there are more active Light(s) to return. - Standard_EXPORT Standard_Boolean MoreActiveLights() const; + Standard_Boolean MoreActiveLights() const { return myActiveLightsIterator.More(); } - //! Go to the next active Light - //! (if there is not, ActiveLight will raise an exception) - Standard_EXPORT void NextActiveLights(); + //! Go to the next active Light (if there is not, ActiveLight will raise an exception) + void NextActiveLights() { myActiveLightsIterator.Next(); } - Standard_EXPORT Handle(V3d_Light) ActiveLight() const; + const Handle(V3d_Light)& ActiveLight() const { return myActiveLightsIterator.Value(); } //! Returns the MAX number of light associated to the view. Standard_EXPORT Standard_Integer LightLimit() const; @@ -1032,11 +1033,11 @@ protected: private: V3d_ViewerPointer MyViewer; - V3d_ListOfTransient MyActiveLights; + V3d_ListOfLight myActiveLights; Graphic3d_Vector MyDefaultViewAxis; Graphic3d_Vertex MyDefaultViewPoint; Handle(Aspect_Window) MyWindow; - TColStd_ListIteratorOfListOfTransient myActiveLightsIterator; + V3d_ListOfLight::Iterator myActiveLightsIterator; Standard_Integer sx; Standard_Integer sy; Standard_Real rx; diff --git a/src/V3d/V3d_View_2.cxx b/src/V3d/V3d_View_2.cxx index 4a6ae4d526..597c97a6a1 100644 --- a/src/V3d/V3d_View_2.cxx +++ b/src/V3d/V3d_View_2.cxx @@ -52,12 +52,12 @@ //============================================================================= void V3d_View::SetLightOn (const Handle(V3d_Light)& theLight) { - if (!MyActiveLights.Contains (theLight)) + if (!myActiveLights.Contains (theLight)) { - V3d_BadValue_Raise_if (MyActiveLights.Extent() >= LightLimit(), + V3d_BadValue_Raise_if (myActiveLights.Extent() >= LightLimit(), "V3d_View::SetLightOn, " "too many lights"); - MyActiveLights.Append (theLight); + myActiveLights.Append (theLight); UpdateLights(); } } @@ -71,7 +71,7 @@ void V3d_View::SetLightOff (const Handle(V3d_Light)& theLight) Standard_TypeMismatch_Raise_if (MyViewer->IsGlobalLight (theLight), "V3d_View::SetLightOff, " "the light is global"); - MyActiveLights.Remove (theLight); + myActiveLights.Remove (theLight); UpdateLights(); } @@ -81,11 +81,8 @@ void V3d_View::SetLightOff (const Handle(V3d_Light)& theLight) //============================================================================= Standard_Boolean V3d_View::IsActiveLight (const Handle(V3d_Light)& theLight) const { - if (theLight.IsNull()) - { - return Standard_False; - } - return MyActiveLights.Contains(theLight); + return !theLight.IsNull() + && myActiveLights.Contains (theLight); } //============================================================================= @@ -94,11 +91,11 @@ Standard_Boolean V3d_View::IsActiveLight (const Handle(V3d_Light)& theLight) con //============================================================================= void V3d_View::SetLightOn() { - for (MyViewer->InitDefinedLights(); MyViewer->MoreDefinedLights(); MyViewer->NextDefinedLights()) + for (V3d_ListOfLightIterator aDefLightIter (MyViewer->DefinedLightIterator()); aDefLightIter.More(); aDefLightIter.Next()) { - if (!MyActiveLights.Contains (MyViewer->DefinedLight())) + if (!myActiveLights.Contains (aDefLightIter.Value())) { - MyActiveLights.Append (MyViewer->DefinedLight()); + myActiveLights.Append (aDefLightIter.Value()); } } UpdateLights(); @@ -110,64 +107,27 @@ void V3d_View::SetLightOn() //============================================================================= void V3d_View::SetLightOff() { - InitActiveLights(); - while(MoreActiveLights()) + for (V3d_ListOfLight::Iterator anActiveLightIter (myActiveLights); anActiveLightIter.More();) { - if (!MyViewer->IsGlobalLight (ActiveLight())) + if (!MyViewer->IsGlobalLight (anActiveLightIter.Value())) { - MyActiveLights.Remove (ActiveLight()); + myActiveLights.Remove (anActiveLightIter); } else { - NextActiveLights(); + anActiveLightIter.Next(); } } UpdateLights(); } -//============================================================================= -//function : InitActiveLights -//purpose : -//============================================================================= -void V3d_View::InitActiveLights() -{ - myActiveLightsIterator.Initialize(MyActiveLights); -} - -//============================================================================= -//function : MoreActiveLights -//purpose : -//============================================================================= -Standard_Boolean V3d_View::MoreActiveLights() const -{ - return myActiveLightsIterator.More(); -} - -//============================================================================= -//function : NextActiveLights -//purpose : -//============================================================================= -void V3d_View::NextActiveLights() -{ - myActiveLightsIterator.Next(); -} - -//============================================================================= -//function : ActiveLight -//purpose : -//============================================================================= -Handle(V3d_Light) V3d_View::ActiveLight() const -{ - return (Handle(V3d_Light)&)(myActiveLightsIterator.Value()); -} - //============================================================================= //function : IfMoreLights //purpose : //============================================================================= Standard_Boolean V3d_View::IfMoreLights() const { - return MyActiveLights.Extent() < LightLimit(); + return myActiveLights.Extent() < LightLimit(); } //======================================================================= diff --git a/src/V3d/V3d_Viewer.cxx b/src/V3d/V3d_Viewer.cxx index d527a8c646..46bc8c34f2 100644 --- a/src/V3d/V3d_Viewer.cxx +++ b/src/V3d/V3d_Viewer.cxx @@ -11,36 +11,60 @@ // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. +#include -#include -#include #include #include -#include #include #include #include #include -#include #include #include #include #include #include -#include +#include +#include #include #include -#include -IMPLEMENT_STANDARD_RTTIEXT(V3d_Viewer,MMgt_TShared) +IMPLEMENT_STANDARD_RTTIEXT(V3d_Viewer, Standard_Transient) + +// ======================================================================== +// function : V3d_Viewer +// purpose : +// ======================================================================== +V3d_Viewer::V3d_Viewer (const Handle(Graphic3d_GraphicDriver)& theDriver) +: myDriver (theDriver), + myStructureManager (new Graphic3d_StructureManager (theDriver)), + myZLayerGenId (1, IntegerLast()), + myBackground (Quantity_NOC_GRAY30), + myViewSize (1000.0), + myViewProj (V3d_XposYnegZpos), + myVisualization (V3d_ZBUFFER), + myShadingModel (V3d_GOURAUD), + myDefaultTypeOfView (V3d_ORTHOGRAPHIC), + myComputedMode (Standard_True), + myDefaultComputedMode (Standard_False), + myPrivilegedPlane (gp_Ax3 (gp_Pnt (0.,0.,0), gp_Dir (0.,0.,1.), gp_Dir (1.,0.,0.))), + myDisplayPlane (Standard_False), + myDisplayPlaneLength (1000.0), + myGridType (Aspect_GT_Rectangular), + myGridEcho (Standard_True), + myGridEchoLastVert (ShortRealLast(), ShortRealLast(), ShortRealLast()) +{ + myRGrid = new V3d_RectangularGrid (this, Quantity_Color (Quantity_NOC_GRAY50), Quantity_Color (Quantity_NOC_GRAY70)); + myCGrid = new V3d_CircularGrid (this, Quantity_Color (Quantity_NOC_GRAY50), Quantity_Color (Quantity_NOC_GRAY70)); +} // ======================================================================== // function : V3d_Viewer // purpose : // ======================================================================== V3d_Viewer::V3d_Viewer (const Handle(Graphic3d_GraphicDriver)& theDriver, - const Standard_ExtString theName, - const Standard_CString theDomain, + const Standard_ExtString , + const Standard_CString , const Standard_Real theViewSize, const V3d_TypeOfOrientation theViewProj, const Quantity_NameOfColor theViewBackground, @@ -49,43 +73,28 @@ V3d_Viewer::V3d_Viewer (const Handle(Graphic3d_GraphicDriver)& theDriver, const V3d_TypeOfUpdate theUpdateMode, const Standard_Boolean theComputedMode, const Standard_Boolean theDefaultComputedMode) -:myNextCount (-1), -myDriver (theDriver), -myName (TCollection_ExtendedString (theName)), -myDomain (TCollection_AsciiString (theDomain)), -myStructureManager (new Graphic3d_StructureManager (theDriver)), -MyDefinedViews(), -MyActiveViews(), -MyDefinedLights(), -MyActiveLights(), -myActiveViewsIterator(), -myDefinedViewsIterator(), -myActiveLightsIterator(), -myDefinedLightsIterator(), -myComputedMode (theComputedMode), -myDefaultComputedMode (theDefaultComputedMode), -myPrivilegedPlane (gp_Ax3 (gp_Pnt (0.,0.,0), gp_Dir (0.,0.,1.), gp_Dir (1.,0.,0.))), -myDisplayPlane (Standard_False), -myDisplayPlaneLength (theViewSize), -myGridEcho (Standard_True), -myGridEchoLastVert (ShortRealLast(), ShortRealLast(), ShortRealLast()), -myZLayerGenId (1, IntegerLast()) +: myDriver (theDriver), + myStructureManager (new Graphic3d_StructureManager (theDriver)), + myZLayerGenId (1, IntegerLast()), + myBackground (theViewBackground), + myViewSize (theViewSize), + myViewProj (theViewProj), + myVisualization (theVisualization), + myShadingModel (theShadingModel), + myDefaultTypeOfView (V3d_ORTHOGRAPHIC), + myComputedMode (theComputedMode), + myDefaultComputedMode (theDefaultComputedMode), + myPrivilegedPlane (gp_Ax3 (gp_Pnt (0.,0.,0), gp_Dir (0.,0.,1.), gp_Dir (1.,0.,0.))), + myDisplayPlane (Standard_False), + myDisplayPlaneLength (theViewSize), + myGridType (Aspect_GT_Rectangular), + myGridEcho (Standard_True), + myGridEchoLastVert (ShortRealLast(), ShortRealLast(), ShortRealLast()) { - SetUpdateMode (theUpdateMode); + myRGrid = new V3d_RectangularGrid (this, Quantity_Color (Quantity_NOC_GRAY50), Quantity_Color (Quantity_NOC_GRAY70)); + myCGrid = new V3d_CircularGrid (this, Quantity_Color (Quantity_NOC_GRAY50), Quantity_Color (Quantity_NOC_GRAY70)); SetDefaultViewSize (theViewSize); - SetDefaultViewProj (theViewProj); - SetDefaultBackgroundColor (theViewBackground); - SetDefaultVisualization (theVisualization); - SetDefaultShadingModel (theShadingModel); - SetDefaultAngle (M_PI / 2.); - SetDefaultTypeOfView (V3d_ORTHOGRAPHIC); - - Quantity_Color Color1 (Quantity_NOC_GRAY50); - Quantity_Color Color2 (Quantity_NOC_GRAY70); -// Quantity_Color White (Quantity_NOC_WHITE); - myRGrid = new V3d_RectangularGrid (this, Color1, Color2); - myCGrid = new V3d_CircularGrid (this, Color1, Color2); - myGridType = Aspect_GT_Rectangular; + SetUpdateMode (theUpdateMode); } // ======================================================================== @@ -94,7 +103,7 @@ myZLayerGenId (1, IntegerLast()) // ======================================================================== Handle(V3d_View) V3d_Viewer::CreateView () { - return new V3d_View(this, MyDefaultTypeOfView); + return new V3d_View(this, myDefaultTypeOfView); } // ======================================================================== @@ -103,9 +112,9 @@ Handle(V3d_View) V3d_Viewer::CreateView () // ======================================================================== void V3d_Viewer::SetViewOn() { - for (InitDefinedViews();MoreDefinedViews();NextDefinedViews()) + for (V3d_ListOfView::Iterator aDefViewIter (myDefinedViews); aDefViewIter.More(); aDefViewIter.Next()) { - SetViewOn (ActiveView()); + SetViewOn (aDefViewIter.Value()); } } @@ -115,9 +124,9 @@ void V3d_Viewer::SetViewOn() // ======================================================================== void V3d_Viewer::SetViewOff() { - for (InitDefinedViews();MoreDefinedViews();NextDefinedViews()) + for (V3d_ListOfView::Iterator aDefViewIter (myDefinedViews); aDefViewIter.More(); aDefViewIter.Next()) { - SetViewOff (ActiveView()); + SetViewOff (aDefViewIter.Value()); } } @@ -128,19 +137,21 @@ void V3d_Viewer::SetViewOff() void V3d_Viewer::SetViewOn (const Handle(V3d_View)& theView) { Handle(Graphic3d_CView) aViewImpl = theView->View(); - if (aViewImpl->IsDefined() && !IsActive (theView)) + if (!aViewImpl->IsDefined() || myActiveViews.Contains (theView)) { - MyActiveViews.Append (theView); - aViewImpl->Activate(); - for (InitActiveLights();MoreActiveLights();NextActiveLights()) - { - theView->SetLightOn (ActiveLight()); - } - - theView->SetGrid (myPrivilegedPlane, Grid ()); - theView->SetGridActivity (Grid ()->IsActive ()); - theView->Redraw(); + return; } + + myActiveViews.Append (theView); + aViewImpl->Activate(); + for (V3d_ListOfLight::Iterator anActiveLightIter (myActiveLights); anActiveLightIter.More(); anActiveLightIter.Next()) + { + theView->SetLightOn (anActiveLightIter.Value()); + } + + theView->SetGrid (myPrivilegedPlane, Grid ()); + theView->SetGridActivity (Grid ()->IsActive ()); + theView->Redraw(); } // ======================================================================== @@ -150,53 +161,22 @@ void V3d_Viewer::SetViewOn (const Handle(V3d_View)& theView) void V3d_Viewer::SetViewOff (const Handle(V3d_View)& theView) { Handle(Graphic3d_CView) aViewImpl = theView->View(); - if (aViewImpl->IsDefined() && IsActive (theView)) + if (aViewImpl->IsDefined() && myActiveViews.Contains (theView)) { - MyActiveViews.Remove (theView); + myActiveViews.Remove (theView); aViewImpl->Deactivate() ; } } -// ======================================================================== -// function : ComputedMode -// purpose : -// ======================================================================== -Standard_Boolean V3d_Viewer::ComputedMode() const -{ - return myComputedMode; -} - -// ======================================================================== -// function : DefaultComputedMode -// purpose : -// ======================================================================== -Standard_Boolean V3d_Viewer::DefaultComputedMode() const -{ - return myDefaultComputedMode; -} - -// ======================================================================== -// function : Update -// purpose : -// ======================================================================== -void V3d_Viewer::Update() -{ - // Redraw() is still here for compatibility with old code. - // See comments, the method is deprecated - Redraw() should - // be used instead. - Redraw(); -} - // ======================================================================== // function : Redraw // purpose : // ======================================================================== -void V3d_Viewer::Redraw()const +void V3d_Viewer::Redraw() const { - TColStd_ListIteratorOfListOfTransient anIt (MyDefinedViews); - for (; anIt.More(); anIt.Next()) + for (V3d_ListOfView::Iterator aDefViewIter (myDefinedViews); aDefViewIter.More(); aDefViewIter.Next()) { - Handle(V3d_View)::DownCast (anIt.Value())->Redraw(); + aDefViewIter.Value()->Redraw(); } } @@ -206,10 +186,9 @@ void V3d_Viewer::Redraw()const // ======================================================================== void V3d_Viewer::RedrawImmediate() const { - TColStd_ListIteratorOfListOfTransient anIt (MyDefinedViews); - for (; anIt.More(); anIt.Next()) + for (V3d_ListOfView::Iterator aDefViewIter (myDefinedViews); aDefViewIter.More(); aDefViewIter.Next()) { - Handle(V3d_View)::DownCast (anIt.Value())->RedrawImmediate(); + aDefViewIter.Value()->RedrawImmediate(); } } @@ -219,10 +198,9 @@ void V3d_Viewer::RedrawImmediate() const // ======================================================================== void V3d_Viewer::Invalidate() const { - TColStd_ListIteratorOfListOfTransient anIt (MyDefinedViews); - for (; anIt.More(); anIt.Next()) + for (V3d_ListOfView::Iterator aDefViewIter (myDefinedViews); aDefViewIter.More(); aDefViewIter.Next()) { - Handle(V3d_View)::DownCast (anIt.Value())->Invalidate(); + aDefViewIter.Value()->Invalidate(); } } @@ -253,77 +231,12 @@ void V3d_Viewer::UnHighlight() const myStructureManager->UnHighlight(); } -void V3d_Viewer::SetDefaultBackgroundColor(const Quantity_TypeOfColor Type, const Standard_Real v1, const Standard_Real v2, const Standard_Real v3) { - Standard_Real V1 = v1 ; - Standard_Real V2 = v2 ; - Standard_Real V3 = v3 ; - - if( V1 < 0. ) V1 = 0. ; else if( V1 > 1. ) V1 = 1. ; - if( V2 < 0. ) V2 = 0. ; else if( V2 > 1. ) V2 = 1. ; - if( V3 < 0. ) V3 = 0. ; else if( V3 > 1. ) V3 = 1. ; - - Quantity_Color C(V1,V2,V3,Type) ; - SetDefaultBackgroundColor(C); -} - -void V3d_Viewer::SetDefaultBackgroundColor(const Quantity_NameOfColor Name) +void V3d_Viewer::SetDefaultViewSize (const Standard_Real theSize) { - Quantity_Color C(Name) ; - SetDefaultBackgroundColor(C); + V3d_BadValue_Raise_if (theSize <= 0.0, "V3d_Viewer::SetDefaultViewSize, bad size"); + myViewSize = theSize; } -void V3d_Viewer::SetDefaultBackgroundColor(const Quantity_Color &Color) -{ - MyBackground.SetColor(Color) ; -} - -void V3d_Viewer::SetDefaultBgGradientColors( const Quantity_NameOfColor Name1, - const Quantity_NameOfColor Name2, - const Aspect_GradientFillMethod FillStyle){ - - Quantity_Color C1(Name1) ; - Quantity_Color C2(Name2) ; - MyGradientBackground.SetColors(C1, C2, FillStyle); - -} - -void V3d_Viewer::SetDefaultBgGradientColors( const Quantity_Color& Color1, - const Quantity_Color& Color2, - const Aspect_GradientFillMethod FillStyle ){ - - MyGradientBackground.SetColors(Color1, Color2, FillStyle); - -} - - -void V3d_Viewer::SetDefaultViewSize(const Standard_Real Size) { - - V3d_BadValue_Raise_if( Size <= 0. ,"V3d_Viewer::SetDefaultViewSize, bad size"); - MyViewSize = Size ; -} - -void V3d_Viewer::SetDefaultViewProj(const V3d_TypeOfOrientation Orientation) { - - MyViewProj = Orientation ; -} - -void V3d_Viewer::SetDefaultVisualization(const V3d_TypeOfVisualization Type) { - - MyVisualization = Type ; -} - -void V3d_Viewer::SetDefaultShadingModel(const V3d_TypeOfShadingModel Type) { - - MyShadingModel = Type ; -} - -void V3d_Viewer::SetDefaultAngle(const Quantity_PlaneAngle Angle) { - MyDefaultAngle = Angle; -} - -void V3d_Viewer::SetDefaultTypeOfView(const V3d_TypeOfView Type) { - MyDefaultTypeOfView = Type;} - // ======================================================================== // function : SetUpdateMode // purpose : @@ -333,42 +246,6 @@ void V3d_Viewer::SetUpdateMode (const V3d_TypeOfUpdate theMode) myStructureManager->SetUpdateMode (static_cast (theMode)); } -void V3d_Viewer::DefaultBackgroundColor(const Quantity_TypeOfColor Type,Standard_Real &V1,Standard_Real &V2,Standard_Real &V3) const -{ - Quantity_Color C = DefaultBackgroundColor(); - C.Values(V1,V2,V3,Type) ; -} - -Quantity_Color V3d_Viewer::DefaultBackgroundColor() const -{ - return MyBackground.Color() ; -} - -void V3d_Viewer::DefaultBgGradientColors(Quantity_Color& Color1,Quantity_Color& Color2) const -{ - MyGradientBackground.Colors(Color1,Color2); -} - -Standard_Real V3d_Viewer::DefaultViewSize() const { - return MyViewSize ; -} - -V3d_TypeOfOrientation V3d_Viewer::DefaultViewProj() const { - return MyViewProj ; -} - -V3d_TypeOfVisualization V3d_Viewer::DefaultVisualization() const { - return MyVisualization ; -} - -V3d_TypeOfShadingModel V3d_Viewer::DefaultShadingModel() const { - return MyShadingModel ; -} - -Quantity_PlaneAngle V3d_Viewer::DefaultAngle() const { - return MyDefaultAngle; -} - // ======================================================================== // function : UpdateMode // purpose : @@ -378,43 +255,35 @@ V3d_TypeOfUpdate V3d_Viewer::UpdateMode() const return static_cast (myStructureManager->UpdateMode()); } -Standard_Boolean V3d_Viewer::IfMoreViews() const { - Standard_Boolean TheStatus = Standard_False ; - -#ifdef NEW - if (MyActiveViews->Length() < myDriver->InquireViewLimit()) -#endif /*NEW*/ - TheStatus = Standard_True ; - return TheStatus ; -} - // ======================================================================== -// function : StructureManager +// function : IfMoreViews // purpose : // ======================================================================== -Handle(Graphic3d_StructureManager) V3d_Viewer::StructureManager() const +Standard_Boolean V3d_Viewer::IfMoreViews() const { - return myStructureManager; + return myDefinedViews.Size() < myStructureManager->MaxNumOfViews(); } -Aspect_Background V3d_Viewer::GetBackgroundColor() const { - return MyBackground ; +// ======================================================================== +// function : AddView +// purpose : +// ======================================================================== +void V3d_Viewer::AddView (const Handle(V3d_View)& theView) +{ + if (!myDefinedViews.Contains (theView)) + { + myDefinedViews.Append (theView); + } } -Aspect_GradientBackground V3d_Viewer::GetGradientBackground() const { - return MyGradientBackground; -} - -void V3d_Viewer::AddView( const Handle(V3d_View)& TheView ) { - - MyDefinedViews.Append(TheView); - IncrCount(); -} - -void V3d_Viewer::DelView( const Handle(V3d_View)& TheView ) { - - MyActiveViews.Remove(TheView); - MyDefinedViews.Remove(TheView); +// ======================================================================== +// function : DelView +// purpose : +// ======================================================================== +void V3d_Viewer::DelView (const Handle(V3d_View)& theView) +{ + myActiveViews.Remove (theView); + myDefinedViews.Remove (theView); } //======================================================================= @@ -488,58 +357,125 @@ Graphic3d_ZLayerSettings V3d_Viewer::ZLayerSettings (const Standard_Integer theL } //======================================================================= -//function : Domain +//function : UpdateLights //purpose : //======================================================================= -Standard_CString V3d_Viewer::Domain() const +void V3d_Viewer::UpdateLights() { - return myDomain.ToCString(); + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) + { + anActiveViewIter.Value()->UpdateLights(); + } } //======================================================================= -//function : Driver +//function : SetLightOn //purpose : //======================================================================= -const Handle(Graphic3d_GraphicDriver)& V3d_Viewer::Driver() const +void V3d_Viewer::SetLightOn (const Handle(V3d_Light)& theLight) { - return myDriver; + if (!myActiveLights.Contains (theLight)) + { + myActiveLights.Append (theLight); + } + + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) + { + anActiveViewIter.Value()->SetLightOn (theLight); + } } //======================================================================= -//function : NextName +//function : SetLightOff //purpose : //======================================================================= -Standard_ExtString V3d_Viewer::NextName() const +void V3d_Viewer::SetLightOff (const Handle(V3d_Light)& theLight) { - TCollection_ExtendedString aNextName = TCollection_ExtendedString (myName.ToExtString()); - aNextName.AssignCat (TCollection_ExtendedString (myNextCount)); - - return aNextName.ToExtString(); + myActiveLights.Remove (theLight); + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) + { + anActiveViewIter.Value()->SetLightOff (theLight); + } } //======================================================================= -//function : IncrCount +//function : SetLightOn //purpose : //======================================================================= -void V3d_Viewer::IncrCount() +void V3d_Viewer::SetLightOn() { - myNextCount++; + for (V3d_ListOfLight::Iterator aDefLightIter (myDefinedLights); aDefLightIter.More(); aDefLightIter.Next()) + { + if (!myActiveLights.Contains (aDefLightIter.Value())) + { + myActiveLights.Append (aDefLightIter.Value()); + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) + { + anActiveViewIter.Value()->SetLightOn (aDefLightIter.Value()); + } + } + } } //======================================================================= -//function : DefaultRenderingParams +//function : SetLightOff //purpose : //======================================================================= -const Graphic3d_RenderingParams& V3d_Viewer::DefaultRenderingParams() const +void V3d_Viewer::SetLightOff() { - return myDefaultRenderingParams; + for (V3d_ListOfLight::Iterator anActiveLightIter (myActiveLights); anActiveLightIter.More(); anActiveLightIter.Next()) + { + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) + { + anActiveViewIter.Value()->SetLightOff (anActiveLightIter.Value()); + } + } + myActiveLights.Clear(); } //======================================================================= -//function : SetDefaultRenderingParams +//function : IsGlobalLight //purpose : //======================================================================= -void V3d_Viewer::SetDefaultRenderingParams (const Graphic3d_RenderingParams& theParams) +Standard_Boolean V3d_Viewer::IsGlobalLight (const Handle(V3d_Light)& theLight) const { - myDefaultRenderingParams = theParams; + return myActiveLights.Contains (theLight); +} + +//======================================================================= +//function : AddLight +//purpose : +//======================================================================= +void V3d_Viewer::AddLight (const Handle(V3d_Light)& theLight) +{ + if (!myDefinedLights.Contains (theLight)) + { + myDefinedLights.Append (theLight); + } +} + +//======================================================================= +//function : DelLight +//purpose : +//======================================================================= +void V3d_Viewer::DelLight (const Handle(V3d_Light)& theLight) +{ + SetLightOff (theLight); + myDefinedLights.Remove (theLight); +} + +//======================================================================= +//function : SetDefaultLights +//purpose : +//======================================================================= +void V3d_Viewer::SetDefaultLights() +{ + while (!myDefinedLights.IsEmpty()) + { + Handle(V3d_Light) aLight = myDefinedLights.First(); + DelLight (aLight); + } + + SetLightOn (new V3d_DirectionalLight (this, V3d_Zneg, Quantity_NOC_WHITE, Standard_True)); + SetLightOn (new V3d_AmbientLight (this)); } diff --git a/src/V3d/V3d_Viewer.hxx b/src/V3d/V3d_Viewer.hxx index 8088375c80..0452b0fb37 100644 --- a/src/V3d/V3d_Viewer.hxx +++ b/src/V3d/V3d_Viewer.hxx @@ -29,8 +29,6 @@ #include #include -#include - #include #include #include @@ -45,14 +43,15 @@ #include #include -#include +#include +#include #include #include #include #include #include -#include +#include #include #include #include @@ -70,41 +69,36 @@ class V3d_RectangularGrid; class V3d_View; class Quantity_Color; -class V3d_Viewer; -DEFINE_STANDARD_HANDLE(V3d_Viewer, MMgt_TShared) - //! Defines services on Viewer type objects. //! The methods of this class allow editing and //! interrogation of the parameters linked to the viewer //! its friend classes (View,light,plane). -class V3d_Viewer : public MMgt_TShared +class V3d_Viewer : public Standard_Transient { - + friend class V3d_View; + friend class V3d_Light; + DEFINE_STANDARD_RTTIEXT(V3d_Viewer, Standard_Transient) public: - - //! Create a Viewer with the given graphic driver and the given parameters or - //! with their default values. - //! Currently creating of more than 100 viewer instances - //! is not supported and leads to an exception. - //! This limitation might be addressed in some future OCCT releases. - //! If the size of the view is <= 0 - //! Warning: Client must creates a graphic driver - Standard_EXPORT V3d_Viewer(const Handle(Graphic3d_GraphicDriver)& theDriver, const Standard_ExtString theName, const Standard_CString theDomain = "", const Quantity_Length theViewSize = 1000.0, const V3d_TypeOfOrientation theViewProj = V3d_XposYnegZpos, const Quantity_NameOfColor theViewBackground = Quantity_NOC_GRAY30, const V3d_TypeOfVisualization theVisualization = V3d_ZBUFFER, const V3d_TypeOfShadingModel theShadingModel = V3d_GOURAUD, const V3d_TypeOfUpdate theUpdateMode = V3d_WAIT, const Standard_Boolean theComputedMode = Standard_True, const Standard_Boolean theDefaultComputedMode = Standard_True); - - //! creates a view in the viewer according to its - //! default parameters. + //! Create a Viewer with the given graphic driver and with default parameters: + //! - View orientation: V3d_XposYnegZpos + //! - View background: Quantity_NOC_GRAY30 + //! - Shading model: V3d_GOURAUD + Standard_EXPORT V3d_Viewer (const Handle(Graphic3d_GraphicDriver)& theDriver); + + //! Returns True if One View more can be defined in this Viewer. + Standard_EXPORT Standard_Boolean IfMoreViews() const; + + //! Creates a view in the viewer according to its default parameters. Standard_EXPORT Handle(V3d_View) CreateView(); - //! Activates all of the views of a viewer attached - //! to a window. + //! Activates all of the views of a viewer attached to a window. Standard_EXPORT void SetViewOn(); - //! Activates a particular view in the Viewer . - //! Must be call if the Window attached to the view - //! has been Deiconified . - Standard_EXPORT void SetViewOn (const Handle(V3d_View)& View); - + //! Activates a particular view in the Viewer. + //! Must be call if the Window attached to the view has been Deiconified. + Standard_EXPORT void SetViewOn (const Handle(V3d_View)& theView); + //! Deactivates all the views of a Viewer //! attached to a window. Standard_EXPORT void SetViewOff(); @@ -112,14 +106,11 @@ public: //! Deactivates a particular view in the Viewer. //! Must be call if the Window attached to the view //! has been Iconified . - Standard_EXPORT void SetViewOff (const Handle(V3d_View)& View); + Standard_EXPORT void SetViewOff (const Handle(V3d_View)& theView); //! Deprecated, Redraw() should be used instead. - Standard_EXPORT void Update(); - - //! Updates the lights of all the views of a viewer. - Standard_EXPORT void UpdateLights(); - + void Update() { Redraw(); } + //! Redraws all the views of the Viewer even if no //! modification has taken place. Must be called if //! all the views of the Viewer are exposed, as for @@ -134,183 +125,239 @@ public: //! Suppresses the Viewer. Standard_EXPORT void Remove(); - - //! Erase all Objects in All the views. - Standard_EXPORT void Erase() const; - - //! UnHighlight all Objects in All the views. - Standard_EXPORT void UnHighlight() const; - - //! Defines the default base colour of views attached - //! to the Viewer by supplying the type of colour - //! definition and the three component values.. - Standard_EXPORT void SetDefaultBackgroundColor (const Quantity_TypeOfColor Type, const Quantity_Parameter V1, const Quantity_Parameter V2, const Quantity_Parameter V3); - + + //! Return Graphic Driver instance. + const Handle(Graphic3d_GraphicDriver)& Driver() const { return myDriver; } + + //! Returns the structure manager associated to this viewer. + Handle(Graphic3d_StructureManager) StructureManager() const { return myStructureManager; } + + //! Return default Rendering Parameters. + //! By default these parameters are set in a new V3d_View. + const Graphic3d_RenderingParams& DefaultRenderingParams() const { return myDefaultRenderingParams; } + + //! Set default Rendering Parameters. + void SetDefaultRenderingParams (const Graphic3d_RenderingParams& theParams) { myDefaultRenderingParams = theParams; } + //! Defines the default background colour of views //! attached to the viewer by supplying the name of the //! colour under the form Quantity_NOC_xxxx . - Standard_EXPORT void SetDefaultBackgroundColor (const Quantity_NameOfColor Name); - + void SetDefaultBackgroundColor (const Quantity_NameOfColor theName) { myBackground.SetColor (Quantity_Color (theName)); } + //! Defines the default background colour of views //! attached to the viewer by supplying the color object - Standard_EXPORT void SetDefaultBackgroundColor (const Quantity_Color& Color); - + void SetDefaultBackgroundColor (const Quantity_Color& theColor) { myBackground.SetColor (theColor); } + + //! Returns the gradient background of the view. + const Aspect_GradientBackground& GetGradientBackground() const { return myGradientBackground; } + //! Defines the default gradient background colours of view //! attached to the viewer by supplying the name of the //! colours under the form Quantity_NOC_xxxx . - Standard_EXPORT void SetDefaultBgGradientColors (const Quantity_NameOfColor Name1, const Quantity_NameOfColor Name2, const Aspect_GradientFillMethod FillStyle = Aspect_GFM_HOR); + void SetDefaultBgGradientColors (const Quantity_NameOfColor theName1, + const Quantity_NameOfColor theName2, + const Aspect_GradientFillMethod theFillStyle = Aspect_GFM_HOR) + { + myGradientBackground.SetColors (Quantity_Color (theName1), Quantity_Color (theName2), theFillStyle); + } //! Defines the default gradient background colours of views //! attached to the viewer by supplying the colour objects - Standard_EXPORT void SetDefaultBgGradientColors (const Quantity_Color& Color1, const Quantity_Color& Color2, const Aspect_GradientFillMethod FillStyle = Aspect_GFM_HOR); - - //! Gives a default size for the creation of views of - //! the viewer. - Standard_EXPORT void SetDefaultViewSize (const Quantity_Length Size); - - //! Gives the default projection for creating views - //! in the viewer. - Standard_EXPORT void SetDefaultViewProj (const V3d_TypeOfOrientation Orientation); - - //! Gives the default visualization mode.. - Standard_EXPORT void SetDefaultVisualization (const V3d_TypeOfVisualization Type); + void SetDefaultBgGradientColors (const Quantity_Color& theColor1, + const Quantity_Color& theColor2, + const Aspect_GradientFillMethod theFillStyle = Aspect_GFM_HOR) + { + myGradientBackground.SetColors (theColor1, theColor2, theFillStyle); + } + + //! Returns the default size of the view. + Standard_Real DefaultViewSize() const { return myViewSize; } + + //! Gives a default size for the creation of views of the viewer. + Standard_EXPORT void SetDefaultViewSize (const Standard_Real theSize); + + //! Returns the default Projection. + V3d_TypeOfOrientation DefaultViewProj() const { return myViewProj; } + + //! Sets the default projection for creating views in the viewer. + void SetDefaultViewProj (const V3d_TypeOfOrientation theOrientation) { myViewProj = theOrientation; } + + //! Returns the default type of Visualization. + V3d_TypeOfVisualization DefaultVisualization() const { return myVisualization; } + + //! Gives the default visualization mode. + void SetDefaultVisualization (const V3d_TypeOfVisualization theType) { myVisualization = theType; } + + //! Returns the default type of Shading + V3d_TypeOfShadingModel DefaultShadingModel() const { return myShadingModel; } //! Gives the default type of SHADING. - Standard_EXPORT void SetDefaultShadingModel (const V3d_TypeOfShadingModel Type); - - Standard_EXPORT void SetDefaultAngle (const Quantity_PlaneAngle Angle); - + void SetDefaultShadingModel (const V3d_TypeOfShadingModel theType) { myShadingModel = theType; } + + //! Returns the regeneration mode of views in the viewer. + Standard_EXPORT V3d_TypeOfUpdate UpdateMode() const; + //! Defines the mode of regenerating the views making //! up the viewer. This can be immediate or //! deferred . In this latter case, the views are //! updated when the method Update(me) is called. Standard_EXPORT void SetUpdateMode (const V3d_TypeOfUpdate theMode); - Standard_EXPORT void SetDefaultTypeOfView (const V3d_TypeOfView Type); + void SetDefaultTypeOfView (const V3d_TypeOfView theType) { myDefaultTypeOfView = theType; } + + //! Returns the default background colour object. + Quantity_Color DefaultBackgroundColor() const { return myBackground.Color(); } + + //! Returns the gradient background colour objects of the view. + void DefaultBgGradientColors (Quantity_Color& theColor1, Quantity_Color& theColor2) const { myGradientBackground.Colors (theColor1, theColor2); } + + //! Return all Z layer ids in sequence ordered by overlay level from lowest layer to highest ( foreground ). + //! The first layer ID in sequence is the default layer that can't be removed. + Standard_EXPORT void GetAllZLayers (TColStd_SequenceOfInteger& theLayerSeq) const; + + //! Add a new top-level Z layer to all managed views and get its ID as value. + //! The Z layers are controlled entirely by viewer, it is not possible to add a layer to a particular view. + //! The method returns Standard_False if the layer can not be created. + //! The layer mechanism allows to display structures in higher layers in overlay of structures in lower layers. + Standard_EXPORT Standard_Boolean AddZLayer (Standard_Integer& theLayerId); + + //! Remove Z layer with ID . + //! Method returns Standard_False if the layer can not be removed or doesn't exists. + //! By default, there are always default bottom-level layer that can't be removed. + Standard_EXPORT Standard_Boolean RemoveZLayer (const Standard_Integer theLayerId); + + //! Returns the settings of a single Z layer. + Standard_EXPORT Graphic3d_ZLayerSettings ZLayerSettings (const Standard_Integer theLayerId); + + //! Sets the settings for a single Z layer. + Standard_EXPORT void SetZLayerSettings (const Standard_Integer theLayerId, const Graphic3d_ZLayerSettings& theSettings); + +public: + + //! Return an iterator for active views. + V3d_ListOfViewIterator ActiveViewIterator() const { return V3d_ListOfViewIterator (myActiveViews); } + + //! Initializes an internal iterator on the active views. + void InitActiveViews() { myActiveViewsIterator.Initialize (myActiveViews); } + + //! Returns true if there are more active view(s) to return. + Standard_Boolean MoreActiveViews() const { return myActiveViewsIterator.More(); } + + //! Go to the next active view (if there is not, ActiveView will raise an exception) + void NextActiveViews() { if (!myActiveViews.IsEmpty()) myActiveViewsIterator.Next(); } - Standard_EXPORT void SetPrivilegedPlane (const gp_Ax3& aPlane); - - Standard_EXPORT gp_Ax3 PrivilegedPlane() const; - - Standard_EXPORT void DisplayPrivilegedPlane (const Standard_Boolean OnOff, const Quantity_Length aSize = 1); + const Handle(V3d_View)& ActiveView() const { return myActiveViewsIterator.Value(); } + //! returns true if there is only one active view. + Standard_Boolean LastActiveView() const { return myActiveViews.Extent() == 1; } + +public: + + //! Return an iterator for defined views. + V3d_ListOfViewIterator DefinedViewIterator() const { return V3d_ListOfViewIterator (myDefinedViews); } + + //! Initializes an internal iterator on the Defined views. + void InitDefinedViews() { myDefinedViewsIterator.Initialize (myDefinedViews); } + + //! returns true if there are more Defined view(s) to return. + Standard_Boolean MoreDefinedViews() const { return myDefinedViewsIterator.More(); } + + //! Go to the next Defined view (if there is not, DefinedView will raise an exception) + void NextDefinedViews() { if (!myDefinedViews.IsEmpty()) myDefinedViewsIterator.Next(); } + + const Handle(V3d_View)& DefinedView() const { return myDefinedViewsIterator.Value(); } + +public: //! @name lights management + + //! Defines default lights: + //! positional-light 0.3 0. 0. + //! directional-light V3d_XnegYposZpos + //! directional-light V3d_XnegYneg + //! ambient-light + Standard_EXPORT void SetDefaultLights(); + //! Activates MyLight in the viewer. - Standard_EXPORT void SetLightOn (const Handle(V3d_Light)& MyLight); + Standard_EXPORT void SetLightOn (const Handle(V3d_Light)& theLight); //! Activates all the lights defined in this viewer. Standard_EXPORT void SetLightOn(); //! Deactivates MyLight in this viewer. - Standard_EXPORT void SetLightOff (const Handle(V3d_Light)& MyLight); + Standard_EXPORT void SetLightOff (const Handle(V3d_Light)& theLight); //! Deactivate all the Lights defined in this viewer. Standard_EXPORT void SetLightOff(); //! Delete Light in Sequence Of Lights. - Standard_EXPORT void DelLight (const Handle(V3d_Light)& MyLight); - - //! Defines the selected light. - Standard_EXPORT void SetCurrentSelectedLight (const Handle(V3d_Light)& TheLight); - - //! Defines the selected light at NULL. - Standard_EXPORT void ClearCurrentSelectedLight(); - - //! Returns the default background colour depending of the type. - Standard_EXPORT void DefaultBackgroundColor (const Quantity_TypeOfColor Type, Quantity_Parameter& V1, Quantity_Parameter& V2, Quantity_Parameter& V3) const; - - //! Returns the default background colour object. - Standard_EXPORT Quantity_Color DefaultBackgroundColor() const; - - //! Returns the gradient background colour objects of the view. - Standard_EXPORT void DefaultBgGradientColors (Quantity_Color& Color1, Quantity_Color& Color2) const; - - //! Returns the default size of the view. - Standard_EXPORT Quantity_Length DefaultViewSize() const; - - //! Returns the default Projection. - Standard_EXPORT V3d_TypeOfOrientation DefaultViewProj() const; - - //! Returns the default type of Visualization. - Standard_EXPORT V3d_TypeOfVisualization DefaultVisualization() const; - - //! Returns the default type of Shading - Standard_EXPORT V3d_TypeOfShadingModel DefaultShadingModel() const; - - Standard_EXPORT Quantity_PlaneAngle DefaultAngle() const; - - //! Returns the regeneration mode of views in the viewer. - Standard_EXPORT V3d_TypeOfUpdate UpdateMode() const; - - //! Returns True if One View more can be - //! activated in this Viewer. - Standard_EXPORT Standard_Boolean IfMoreViews() const; - - //! initializes an iteration on the active views. - Standard_EXPORT void InitActiveViews(); - - //! returns true if there are more active view(s) to return. - Standard_EXPORT Standard_Boolean MoreActiveViews() const; - - //! Go to the next active view - //! (if there is not, ActiveView will raise an exception) - Standard_EXPORT void NextActiveViews(); - - Standard_EXPORT Handle(V3d_View) ActiveView() const; - - //! returns true if there is only - //! one active view. - Standard_EXPORT Standard_Boolean LastActiveView() const; - - //! initializes an iteration on the Defined views. - Standard_EXPORT void InitDefinedViews(); - - //! returns true if there are more Defined view(s) to return. - Standard_EXPORT Standard_Boolean MoreDefinedViews() const; - - //! Go to the next Defined view - //! (if there is not, DefinedView will raise an exception) - Standard_EXPORT void NextDefinedViews(); - - Standard_EXPORT Handle(V3d_View) DefinedView() const; - - //! initializes an iteration on the active Lights. - Standard_EXPORT void InitActiveLights(); - - //! returns true if there are more active Light(s) to return. - Standard_EXPORT Standard_Boolean MoreActiveLights() const; - - //! Go to the next active Light - //! (if there is not, ActiveLight will raise an exception) - Standard_EXPORT void NextActiveLights(); - - Standard_EXPORT Handle(V3d_Light) ActiveLight() const; - - //! initializes an iteration on the Defined Lights. - Standard_EXPORT void InitDefinedLights(); - - //! returns true if there are more Defined Light(s) to return. - Standard_EXPORT Standard_Boolean MoreDefinedLights() const; - - //! Go to the next Defined Light - //! (if there is not, DefinedLight will raise an exception) - Standard_EXPORT void NextDefinedLights(); - - Standard_EXPORT Handle(V3d_Light) DefinedLight() const; - - //! Returns the structure manager associated to this viewer. - Standard_EXPORT Handle(Graphic3d_StructureManager) StructureManager() const; - - //! Returns the Selected Light. - Standard_EXPORT Handle(V3d_Light) CurrentSelectedLight() const; + Standard_EXPORT void DelLight (const Handle(V3d_Light)& theLight); + //! Updates the lights of all the views of a viewer. + Standard_EXPORT void UpdateLights(); + Standard_EXPORT Standard_Boolean IsGlobalLight (const Handle(V3d_Light)& TheLight) const; + + //! Return an iterator for defined lights. + V3d_ListOfLightIterator ActiveLightIterator() const { return V3d_ListOfLightIterator (myActiveLights); } + + //! Initializes an internal iteratator on the active Lights. + void InitActiveLights() { myActiveLightsIterator.Initialize (myActiveLights); } + + //! returns true if there are more active Light(s) to return. + Standard_Boolean MoreActiveLights() const { return myActiveLightsIterator.More(); } + + //! Go to the next active Light (if there is not, ActiveLight() will raise an exception) + void NextActiveLights() { myActiveLightsIterator.Next(); } + + const Handle(V3d_Light)& ActiveLight() const { return myActiveLightsIterator.Value(); } + +public: + + //! Return an iterator for defined lights. + V3d_ListOfLightIterator DefinedLightIterator() const { return V3d_ListOfLightIterator (myDefinedLights); } + + //! Initializes an internal iterattor on the Defined Lights. + void InitDefinedLights() { myDefinedLightsIterator.Initialize (myDefinedLights); } + //! Returns true if there are more Defined Light(s) to return. + Standard_Boolean MoreDefinedLights() const { return myDefinedLightsIterator.More(); } + + //! Go to the next Defined Light (if there is not, DefinedLight() will raise an exception) + void NextDefinedLights() { if (!myDefinedLights.IsEmpty()) myDefinedLightsIterator.Next(); } + + const Handle(V3d_Light)& DefinedLight() const { return myDefinedLightsIterator.Value(); } + +public: //! @name objects management + + //! Erase all Objects in All the views. + Standard_EXPORT void Erase() const; + + //! UnHighlight all Objects in All the views. + Standard_EXPORT void UnHighlight() const; + +public: + //! returns true if the computed mode can be used. - Standard_EXPORT Standard_Boolean ComputedMode() const; - + Standard_Boolean ComputedMode() const { return myComputedMode; } + + //! Set if the computed mode can be used. + void SetComputedMode (const Standard_Boolean theMode) { myComputedMode = theMode; } + //! returns true if by default the computed mode must be used. - Standard_EXPORT Standard_Boolean DefaultComputedMode() const; - + Standard_Boolean DefaultComputedMode() const { return myDefaultComputedMode; } + + //! Set if by default the computed mode must be used. + void SetDefaultComputedMode (const Standard_Boolean theMode) { myDefaultComputedMode = theMode; } + +public: //! @name privileged plane management + + Standard_EXPORT gp_Ax3 PrivilegedPlane() const; + + Standard_EXPORT void SetPrivilegedPlane (const gp_Ax3& thePlane); + + Standard_EXPORT void DisplayPrivilegedPlane (const Standard_Boolean theOnOff, const Quantity_Length theSize = 1); + +public: //! @name grid management + //! Activates the grid in all views of . Standard_EXPORT void ActivateGrid (const Aspect_GridType aGridType, const Aspect_GridDrawMode aGridDrawMode); @@ -383,119 +430,100 @@ public: //! defines the displacement along the plane normal. Standard_EXPORT void SetRectangularGridGraphicValues (const Quantity_Length XSize, const Quantity_Length YSize, const Quantity_Length OffSet); - //! Returns the gradient background of the view. - Standard_EXPORT Aspect_GradientBackground GetGradientBackground() const; - - //! defines default lights - - //! positional-light 0.3 0. 0. - //! directional-light V3d_XnegYposZpos - //! directional-light V3d_XnegYneg - //! ambient-light - Standard_EXPORT void SetDefaultLights(); - - //! Display grid echo at requested point in the view. Standard_EXPORT void ShowGridEcho (const Handle(V3d_View)& theView, const Graphic3d_Vertex& thePoint); - //! Temporarly hide grid echo. Standard_EXPORT void HideGridEcho (const Handle(V3d_View)& theView); - //! Add a new top-level Z layer to all managed views and get - //! its ID as value. The Z layers are controlled entirely - //! by viewer, it is not possible to add a layer to a - //! particular view. The method returns Standard_False if the layer can - //! not be created. The layer mechanism allows to display structures - //! in higher layers in overlay of structures in lower layers. - Standard_EXPORT Standard_Boolean AddZLayer (Standard_Integer& theLayerId); +public: //! @name deprecated methods - //! Remove Z layer with ID . Method returns - //! Standard_False if the layer can not be removed or doesn't exists. - //! By default, there are always default bottom-level layer that can't - //! be removed. - Standard_EXPORT Standard_Boolean RemoveZLayer (const Standard_Integer theLayerId); + Standard_DEPRECATED("This constructor is deprecated") + Standard_EXPORT V3d_Viewer (const Handle(Graphic3d_GraphicDriver)& theDriver, + const Standard_ExtString theName, + const Standard_CString theDomain = "", + const Quantity_Length theViewSize = 1000.0, + const V3d_TypeOfOrientation theViewProj = V3d_XposYnegZpos, + const Quantity_NameOfColor theViewBackground = Quantity_NOC_GRAY30, + const V3d_TypeOfVisualization theVisualization = V3d_ZBUFFER, + const V3d_TypeOfShadingModel theShadingModel = V3d_GOURAUD, + const V3d_TypeOfUpdate theUpdateMode = V3d_WAIT, + const Standard_Boolean theComputedMode = Standard_True, + const Standard_Boolean theDefaultComputedMode = Standard_True); - //! Return all Z layer ids in sequence ordered by overlay level - //! from lowest layer to highest ( foreground ). The first layer ID - //! in sequence is the default layer that can't be removed. - Standard_EXPORT void GetAllZLayers (TColStd_SequenceOfInteger& theLayerSeq) const; + //! Defines the default base colour of views attached + //! to the Viewer by supplying the type of colour + //! definition and the three component values. + Standard_DEPRECATED("This method is deprecated - SetDefaultBackgroundColor() taking Quantity_Color should be used instead") + void SetDefaultBackgroundColor (const Quantity_TypeOfColor theType, + const Quantity_Parameter theV1, + const Quantity_Parameter theV2, + const Quantity_Parameter theV3) + { + Standard_Real aV1 = theV1; + Standard_Real aV2 = theV2; + Standard_Real aV3 = theV3; + if (aV1 < 0.0) aV1 = 0.0; else if (aV1 > 1.0) aV1 = 1.0; + if (aV2 < 0.0) aV2 = 0.0; else if (aV2 > 1.0) aV2 = 1.0; + if (aV3 < 0.0) aV3 = 0.0; else if (aV3 > 1.0) aV3 = 1.0; + SetDefaultBackgroundColor (Quantity_Color (aV1, aV2, aV3, theType)); + } - //! Sets the settings for a single Z layer. - Standard_EXPORT void SetZLayerSettings (const Standard_Integer theLayerId, const Graphic3d_ZLayerSettings& theSettings); - - //! Returns the settings of a single Z layer. - Standard_EXPORT Graphic3d_ZLayerSettings ZLayerSettings (const Standard_Integer theLayerId); - - //! Return Graphic Driver instance. - Standard_EXPORT const Handle(Graphic3d_GraphicDriver)& Driver() const; - - Standard_EXPORT Standard_ExtString NextName() const; - - Standard_EXPORT Standard_CString Domain() const; - - //! Return default Rendering Parameters. - //! By default these parameters are set in a new V3d_View. - Standard_EXPORT const Graphic3d_RenderingParams& DefaultRenderingParams() const; - - //! Set default Rendering Parameters. - Standard_EXPORT void SetDefaultRenderingParams (const Graphic3d_RenderingParams& theParams); - -friend class V3d_View; -friend class V3d_Light; - - DEFINE_STANDARD_RTTIEXT(V3d_Viewer,MMgt_TShared) - -protected: - - Standard_EXPORT void IncrCount(); + Standard_DEPRECATED("This method is deprecated - DefaultBackgroundColor() without arguments should be used instead") + void DefaultBackgroundColor (const Quantity_TypeOfColor theType, Quantity_Parameter& theV1, Quantity_Parameter& theV2, Quantity_Parameter& theV3) const + { + Quantity_Color aColor = DefaultBackgroundColor(); + aColor.Values (theV1, theV2, theV3, theType) ; + } private: //! Returns the default background colour. - Standard_EXPORT Aspect_Background GetBackgroundColor() const; - + const Aspect_Background& GetBackgroundColor() const { return myBackground; } + //! Adds View in Sequence Of Views. - Standard_EXPORT void AddView (const Handle(V3d_View)& MyView); + Standard_EXPORT void AddView (const Handle(V3d_View)& theView); //! Delete View in Sequence Of Views. - Standard_EXPORT void DelView (const Handle(V3d_View)& MyView); + Standard_EXPORT void DelView (const Handle(V3d_View)& theView); //! Adds Light in Sequence Of Lights. - Standard_EXPORT void AddLight (const Handle(V3d_Light)& MyLight); + Standard_EXPORT void AddLight (const Handle(V3d_Light)& theLight); - Standard_EXPORT Standard_Boolean IsActive (const Handle(V3d_View)& aView) const; - private: - Standard_Integer myNextCount; Handle(Graphic3d_GraphicDriver) myDriver; - TCollection_ExtendedString myName; - TCollection_AsciiString myDomain; Handle(Graphic3d_StructureManager) myStructureManager; - V3d_ListOfTransient MyDefinedViews; - V3d_ListOfTransient MyActiveViews; - V3d_ListOfTransient MyDefinedLights; - V3d_ListOfTransient MyActiveLights; - Aspect_Background MyBackground; - Aspect_GradientBackground MyGradientBackground; - Standard_Real MyViewSize; - V3d_TypeOfOrientation MyViewProj; - V3d_TypeOfVisualization MyVisualization; - V3d_TypeOfShadingModel MyShadingModel; - Quantity_PlaneAngle MyDefaultAngle; - V3d_TypeOfView MyDefaultTypeOfView; + TColStd_MapOfInteger myLayerIds; + Aspect_GenId myZLayerGenId; + + V3d_ListOfView myDefinedViews; + V3d_ListOfView myActiveViews; + V3d_ListOfLight myDefinedLights; + V3d_ListOfLight myActiveLights; + + Aspect_Background myBackground; + Aspect_GradientBackground myGradientBackground; + Standard_Real myViewSize; + V3d_TypeOfOrientation myViewProj; + V3d_TypeOfVisualization myVisualization; + V3d_TypeOfShadingModel myShadingModel; + V3d_TypeOfView myDefaultTypeOfView; Graphic3d_RenderingParams myDefaultRenderingParams; - Handle(V3d_Light) MyCurrentSelectedLight; - TColStd_ListIteratorOfListOfTransient myActiveViewsIterator; - TColStd_ListIteratorOfListOfTransient myDefinedViewsIterator; - TColStd_ListIteratorOfListOfTransient myActiveLightsIterator; - TColStd_ListIteratorOfListOfTransient myDefinedLightsIterator; + + V3d_ListOfView::Iterator myActiveViewsIterator; + V3d_ListOfView::Iterator myDefinedViewsIterator; + V3d_ListOfLight::Iterator myActiveLightsIterator; + V3d_ListOfLight::Iterator myDefinedLightsIterator; + Standard_Boolean myComputedMode; Standard_Boolean myDefaultComputedMode; + gp_Ax3 myPrivilegedPlane; Handle(Graphic3d_Structure) myPlaneStructure; Standard_Boolean myDisplayPlane; Quantity_Length myDisplayPlaneLength; + Handle(V3d_RectangularGrid) myRGrid; Handle(V3d_CircularGrid) myCGrid; Aspect_GridType myGridType; @@ -504,8 +532,9 @@ private: Handle(Graphic3d_Group) myGridEchoGroup; Handle(Graphic3d_AspectMarker3d) myGridEchoAspect; Graphic3d_Vertex myGridEchoLastVert; - TColStd_MapOfInteger myLayerIds; - Aspect_GenId myZLayerGenId; + }; +DEFINE_STANDARD_HANDLE(V3d_Viewer, Standard_Transient) + #endif // _V3d_Viewer_HeaderFile diff --git a/src/V3d/V3d_Viewer_1.cxx b/src/V3d/V3d_Viewer_1.cxx deleted file mode 100644 index e1d8220d0e..0000000000 --- a/src/V3d/V3d_Viewer_1.cxx +++ /dev/null @@ -1,84 +0,0 @@ -// Copyright (c) 1999-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 -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -void V3d_Viewer::InitActiveViews() { -myActiveViewsIterator.Initialize(MyActiveViews); -} -Standard_Boolean V3d_Viewer::MoreActiveViews () const { - return myActiveViewsIterator.More(); -} -void V3d_Viewer::NextActiveViews () { - if(!MyActiveViews.IsEmpty())myActiveViewsIterator.Next(); -} -Handle(V3d_View) V3d_Viewer::ActiveView() const { - return (Handle(V3d_View)&)(myActiveViewsIterator.Value());} - -Standard_Boolean V3d_Viewer::LastActiveView() const { - return MyActiveViews.Extent() == 1;} - -Standard_Boolean V3d_Viewer::IsActive(const Handle(V3d_View)& aView) const { - return MyActiveViews.Contains(aView); -} -void V3d_Viewer::InitDefinedViews() { -myDefinedViewsIterator.Initialize(MyDefinedViews); -} -Standard_Boolean V3d_Viewer::MoreDefinedViews () const { - return myDefinedViewsIterator.More(); -} -void V3d_Viewer::NextDefinedViews () { - if(!MyDefinedViews.IsEmpty())myDefinedViewsIterator.Next(); -} -Handle(V3d_View) V3d_Viewer::DefinedView() const { - return (Handle(V3d_View)&)(myDefinedViewsIterator.Value());} - -void V3d_Viewer::InitActiveLights() { -myActiveLightsIterator.Initialize(MyActiveLights); -} -Standard_Boolean V3d_Viewer::MoreActiveLights () const { - return myActiveLightsIterator.More(); -} -void V3d_Viewer::NextActiveLights () { - myActiveLightsIterator.Next(); -} -Handle(V3d_Light) V3d_Viewer::ActiveLight() const { - return (Handle(V3d_Light)&)(myActiveLightsIterator.Value());} - -void V3d_Viewer::InitDefinedLights() { -myDefinedLightsIterator.Initialize(MyDefinedLights); -} -Standard_Boolean V3d_Viewer::MoreDefinedLights () const { - return myDefinedLightsIterator.More(); -} -void V3d_Viewer::NextDefinedLights () { - if(!MyDefinedLights.IsEmpty())myDefinedLightsIterator.Next(); -} -Handle(V3d_Light) V3d_Viewer::DefinedLight() const { - return (Handle(V3d_Light)&)(myDefinedLightsIterator.Value());} diff --git a/src/V3d/V3d_Viewer_2.cxx b/src/V3d/V3d_Viewer_2.cxx deleted file mode 100644 index df66692001..0000000000 --- a/src/V3d/V3d_Viewer_2.cxx +++ /dev/null @@ -1,126 +0,0 @@ -// Copyright (c) 1999-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 -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -void V3d_Viewer::UpdateLights() { - - for (InitActiveViews();MoreActiveViews();NextActiveViews()){ - ActiveView()->UpdateLights(); - } -} - -void V3d_Viewer::SetLightOn( const Handle(V3d_Light)& TheLight ) { - - - if(!MyActiveLights.Contains(TheLight)) { -// V3d_BadValue_Raise_if( MyActiveLights.Extent() >= MyDriver->InquireLightLimit(), -// "too many lights"); - MyActiveLights.Append(TheLight) ; - } - - for (InitActiveViews();MoreActiveViews();NextActiveViews()){ - ActiveView()->SetLightOn(TheLight);} -} - -void V3d_Viewer::SetLightOff( const Handle(V3d_Light)& TheLight ) { - - MyActiveLights.Remove(TheLight); - for (InitActiveViews();MoreActiveViews();NextActiveViews()) { - ActiveView()->SetLightOff(TheLight);} -} - - -void V3d_Viewer::SetLightOn() { - - for (InitDefinedLights();MoreDefinedLights();NextDefinedLights()) { - if(!MyActiveLights.Contains(DefinedLight())) { -// V3d_BadValue_Raise_if( MyActiveLights.Extent() >= MyDriver->InquireLightLimit(), -// "too many lights"); - MyActiveLights.Append(DefinedLight()); - for (InitActiveViews();MoreActiveViews();NextActiveViews()) { - ActiveView()->SetLightOn(DefinedLight());} - } - } -} - -void V3d_Viewer::SetLightOff() { - - for (InitActiveLights();MoreActiveLights();NextActiveLights()) { - for(InitActiveViews();MoreActiveViews();NextActiveViews()){ - ActiveView()->SetLightOff(ActiveLight());} - } - MyActiveLights.Clear(); -} - -void V3d_Viewer::SetCurrentSelectedLight(const Handle(V3d_Light)& TheLight) { - MyCurrentSelectedLight = TheLight; -} - -void V3d_Viewer::ClearCurrentSelectedLight() { - MyCurrentSelectedLight.Nullify(); -} - - -Handle(V3d_Light) V3d_Viewer::CurrentSelectedLight() const { - - return MyCurrentSelectedLight; -} - -Standard_Boolean V3d_Viewer::IsGlobalLight(const Handle(V3d_Light)& TheLight) - const { - - return MyActiveLights.Contains(TheLight); -} - - -void V3d_Viewer::AddLight( const Handle(V3d_Light)& TheLight ) { - - MyDefinedLights.Append(TheLight); -} - -void V3d_Viewer::DelLight( const Handle(V3d_Light)& TheLight ) { - - SetLightOff(TheLight); - MyDefinedLights.Remove(TheLight); -} - -void V3d_Viewer::SetDefaultLights() -{ - while (MyDefinedLights.Extent() > 0) - { - DelLight (Handle(V3d_Light)::DownCast (MyDefinedLights.First())); - } - - SetLightOn (new V3d_DirectionalLight (this, V3d_Zneg, Quantity_NOC_WHITE, Standard_True)); - SetLightOn (new V3d_AmbientLight (this)); -} diff --git a/src/V3d/V3d_Viewer_3.cxx b/src/V3d/V3d_Viewer_3.cxx index 2a5ca486eb..f131be6fd8 100644 --- a/src/V3d/V3d_Viewer_3.cxx +++ b/src/V3d/V3d_Viewer_3.cxx @@ -56,8 +56,11 @@ void V3d_Viewer::SetPrivilegedPlane(const gp_Ax3& aPlane) { myPrivilegedPlane = aPlane; Grid()->SetDrawMode(Grid()->DrawMode()); - for (InitActiveViews (); MoreActiveViews (); NextActiveViews ()) - ActiveView ()->SetGrid (myPrivilegedPlane, Grid ()); + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) + { + anActiveViewIter.Value()->SetGrid (myPrivilegedPlane, Grid()); + } + if(myDisplayPlane) DisplayPrivilegedPlane(Standard_True,myDisplayPlaneLength); else diff --git a/src/V3d/V3d_Viewer_4.cxx b/src/V3d/V3d_Viewer_4.cxx index 0d782eff3f..ab437f4d52 100644 --- a/src/V3d/V3d_Viewer_4.cxx +++ b/src/V3d/V3d_Viewer_4.cxx @@ -76,9 +76,9 @@ void V3d_Viewer::ActivateGrid (const Aspect_GridType theType, Grid()->Display(); } Grid()->Activate(); - for (InitActiveViews(); MoreActiveViews(); NextActiveViews()) + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) { - ActiveView()->SetGrid (myPrivilegedPlane, Grid()); + anActiveViewIter.Value()->SetGrid (myPrivilegedPlane, Grid()); } Update(); } @@ -92,9 +92,9 @@ void V3d_Viewer::DeactivateGrid() Grid()->Erase(); myGridType = Aspect_GT_Rectangular; Grid()->Deactivate(); - for (InitActiveViews(); MoreActiveViews(); NextActiveViews()) + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) { - ActiveView()->SetGridActivity (Standard_False); + anActiveViewIter.Value()->SetGridActivity (Standard_False); if (myGridEcho && !myGridEchoStructure.IsNull()) { @@ -141,9 +141,9 @@ void V3d_Viewer::SetRectangularGridValues (const Quantity_Length theXOrigin, const Quantity_PlaneAngle theRotationAngle) { myRGrid->SetGridValues (theXOrigin, theYOrigin, theXStep, theYStep, theRotationAngle); - for (InitActiveViews(); MoreActiveViews(); NextActiveViews()) + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) { - ActiveView()->SetGrid (myPrivilegedPlane, myRGrid); + anActiveViewIter.Value()->SetGrid (myPrivilegedPlane, myRGrid); } Update(); } @@ -177,9 +177,9 @@ void V3d_Viewer::SetCircularGridValues (const Quantity_Length theXOrigin, { myCGrid->SetGridValues (theXOrigin, theYOrigin, theRadiusStep, theDivisionNumber, theRotationAngle); - for (InitActiveViews(); MoreActiveViews(); NextActiveViews()) + for (V3d_ListOfView::Iterator anActiveViewIter (myActiveViews); anActiveViewIter.More(); anActiveViewIter.Next()) { - ActiveView()->SetGrid (myPrivilegedPlane, myCGrid); + anActiveViewIter.Value()->SetGrid (myPrivilegedPlane, myCGrid); } Update(); } diff --git a/src/ViewerTest/ViewerTest.cxx b/src/ViewerTest/ViewerTest.cxx index 113dbfda6c..f66ed35102 100644 --- a/src/ViewerTest/ViewerTest.cxx +++ b/src/ViewerTest/ViewerTest.cxx @@ -3786,9 +3786,9 @@ static int VDisplay2 (Draw_Interpretor& theDI, aDispStatus); if (toDisplayInView) { - for (aCtx->CurrentViewer()->InitDefinedViews(); aCtx->CurrentViewer()->MoreDefinedViews(); aCtx->CurrentViewer()->NextDefinedViews()) + for (V3d_ListOfViewIterator aViewIter (aCtx->CurrentViewer()->DefinedViewIterator()); aViewIter.More(); aViewIter.Next()) { - aCtx->SetViewAffinity (aShape, aCtx->CurrentViewer()->DefinedView(), Standard_False); + aCtx->SetViewAffinity (aShape, aViewIter.Value(), Standard_False); } aCtx->SetViewAffinity (aShape, ViewerTest::CurrentView(), Standard_True); } diff --git a/src/ViewerTest/ViewerTest_ViewerCommands.cxx b/src/ViewerTest/ViewerTest_ViewerCommands.cxx index 844b1fb79b..cc7a130368 100644 --- a/src/ViewerTest/ViewerTest_ViewerCommands.cxx +++ b/src/ViewerTest/ViewerTest_ViewerCommands.cxx @@ -656,8 +656,7 @@ TCollection_AsciiString ViewerTest::ViewerInit (const Standard_Integer thePxLeft else if (a3DViewer.IsNull()) { toCreateViewer = Standard_True; - TCollection_ExtendedString NameOfWindow("Viewer3D"); - a3DViewer = new V3d_Viewer(aGraphicDriver, NameOfWindow.ToExtString()); + a3DViewer = new V3d_Viewer(aGraphicDriver); a3DViewer->SetDefaultBackgroundColor (ViewerTest_DefaultBackground.FlatColor); a3DViewer->SetDefaultBgGradientColors (ViewerTest_DefaultBackground.GradientColor1, ViewerTest_DefaultBackground.GradientColor2, @@ -7631,9 +7630,9 @@ static int VLight (Draw_Interpretor& theDi, { // print lights info Standard_Integer aLightId = 0; - for (aView->InitActiveLights(); aView->MoreActiveLights(); aView->NextActiveLights(), ++aLightId) + for (V3d_ListOfLightIterator aLightIter (aView->ActiveLightIterator()); aLightIter.More(); aLightIter.Next(), ++aLightId) { - Handle(V3d_Light) aLight = aView->ActiveLight(); + Handle(V3d_Light) aLight = aLightIter.Value(); const Quantity_Color aColor = aLight->Color(); theDi << "Light" << aLightId << "\n"; switch (aLight->Type()) @@ -7747,11 +7746,11 @@ static int VLight (Draw_Interpretor& theDi, || anArgCase.IsEqual ("CLEAR")) { toCreate = Standard_False; - aView->InitActiveLights(); - while (aView->MoreActiveLights()) + for (V3d_ListOfLightIterator aLightIter (aView->ActiveLightIterator()); aLightIter.More();) { - aViewer->DelLight (aView->ActiveLight()); - aView->InitActiveLights(); + Handle(V3d_Light) aLight = aLightIter.Value(); + aViewer->DelLight (aLight); + aLightIter = aView->ActiveLightIterator(); } } else if (anArgCase.IsEqual ("AMB") @@ -7815,11 +7814,11 @@ static int VLight (Draw_Interpretor& theDi, const Standard_Integer aLightId = getLightId (theArgVec[anArgIt]); Standard_Integer aLightIt = 0; - for (aView->InitActiveLights(); aView->MoreActiveLights(); aView->NextActiveLights(), ++aLightIt) + for (V3d_ListOfLightIterator aLightIter (aView->ActiveLightIterator()); aLightIter.More(); aLightIter.Next(), ++aLightIt) { if (aLightIt == aLightId) { - aLightOld = aView->ActiveLight(); + aLightOld = aLightIter.Value(); break; } } @@ -7843,9 +7842,9 @@ static int VLight (Draw_Interpretor& theDi, const TCollection_AsciiString anArgNext (theArgVec[anArgIt]); const Standard_Integer aLightDelId = getLightId (theArgVec[anArgIt]); Standard_Integer aLightIt = 0; - for (aView->InitActiveLights(); aView->MoreActiveLights(); aView->NextActiveLights(), ++aLightIt) + for (V3d_ListOfLightIterator aLightIter (aView->ActiveLightIterator()); aLightIter.More(); aLightIter.Next(), ++aLightIt) { - aLightDel = aView->ActiveLight(); + aLightDel = aLightIter.Value(); if (aLightIt == aLightDelId) { break; diff --git a/src/XDEDRAW/XDEDRAW.cxx b/src/XDEDRAW/XDEDRAW.cxx index 21368148a1..9a425cfe7d 100644 --- a/src/XDEDRAW/XDEDRAW.cxx +++ b/src/XDEDRAW/XDEDRAW.cxx @@ -94,11 +94,6 @@ #include #include -#define ZVIEW_SIZE 1000000.0 -// avoid warnings on 'extern "C"' functions returning C++ classes -#ifdef _MSC_VER -#pragma warning(4:4190) -#endif //======================================================================= // Section: General commands @@ -486,11 +481,6 @@ static Standard_Integer show (Draw_Interpretor& di, Standard_Integer argc, const aDocViewer = TPrsStd_AISViewer::New (aRoot, ViewerTest::GetAISContext()); } - //szv:CAX-TRJ7 c2-pe-214.stp was clipped - aDocViewer->GetInteractiveContext()->CurrentViewer()->InitActiveViews(); - aDocViewer->GetInteractiveContext()->CurrentViewer()->ActiveView()->SetZSize(ZVIEW_SIZE); - //DDF::ReturnLabel(di,viewer->Label()); - // collect sequence of labels to display Handle(XCAFDoc_ShapeTool) shapes = XCAFDoc_DocumentTool::ShapeTool (aDoc->Main()); TDF_LabelSequence seq; @@ -550,10 +540,11 @@ static Standard_Integer xwd (Draw_Interpretor& di, Standard_Integer argc, const return 1; } - Handle(V3d_Viewer) viewer = IC->CurrentViewer(); - viewer->InitActiveViews(); - if ( viewer->MoreActiveViews() ) { - viewer->ActiveView()->Dump ( argv[2] ); + Handle(V3d_Viewer) aViewer = IC->CurrentViewer(); + V3d_ListOfViewIterator aViewIter = aViewer->ActiveViewIterator(); + if (aViewIter.More()) + { + aViewIter.Value()->Dump ( argv[2] ); } else { di << "Cannot find an active view in a viewer " << argv[1] << "\n";