Cloned library of VTK-5.0.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

155 lines
5.0 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: TestMultiBlock.cxx,v $
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
// This example demonstrates how hierarchical box (uniform rectilinear)
// AMR datasets can be processed using the new vtkHierarchicalBoxDataSet class.
//
// The command line arguments are:
// -I => run in interactive mode; unless this is used, the program will
// not allow interaction and exit
// -D <path> => path to the data; the data should be in <path>/Data/
#include "vtkCamera.h"
#include "vtkCellDataToPointData.h"
#include "vtkContourFilter.h"
#include "vtkDebugLeaks.h"
#include "vtkHierarchicalDataExtractDataSets.h"
#include "vtkHierarchicalDataSetGeometryFilter.h"
#include "vtkMultiBlockPLOT3DReader.h"
#include "vtkOutlineCornerFilter.h"
#include "vtkPolyDataMapper.h"
#include "vtkProperty.h"
#include "vtkRegressionTestImage.h"
#include "vtkRenderer.h"
#include "vtkRenderWindow.h"
#include "vtkRenderWindowInteractor.h"
#include "vtkShrinkPolyData.h"
#include "vtkTestUtilities.h"
int TestMultiBlock(int argc, char* argv[])
{
// Standard rendering classes
vtkRenderer *ren = vtkRenderer::New();
vtkCamera* cam = ren->GetActiveCamera();
cam->SetPosition(-5.1828, 5.89733, 8.97969);
cam->SetFocalPoint(14.6491, -2.08677, -8.92362);
cam->SetViewUp(0.210794, 0.95813, -0.193784);
vtkRenderWindow *renWin = vtkRenderWindow::New();
renWin->AddRenderer(ren);
vtkRenderWindowInteractor *iren = vtkRenderWindowInteractor::New();
iren->SetRenderWindow(renWin);
char* xyzname =
vtkTestUtilities::ExpandDataFileName(argc, argv, "Data/mbwavelet_ascii.xyz");
char* qname =
vtkTestUtilities::ExpandDataFileName(argc, argv, "Data/mbwavelet_ascii.q");
vtkMultiBlockPLOT3DReader* reader = vtkMultiBlockPLOT3DReader::New();
reader->SetXYZFileName(xyzname);
reader->SetQFileName(qname);
reader->SetMultiGrid(1);
reader->SetBinaryFile(0);
delete[] xyzname;
delete[] qname;
// geometry filter
vtkHierarchicalDataSetGeometryFilter* geom =
vtkHierarchicalDataSetGeometryFilter::New();
geom->SetInputConnection(0, reader->GetOutputPort(0));
vtkShrinkPolyData* shrink = vtkShrinkPolyData::New();
shrink->SetShrinkFactor(0.2);
shrink->SetInputConnection(0, geom->GetOutputPort(0));
// Rendering objects
vtkPolyDataMapper* shMapper = vtkPolyDataMapper::New();
shMapper->SetInputConnection(0, shrink->GetOutputPort(0));
vtkActor* shActor = vtkActor::New();
shActor->SetMapper(shMapper);
shActor->GetProperty()->SetColor(0, 0, 1);
ren->AddActor(shActor);
// corner outline
vtkOutlineCornerFilter* ocf = vtkOutlineCornerFilter::New();
ocf->SetInputConnection(0, reader->GetOutputPort(0));
// geometry filter
vtkHierarchicalDataSetGeometryFilter* geom2 =
vtkHierarchicalDataSetGeometryFilter::New();
geom2->SetInputConnection(0, ocf->GetOutputPort(0));
// Rendering objects
vtkPolyDataMapper* ocMapper = vtkPolyDataMapper::New();
ocMapper->SetInputConnection(0, geom2->GetOutputPort(0));
vtkActor* ocActor = vtkActor::New();
ocActor->SetMapper(ocMapper);
ocActor->GetProperty()->SetColor(1, 0, 0);
ren->AddActor(ocActor);
// extract a block
vtkHierarchicalDataExtractDataSets* eds =
vtkHierarchicalDataExtractDataSets::New();
eds->SetInputConnection(0, reader->GetOutputPort(0));
eds->AddDataSet(0, 1);
// contour
vtkContourFilter* contour = vtkContourFilter::New();
contour->SetInputConnection(0, eds->GetOutputPort(0));
contour->SetValue(0, 149);
// geometry filter
vtkHierarchicalDataSetGeometryFilter* geom3 =
vtkHierarchicalDataSetGeometryFilter::New();
geom3->SetInputConnection(0, contour->GetOutputPort(0));
// Rendering objects
vtkPolyDataMapper* contMapper = vtkPolyDataMapper::New();
contMapper->SetInputConnection(0, geom3->GetOutputPort(0));
vtkActor* contActor = vtkActor::New();
contActor->SetMapper(contMapper);
contActor->GetProperty()->SetColor(1, 0, 0);
ren->AddActor(contActor);
// Standard testing code.
eds->Delete();
ocf->Delete();
geom2->Delete();
ocMapper->Delete();
ocActor->Delete();
contour->Delete();
geom3->Delete();
contMapper->Delete();
contActor->Delete();
ren->SetBackground(1,1,1);
renWin->SetSize(300,300);
renWin->Render();
int retVal = vtkRegressionTestImage( renWin );
if ( retVal == vtkRegressionTester::DO_INTERACTOR)
{
iren->Start();
}
// Cleanup
geom->Delete();
shMapper->Delete();
shActor->Delete();
ren->Delete();
renWin->Delete();
iren->Delete();
reader->Delete();
shrink->Delete();
return !retVal;
}