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.

316 lines
9.8 KiB

2 years ago
/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: BoxClipPolyData.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.
=========================================================================*/
/*----------------------------------------------------------------------------
Copyright (c) Sandia Corporation
See Copyright.txt or http://www.paraview.org/HTML/Copyright.html for details.
----------------------------------------------------------------------------*/
#include "vtkActor.h"
#include "vtkBoxClipDataSet.h"
#include "vtkCellArray.h"
#include "vtkCellData.h"
#include "vtkCutter.h"
#include "vtkDataSetSurfaceFilter.h"
#include "vtkDoubleArray.h"
#include "vtkPlane.h"
#include "vtkPolyDataMapper.h"
#include "vtkProperty.h"
#include "vtkRenderer.h"
#include "vtkRenderWindow.h"
#include "vtkRenderWindowInteractor.h"
#include "vtkSphereSource.h"
#include "vtkUnstructuredGrid.h"
#include "vtkRegressionTestImage.h"
#include "vtkSmartPointer.h"
#define VTK_CREATE(type, var) \
vtkSmartPointer<type> var = vtkSmartPointer<type>::New()
const double minpoint1[] = { -1.00002, -0.50002, -0.50002 };
const double maxpoint1[] = { -0.0511337, 0.5, 0.5 };
const double minpoint2[] = { -1.0, -1.0, -1.0 };
const double maxpoint2[] = { 1.0, 1.0, 1.0 };
const double minusx[] = { -1.0, 0.0, 0.0 };
const double minusy[] = { 0.0, -1.0, 0.0 };
const double minusz[] = { 0.0, 0.0, -1.0 };
const double plusx[] = { 1.0, 0.0, 0.0 };
const double plusy[] = { 0.0, 1.0, 0.0 };
const double plusz[] = { 0.0, 0.0, 1.0 };
const int numTriangles = 6;
const int numTrianglePoints = numTriangles*3*3;
static double trianglePointData[numTrianglePoints] = {
-2.0, -1.0, 0.0,
0.0, -1.0, 0.0,
-1.0, -0.5, 0.0,
0.0, -1.0, 0.0,
2.0, -1.0, 0.0,
1.0, -0.5, 0.0,
-1.0, 0.25, 0.0,
-2.0, -0.25, 0.0,
0.0, -0.25, 0.0,
1.0, 0.25, 0.0,
0.0, -0.25, 0.0,
2.0, -0.25, 0.0,
0.0, 0.5, 0.0,
-1.0, 1.0, 0.0,
-2.0, 0.5, 0.0,
2.0, 0.5, 0.0,
1.0, 1.0, 0.0,
0.0, 0.5, 0.0
};
//-----------------------------------------------------------------------------
const int numPolySets = 4;
static void TestPolyData(vtkPolyData *data, int num, vtkRenderWindow *renwin,
const double minBoxPoint[3],
const double maxBoxPoint[3])
{
// Set up test of normal box.
VTK_CREATE(vtkBoxClipDataSet, clipper1);
clipper1->SetInput(data);
clipper1->GenerateClippedOutputOff();
clipper1->SetBoxClip(minBoxPoint[0], maxBoxPoint[0],
minBoxPoint[1], maxBoxPoint[1],
minBoxPoint[2], maxBoxPoint[2]);
VTK_CREATE(vtkDataSetSurfaceFilter, surface1);
surface1->SetInputConnection(0, clipper1->GetOutputPort(0));
VTK_CREATE(vtkPolyDataMapper, mapper1);
mapper1->SetInputConnection(0, surface1->GetOutputPort(0));
VTK_CREATE(vtkActor, actor1);
actor1->SetMapper(mapper1);
actor1->GetProperty()->SetPointSize(3.0f);
VTK_CREATE(vtkRenderer, renderer1);
renderer1->AddActor(actor1);
renderer1->SetBackground(0.0, 0.5, 0.5);
renderer1->SetViewport(0.0, (double)num/numPolySets,
0.25, (double)(num+1)/numPolySets);
renwin->AddRenderer(renderer1);
// Set up test of normal box with generation of clipped output.
VTK_CREATE(vtkBoxClipDataSet, clipper2);
clipper2->SetInput(data);
clipper2->GenerateClippedOutputOn();
clipper2->SetBoxClip(minBoxPoint[0], maxBoxPoint[0],
minBoxPoint[1], maxBoxPoint[1],
minBoxPoint[2], maxBoxPoint[2]);
VTK_CREATE(vtkDataSetSurfaceFilter, surface2_1);
surface2_1->SetInputConnection(0, clipper2->GetOutputPort(0));
VTK_CREATE(vtkPolyDataMapper, mapper2_1);
mapper2_1->SetInputConnection(0, surface2_1->GetOutputPort(0));
VTK_CREATE(vtkActor, actor2_1);
actor2_1->SetMapper(mapper2_1);
actor2_1->GetProperty()->SetPointSize(3.0f);
VTK_CREATE(vtkDataSetSurfaceFilter, surface2_2);
surface2_2->SetInput(clipper2->GetClippedOutput());
VTK_CREATE(vtkPolyDataMapper, mapper2_2);
mapper2_2->SetInputConnection(0, surface2_2->GetOutputPort(0));
VTK_CREATE(vtkActor, actor2_2);
actor2_2->SetMapper(mapper2_2);
actor2_2->GetProperty()->SetColor(1.0, 0.5, 0.5);
actor2_2->GetProperty()->SetPointSize(3.0f);
VTK_CREATE(vtkRenderer, renderer2);
renderer2->AddActor(actor2_1);
renderer2->AddActor(actor2_2);
renderer2->SetBackground(0.0, 0.5, 0.5);
renderer2->SetViewport(0.25, (double)num/numPolySets,
0.5, (double)(num+1)/numPolySets);
renwin->AddRenderer(renderer2);
// Set up test of an oriented box.
VTK_CREATE(vtkBoxClipDataSet, clipper3);
clipper3->SetInput(data);
clipper3->GenerateClippedOutputOff();
clipper3->SetBoxClip(minusx, minBoxPoint,
minusy, minBoxPoint,
minusz, minBoxPoint,
plusx, maxBoxPoint,
plusy, maxBoxPoint,
plusz, maxBoxPoint);
VTK_CREATE(vtkDataSetSurfaceFilter, surface3);
surface3->SetInputConnection(0, clipper3->GetOutputPort(0));
VTK_CREATE(vtkPolyDataMapper, mapper3);
mapper3->SetInputConnection(0, surface3->GetOutputPort(0));
VTK_CREATE(vtkActor, actor3);
actor3->SetMapper(mapper3);
actor3->GetProperty()->SetPointSize(3.0f);
VTK_CREATE(vtkRenderer, renderer3);
renderer3->AddActor(actor3);
renderer3->SetBackground(0.0, 0.5, 0.5);
renderer3->SetViewport(0.5, (double)num/numPolySets,
0.75, (double)(num+1)/numPolySets);
renwin->AddRenderer(renderer3);
// Set up test of an oriented box with generation of clipped output.
VTK_CREATE(vtkBoxClipDataSet, clipper4);
clipper4->SetInput(data);
clipper4->GenerateClippedOutputOn();
clipper4->SetBoxClip(minusx, minBoxPoint,
minusy, minBoxPoint,
minusz, minBoxPoint,
plusx, maxBoxPoint,
plusy, maxBoxPoint,
plusz, maxBoxPoint);
VTK_CREATE(vtkDataSetSurfaceFilter, surface4_1);
surface4_1->SetInputConnection(0, clipper4->GetOutputPort(0));
VTK_CREATE(vtkPolyDataMapper, mapper4_1);
mapper4_1->SetInputConnection(0, surface4_1->GetOutputPort(0));
VTK_CREATE(vtkActor, actor4_1);
actor4_1->SetMapper(mapper4_1);
actor4_1->GetProperty()->SetPointSize(3.0f);
VTK_CREATE(vtkDataSetSurfaceFilter, surface4_2);
surface4_2->SetInput(clipper4->GetClippedOutput());
VTK_CREATE(vtkPolyDataMapper, mapper4_2);
mapper4_2->SetInputConnection(0, surface4_2->GetOutputPort(0));
VTK_CREATE(vtkActor, actor4_2);
actor4_2->SetMapper(mapper4_2);
actor4_2->GetProperty()->SetColor(1.0, 0.5, 0.5);
actor4_2->GetProperty()->SetPointSize(3.0f);
VTK_CREATE(vtkRenderer, renderer4);
renderer4->AddActor(actor4_1);
renderer4->AddActor(actor4_2);
renderer4->SetBackground(0.0, 0.5, 0.5);
renderer4->SetViewport(0.75, (double)num/numPolySets,
1.0, (double)(num+1)/numPolySets);
renwin->AddRenderer(renderer4);
}
//-----------------------------------------------------------------------------
int BoxClipPolyData(int argc, char *argv[])
{
vtkIdType i;
// The render window.
VTK_CREATE(vtkRenderWindow, renwin);
renwin->SetSize(640, 640);
VTK_CREATE(vtkRenderWindowInteractor, iren);
iren->SetRenderWindow(renwin);
// Test polygons on a sphere
VTK_CREATE(vtkSphereSource, sphere);
sphere->Update();
TestPolyData(sphere->GetOutput(), 0, renwin, minpoint1, maxpoint1);
// Test a triangle with points right on the box.
VTK_CREATE(vtkDoubleArray, trianglePointsArray);
trianglePointsArray->SetArray(trianglePointData, numTrianglePoints, 1);
trianglePointsArray->SetNumberOfComponents(3);
trianglePointsArray->SetNumberOfTuples(numTriangles*3);
VTK_CREATE(vtkPoints, trianglePoints);
trianglePoints->SetData(trianglePointsArray);
VTK_CREATE(vtkDoubleArray, triangleNormals);
triangleNormals->SetName("Normals");
triangleNormals->SetNumberOfComponents(3);
triangleNormals->SetNumberOfTuples(numTriangles);
VTK_CREATE(vtkCellArray, triangleCells);
triangleCells->Allocate(numTriangles*4);
for (i = 0; i < numTriangles; i++)
{
triangleNormals->SetTuple3(i, 0.0, 0.0, 1.0);
vtkIdType pts[3];
pts[0] = i*3+0; pts[1] = i*3+1; pts[2] = i*3+2;
triangleCells->InsertNextCell(3, pts);
}
VTK_CREATE(vtkPolyData, triangles);
triangles->SetPoints(trianglePoints);
triangles->SetPolys(triangleCells);
triangles->GetCellData()->SetNormals(triangleNormals);
TestPolyData(triangles, 1, renwin, minpoint2, maxpoint2);
// Test lines.
VTK_CREATE(vtkPolyData, sphereNoNormals);
sphereNoNormals->CopyStructure(sphere->GetOutput());
VTK_CREATE(vtkPlane, plane);
plane->SetOrigin(0.0, 0.0, 0.0);
plane->SetNormal(0.0, 0.0, 1.0);
VTK_CREATE(vtkCutter, cutter);
cutter->SetInput(sphereNoNormals);
cutter->SetCutFunction(plane);
cutter->Update();
TestPolyData(cutter->GetOutput(), 2, renwin, minpoint1, maxpoint1);
// Test verts.
VTK_CREATE(vtkPolyData, verts);
vtkPoints *vertsPoints = sphereNoNormals->GetPoints();
verts->SetPoints(vertsPoints);
VTK_CREATE(vtkCellArray, vertsCells);
vertsCells->Allocate(2*vertsPoints->GetNumberOfPoints());
for (i = 0; i < vertsPoints->GetNumberOfPoints(); i++)
{
vertsCells->InsertNextCell(1, &i);
}
verts->SetVerts(vertsCells);
TestPolyData(verts, 3, renwin, minpoint1, maxpoint1);
// Run the regression test.
renwin->Render();
int retVal = vtkRegressionTestImage(renwin);
if (retVal == vtkRegressionTester::DO_INTERACTOR)
{
iren->Start();
return 0;
}
return !retVal;
}