mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-12 01:30:34 +05:00
Fix of the problem with vtkRenderer::GetActors() method
This commit is contained in:
parent
55510e5ccd
commit
4e54c1cef1
@ -96,6 +96,8 @@
|
||||
#include <SVTK_ViewModel.h>
|
||||
#include <SVTK_ViewManager.h>
|
||||
|
||||
#include <VTKViewer_Algorithm.h>
|
||||
|
||||
#include <SUIT_MessageBox.h>
|
||||
#include <SUIT_ResourceMgr.h>
|
||||
#include <SUIT_FileDlg.h>
|
||||
@ -4038,7 +4040,8 @@ void SMESHGUI::storeVisualParameters (int savePoint)
|
||||
{
|
||||
if (SVTK_ViewWindow* vtkView = dynamic_cast<SVTK_ViewWindow*>(views[i]))
|
||||
{
|
||||
vtkActorCollection* allActors = vtkView->getRenderer()->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(vtkView->getRenderer()->GetActors());
|
||||
vtkActorCollection* allActors = aCopy.GetActors();
|
||||
allActors->InitTraversal();
|
||||
while (vtkActor* actor = allActors->GetNextActor())
|
||||
{
|
||||
@ -4254,7 +4257,8 @@ void SMESHGUI::restoreVisualParameters (int savePoint)
|
||||
// access later when restoring other parameters
|
||||
SVTK_ViewWindow* vtkView = (SVTK_ViewWindow*) vman->getActiveView();
|
||||
vtkRenderer* Renderer = vtkView->getRenderer();
|
||||
vtkActorCollection* theActors = Renderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(Renderer->GetActors());
|
||||
vtkActorCollection* theActors = aCopy.GetActors();
|
||||
theActors->InitTraversal();
|
||||
bool isFound = false;
|
||||
vtkActor *ac = theActors->GetNextActor();
|
||||
|
@ -61,6 +61,8 @@
|
||||
|
||||
#include <SVTK_ViewWindow.h>
|
||||
|
||||
#include <VTKViewer_Algorithm.h>
|
||||
|
||||
// SALOME KERNEL includes
|
||||
#include <SALOMEDSClient_Study.hxx>
|
||||
|
||||
@ -2206,7 +2208,8 @@ bool SMESHGUI_GroupDlg::SetAppropriateActor()
|
||||
|
||||
// iterate on all actors in current view window, search for
|
||||
// any visible actor, that belongs to group or submesh of current mesh
|
||||
vtkActorCollection *aCollection = aViewWindow->getRenderer()->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aViewWindow->getRenderer()->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
int nbItems = aCollection->GetNumberOfItems();
|
||||
for (int i=0; i<nbItems && !isActor; i++)
|
||||
{
|
||||
|
@ -50,6 +50,7 @@
|
||||
#include <LightApp_SelectionMgr.h>
|
||||
|
||||
#include <SVTK_ViewWindow.h>
|
||||
#include <VTKViewer_Algorithm.h>
|
||||
#include <VTKViewer_CellLocationsArray.h>
|
||||
|
||||
// SALOME KERNEL includes
|
||||
@ -423,7 +424,8 @@ bool SMESHGUI_NodesDlg::ClickOnApply()
|
||||
mySelectionMgr->selectedObjects( aList );
|
||||
if ( aList.Extent() != 1 ) {
|
||||
if ( SVTK_ViewWindow* aViewWindow = SMESH::GetCurrentVtkView() ) {
|
||||
vtkActorCollection *aCollection = aViewWindow->getRenderer()->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aViewWindow->getRenderer()->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while ( vtkActor *anAct = aCollection->GetNextActor() ) {
|
||||
if ( SMESH_Actor *anActor = dynamic_cast<SMESH_Actor*>( anAct ) ) {
|
||||
|
@ -49,6 +49,8 @@
|
||||
#include <SVTK_ViewModel.h>
|
||||
#include <SVTK_ViewWindow.h>
|
||||
|
||||
#include <VTKViewer_Algorithm.h>
|
||||
|
||||
#include <LightApp_SelectionMgr.h>
|
||||
#include <SalomeApp_Application.h>
|
||||
#include <SalomeApp_Study.h>
|
||||
@ -143,7 +145,8 @@ namespace SMESH
|
||||
for ( int iV = 0; iV < views.count(); ++iV ) {
|
||||
if(SVTK_ViewWindow* vtkWnd = GetVtkViewWindow(views[iV])) {
|
||||
vtkRenderer *aRenderer = vtkWnd->getRenderer();
|
||||
vtkActorCollection *actors = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *actors = aCopy.GetActors();
|
||||
for (int i = 0; i < actors->GetNumberOfItems(); ++i ) {
|
||||
// size of actors changes inside the loop
|
||||
while (SMESH_Actor *actor = dynamic_cast<SMESH_Actor*>(actors->GetItemAsObject(i)))
|
||||
@ -185,7 +188,8 @@ namespace SMESH
|
||||
for ( int iV = 0; iV < views.count(); ++iV ) {
|
||||
if(SVTK_ViewWindow* vtkWnd = GetVtkViewWindow(views[iV])) {
|
||||
vtkRenderer *aRenderer = vtkWnd->getRenderer();
|
||||
vtkActorCollection *actors = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *actors = aCopy.GetActors();
|
||||
for (int i = 0; i < actors->GetNumberOfItems(); ++i ) {
|
||||
// size of actors changes inside the loop
|
||||
while(SMESH_Actor *actor = dynamic_cast<SMESH_Actor*>(actors->GetItemAsObject(i)))
|
||||
@ -516,7 +520,8 @@ namespace SMESH
|
||||
{
|
||||
if(SVTK_ViewWindow* aViewWindow = GetVtkViewWindow(theWindow)){
|
||||
vtkRenderer *aRenderer = aViewWindow->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while(vtkActor *anAct = aCollection->GetNextActor()){
|
||||
if(SMESH_Actor *anActor = dynamic_cast<SMESH_Actor*>(anAct)){
|
||||
@ -645,7 +650,8 @@ namespace SMESH
|
||||
{
|
||||
if(SVTK_ViewWindow* aViewWindow = GetVtkViewWindow(theWnd)) {
|
||||
vtkRenderer *aRenderer = aViewWindow->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while(vtkActor *anAct = aCollection->GetNextActor())
|
||||
if(dynamic_cast<SMESH_Actor*>(anAct))
|
||||
@ -664,7 +670,8 @@ namespace SMESH
|
||||
{
|
||||
OK = true;
|
||||
vtkRenderer *aRenderer = aViewWnd->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
|
||||
switch (theAction) {
|
||||
@ -741,7 +748,8 @@ namespace SMESH
|
||||
|
||||
if( selected.Extent() == 0){
|
||||
vtkRenderer* aRenderer = aWnd->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while(vtkActor *anAct = aCollection->GetNextActor()){
|
||||
if(SMESH_Actor *anActor = dynamic_cast<SMESH_Actor*>(anAct)){
|
||||
@ -841,7 +849,8 @@ namespace SMESH
|
||||
PW);
|
||||
// update actors
|
||||
vtkRenderer* aRenderer = aVtkView->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while(vtkActor *anAct = aCollection->GetNextActor()){
|
||||
if(SMESH_Actor *anActor = dynamic_cast<SMESH_Actor*>(anAct)){
|
||||
@ -907,7 +916,8 @@ namespace SMESH
|
||||
void SetPointRepresentation(bool theIsVisible){
|
||||
if(SVTK_ViewWindow* aViewWindow = GetCurrentVtkView()){
|
||||
vtkRenderer *aRenderer = aViewWindow->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while(vtkActor *anAct = aCollection->GetNextActor()){
|
||||
if(SMESH_Actor *anActor = dynamic_cast<SMESH_Actor*>(anAct)){
|
||||
@ -925,7 +935,8 @@ namespace SMESH
|
||||
if(SVTK_ViewWindow* aWnd = GetCurrentVtkView()){
|
||||
int anIsAllPickable = (theActor == NULL);
|
||||
vtkRenderer *aRenderer = aWnd->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
while(vtkActor *anAct = aCollection->GetNextActor()){
|
||||
if(SALOME_Actor *anActor = dynamic_cast<SALOME_Actor*>(anAct)){
|
||||
@ -1135,7 +1146,8 @@ namespace SMESH
|
||||
if( SVTK_ViewWindow* aWnd = SMESH::GetCurrentVtkView() )
|
||||
{
|
||||
vtkRenderer *aRenderer = aWnd->getRenderer();
|
||||
vtkActorCollection *aCollection = aRenderer->GetActors();
|
||||
VTK::ActorCollectionCopy aCopy(aRenderer->GetActors());
|
||||
vtkActorCollection *aCollection = aCopy.GetActors();
|
||||
aCollection->InitTraversal();
|
||||
|
||||
while ( vtkActor *anAct = aCollection->GetNextActor())
|
||||
|
Loading…
Reference in New Issue
Block a user