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.

567 lines
20 KiB

2 years ago
/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: TestImageTracerWidget.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.
=========================================================================*/
#include "vtkCamera.h"
#include "vtkCommand.h"
#include "vtkExtractVOI.h"
#include "vtkGlyphSource2D.h"
#include "vtkImageActor.h"
#include "vtkImageData.h"
#include "vtkImageShiftScale.h"
#include "vtkImageStencil.h"
#include "vtkImageTracerWidget.h"
#include "vtkInteractorEventRecorder.h"
#include "vtkInteractorStyleImage.h"
#include "vtkLinearExtrusionFilter.h"
#include "vtkMapper.h"
#include "vtkPoints.h"
#include "vtkPolyData.h"
#include "vtkPolyDataToImageStencil.h"
#include "vtkRenderer.h"
#include "vtkRenderWindow.h"
#include "vtkRenderWindowInteractor.h"
#include "vtkSplineWidget.h"
#include "vtkVolume16Reader.h"
#include "vtkTestUtilities.h"
#include "vtkRegressionTestImage.h"
#include "vtkDebugLeaks.h"
char ImageTracerWidgetEventLog[] =
"# StreamVersion 1\n"
"MouseMoveEvent 322 145 0 0 0 0 b\n"
"LeftButtonPressEvent 322 145 0 0 0 0 b\n"
"LeftButtonReleaseEvent 322 145 0 0 0 0 b\n"
"MouseMoveEvent 146 166 0 0 0 0 b\n"
"LeftButtonPressEvent 146 166 0 0 0 0 b\n"
"MouseMoveEvent 154 161 0 0 0 0 b\n"
"MouseMoveEvent 162 148 0 0 0 0 b\n"
"MouseMoveEvent 169 129 0 0 0 0 b\n"
"MouseMoveEvent 168 100 0 0 0 0 b\n"
"MouseMoveEvent 161 95 0 0 0 0 b\n"
"MouseMoveEvent 131 90 0 0 0 0 b\n"
"MouseMoveEvent 113 95 0 0 0 0 b\n"
"MouseMoveEvent 77 116 0 0 0 0 b\n"
"MouseMoveEvent 68 132 0 0 0 0 b\n"
"MouseMoveEvent 67 151 0 0 0 0 b\n"
"MouseMoveEvent 73 165 0 0 0 0 b\n"
"MouseMoveEvent 89 179 0 0 0 0 b\n"
"MouseMoveEvent 98 182 0 0 0 0 b\n"
"MouseMoveEvent 111 182 0 0 0 0 b\n"
"MouseMoveEvent 118 182 0 0 0 0 b\n"
"MouseMoveEvent 130 177 0 0 0 0 b\n"
"MouseMoveEvent 134 175 0 0 0 0 b\n"
"MouseMoveEvent 144 170 0 0 0 0 b\n"
"MouseMoveEvent 146 167 0 0 0 0 b\n"
"LeftButtonReleaseEvent 146 167 0 0 0 0 b\n"
"MouseMoveEvent 132 164 0 0 0 0 b\n"
"MiddleButtonPressEvent 132 164 0 0 0 0 b\n"
"MiddleButtonReleaseEvent 132 164 0 0 0 0 b\n"
"MouseMoveEvent 131 163 0 0 0 0 b\n"
"MouseMoveEvent 127 161 0 0 0 0 b\n"
"MouseMoveEvent 120 153 0 0 0 0 b\n"
"MouseMoveEvent 110 146 0 0 0 0 b\n"
"MouseMoveEvent 104 140 0 0 0 0 b\n"
"MouseMoveEvent 101 132 0 0 0 0 b\n"
"MouseMoveEvent 99 128 0 0 0 0 b\n"
"MouseMoveEvent 95 123 0 0 0 0 b\n"
"MouseMoveEvent 91 116 0 0 0 0 b\n"
"MiddleButtonPressEvent 91 116 0 0 0 0 b\n"
"MiddleButtonReleaseEvent 91 116 0 0 0 0 b\n"
"MouseMoveEvent 95 116 0 0 0 0 b\n"
"MouseMoveEvent 105 118 0 0 0 0 b\n"
"MouseMoveEvent 115 121 0 0 0 0 b\n"
"MouseMoveEvent 124 124 0 0 0 0 b\n"
"MouseMoveEvent 136 127 0 0 0 0 b\n"
"MouseMoveEvent 144 128 0 0 0 0 b\n"
"MouseMoveEvent 150 130 0 0 0 0 b\n"
"MouseMoveEvent 154 132 0 0 0 0 b\n"
"MouseMoveEvent 157 133 0 0 0 0 b\n"
"MouseMoveEvent 161 133 0 0 0 0 b\n"
"MouseMoveEvent 164 134 0 0 0 0 b\n"
"MouseMoveEvent 167 135 0 0 0 0 b\n"
"MouseMoveEvent 169 136 0 0 0 0 b\n"
"KeyPressEvent 169 136 -128 0 0 1 Control_L\n"
"MiddleButtonPressEvent 169 136 8 0 0 0 Control_L\n"
"MiddleButtonReleaseEvent 169 136 8 0 0 0 Control_L\n"
"KeyReleaseEvent 169 136 0 0 0 1 Control_L\n"
"RightButtonPressEvent 169 136 0 0 0 0 Control_L\n"
"MouseMoveEvent 167 142 0 0 0 0 Control_L\n"
"MouseMoveEvent 164 146 0 0 0 0 Control_L\n"
"MouseMoveEvent 162 149 0 0 0 0 Control_L\n"
"MouseMoveEvent 159 152 0 0 0 0 Control_L\n"
"MouseMoveEvent 155 155 0 0 0 0 Control_L\n"
"MouseMoveEvent 152 157 0 0 0 0 Control_L\n"
"MouseMoveEvent 148 159 0 0 0 0 Control_L\n"
"MouseMoveEvent 143 163 0 0 0 0 Control_L\n"
"MouseMoveEvent 137 165 0 0 0 0 Control_L\n"
"MouseMoveEvent 133 166 0 0 0 0 Control_L\n"
"MouseMoveEvent 132 164 0 0 0 0 Control_L\n"
"RightButtonReleaseEvent 132 164 0 0 0 0 Control_L\n"
"MouseMoveEvent 133 164 0 0 0 0 Control_L\n"
"KeyPressEvent 133 164 -128 0 0 1 Control_L\n"
"RightButtonPressEvent 133 164 8 0 0 0 Control_L\n"
"RightButtonReleaseEvent 133 164 8 0 0 0 Control_L\n"
"KeyReleaseEvent 133 164 0 0 0 1 Control_L\n"
"MouseMoveEvent 133 164 0 0 0 0 Control_L\n"
"MouseMoveEvent 129 162 0 0 0 0 Control_L\n"
"MouseMoveEvent 125 160 0 0 0 0 Control_L\n"
"MouseMoveEvent 125 156 0 0 0 0 Control_L\n"
"MouseMoveEvent 122 154 0 0 0 0 Control_L\n"
"MouseMoveEvent 121 152 0 0 0 0 Control_L\n"
"KeyPressEvent 121 152 0 -128 0 1 Shift_L\n"
"RightButtonPressEvent 121 152 0 4 0 0 Shift_L\n"
"RightButtonReleaseEvent 121 152 0 4 0 0 Shift_L\n"
"KeyReleaseEvent 121 152 0 0 0 1 Shift_L\n"
"MouseMoveEvent 108 137 0 0 0 0 Shift_L\n"
"KeyPressEvent 108 137 0 -128 0 1 Shift_L\n"
"RightButtonPressEvent 108 137 0 4 0 0 Shift_L\n"
"RightButtonReleaseEvent 108 137 0 4 0 0 Shift_L\n"
"KeyReleaseEvent 108 137 0 0 0 1 Shift_L\n"
"RightButtonPressEvent 108 137 0 0 0 0 Shift_L\n"
"MouseMoveEvent 112 127 0 0 0 0 Shift_L\n"
"MouseMoveEvent 118 116 0 0 0 0 Shift_L\n"
"MouseMoveEvent 121 109 0 0 0 0 Shift_L\n"
"MouseMoveEvent 128 97 0 0 0 0 Shift_L\n"
"MouseMoveEvent 134 88 0 0 0 0 Shift_L\n"
"MouseMoveEvent 136 86 0 0 0 0 Shift_L\n"
"RightButtonReleaseEvent 136 86 0 0 0 0 Shift_L\n"
"MouseMoveEvent 122 152 0 0 0 0 Shift_L\n"
"RightButtonPressEvent 122 152 0 0 0 0 Shift_L\n"
"MouseMoveEvent 125 149 0 0 0 0 Shift_L\n"
"MouseMoveEvent 156 143 0 0 0 0 Shift_L\n"
"MouseMoveEvent 164 141 0 0 0 0 Shift_L\n"
"MouseMoveEvent 168 140 0 0 0 0 Shift_L\n"
"MouseMoveEvent 170 140 0 0 0 0 Shift_L\n"
"RightButtonReleaseEvent 170 140 0 0 0 0 Shift_L\n"
"MouseMoveEvent 129 166 0 0 0 0 Shift_L\n"
"RightButtonPressEvent 129 166 0 0 0 0 Shift_L\n"
"MouseMoveEvent 127 164 0 0 0 0 Shift_L\n"
"MouseMoveEvent 115 152 0 0 0 0 Shift_L\n"
"MouseMoveEvent 104 140 0 0 0 0 Shift_L\n"
"MouseMoveEvent 95 130 0 0 0 0 Shift_L\n"
"MouseMoveEvent 89 124 0 0 0 0 Shift_L\n"
"MouseMoveEvent 88 118 0 0 0 0 Shift_L\n"
"RightButtonReleaseEvent 88 118 0 0 0 0 Shift_L\n"
"MouseMoveEvent 168 140 0 0 0 0 Shift_L\n"
"RightButtonPressEvent 168 140 0 0 0 0 Shift_L\n"
"MouseMoveEvent 165 140 0 0 0 0 Shift_L\n"
"MouseMoveEvent 162 142 0 0 0 0 Shift_L\n"
"MouseMoveEvent 159 145 0 0 0 0 Shift_L\n"
"MouseMoveEvent 156 146 0 0 0 0 Shift_L\n"
"MouseMoveEvent 153 148 0 0 0 0 Shift_L\n"
"MouseMoveEvent 150 150 0 0 0 0 Shift_L\n"
"MouseMoveEvent 147 153 0 0 0 0 Shift_L\n"
"RightButtonReleaseEvent 147 153 0 0 0 0 Shift_L\n"
"MouseMoveEvent 137 84 0 0 0 0 Shift_L\n"
"RightButtonPressEvent 137 84 0 0 0 0 Shift_L\n"
"MouseMoveEvent 133 94 0 0 0 0 Shift_L\n"
"MouseMoveEvent 130 107 0 0 0 0 Shift_L\n"
"MouseMoveEvent 123 124 0 0 0 0 Shift_L\n"
"MouseMoveEvent 110 147 0 0 0 0 Shift_L\n"
"MouseMoveEvent 99 160 0 0 0 0 Shift_L\n"
"RightButtonReleaseEvent 99 160 0 0 0 0 Shift_L\n"
"MouseMoveEvent 337 163 0 0 0 0 Shift_L\n"
"RightButtonPressEvent 337 163 0 0 0 0 Shift_L\n"
"MouseMoveEvent 337 162 0 0 0 0 Shift_L\n"
"MouseMoveEvent 337 160 0 0 0 0 Shift_L\n"
"MouseMoveEvent 338 158 0 0 0 0 Shift_L\n"
"MouseMoveEvent 342 153 0 0 0 0 Shift_L\n"
"MouseMoveEvent 346 149 0 0 0 0 Shift_L\n"
"MouseMoveEvent 349 147 0 0 0 0 Shift_L\n"
"MouseMoveEvent 352 144 0 0 0 0 Shift_L\n"
"MouseMoveEvent 354 141 0 0 0 0 Shift_L\n"
"MouseMoveEvent 356 139 0 0 0 0 Shift_L\n"
"MouseMoveEvent 358 136 0 0 0 0 Shift_L\n"
"MouseMoveEvent 359 135 0 0 0 0 Shift_L\n"
"MouseMoveEvent 360 133 0 0 0 0 Shift_L\n"
"MouseMoveEvent 360 131 0 0 0 0 Shift_L\n"
"MouseMoveEvent 361 130 0 0 0 0 Shift_L\n"
"MouseMoveEvent 362 128 0 0 0 0 Shift_L\n"
"MouseMoveEvent 364 124 0 0 0 0 Shift_L\n"
"MouseMoveEvent 365 122 0 0 0 0 Shift_L\n"
"MouseMoveEvent 367 119 0 0 0 0 Shift_L\n"
"MouseMoveEvent 368 117 0 0 0 0 Shift_L\n"
"MouseMoveEvent 369 114 0 0 0 0 Shift_L\n"
"MouseMoveEvent 370 113 0 0 0 0 Shift_L\n"
"MouseMoveEvent 370 112 0 0 0 0 Shift_L\n"
"MouseMoveEvent 370 113 0 0 0 0 Shift_L\n"
"MouseMoveEvent 368 114 0 0 0 0 Shift_L\n"
"MouseMoveEvent 367 115 0 0 0 0 Shift_L\n"
"MouseMoveEvent 366 116 0 0 0 0 Shift_L\n"
"MouseMoveEvent 366 118 0 0 0 0 Shift_L\n"
"MouseMoveEvent 365 118 0 0 0 0 Shift_L\n"
"MouseMoveEvent 365 120 0 0 0 0 Shift_L\n"
"MouseMoveEvent 364 121 0 0 0 0 Shift_L\n"
"MouseMoveEvent 363 123 0 0 0 0 Shift_L\n"
"MouseMoveEvent 362 125 0 0 0 0 Shift_L\n"
"MouseMoveEvent 362 127 0 0 0 0 Shift_L\n"
"MouseMoveEvent 361 128 0 0 0 0 Shift_L\n"
"MouseMoveEvent 360 130 0 0 0 0 Shift_L\n"
"MouseMoveEvent 360 131 0 0 0 0 Shift_L\n"
"MouseMoveEvent 359 133 0 0 0 0 Shift_L\n"
"MouseMoveEvent 358 134 0 0 0 0 Shift_L\n"
"MouseMoveEvent 357 136 0 0 0 0 Shift_L\n"
"MouseMoveEvent 356 139 0 0 0 0 Shift_L\n"
"MouseMoveEvent 355 141 0 0 0 0 Shift_L\n"
"MouseMoveEvent 354 143 0 0 0 0 Shift_L\n"
"MouseMoveEvent 353 145 0 0 0 0 Shift_L\n"
"MouseMoveEvent 352 147 0 0 0 0 Shift_L\n"
"MouseMoveEvent 352 148 0 0 0 0 Shift_L\n"
"MouseMoveEvent 352 150 0 0 0 0 Shift_L\n"
"MouseMoveEvent 351 152 0 0 0 0 Shift_L\n"
"MouseMoveEvent 350 156 0 0 0 0 Shift_L\n"
"MouseMoveEvent 349 158 0 0 0 0 Shift_L\n"
"RightButtonReleaseEvent 349 158 0 0 0 0 Shift_L\n"
"MouseMoveEvent 381 179 0 0 0 0 Shift_L\n"
"LeftButtonPressEvent 381 179 0 0 0 0 Shift_L\n"
"MouseMoveEvent 382 179 0 0 0 0 Shift_L\n"
"MouseMoveEvent 379 179 0 0 0 0 Shift_L\n"
"MouseMoveEvent 376 177 0 0 0 0 Shift_L\n"
"MouseMoveEvent 371 174 0 0 0 0 Shift_L\n"
"MouseMoveEvent 364 167 0 0 0 0 Shift_L\n"
"MouseMoveEvent 353 156 0 0 0 0 Shift_L\n"
"MouseMoveEvent 348 146 0 0 0 0 Shift_L\n"
"MouseMoveEvent 345 139 0 0 0 0 Shift_L\n"
"MouseMoveEvent 342 129 0 0 0 0 Shift_L\n"
"MouseMoveEvent 340 121 0 0 0 0 Shift_L\n"
"MouseMoveEvent 337 111 0 0 0 0 Shift_L\n"
"MouseMoveEvent 336 101 0 0 0 0 Shift_L\n"
"MouseMoveEvent 336 98 0 0 0 0 Shift_L\n"
"MouseMoveEvent 335 95 0 0 0 0 Shift_L\n"
"MouseMoveEvent 335 93 0 0 0 0 Shift_L\n"
"MouseMoveEvent 333 91 0 0 0 0 Shift_L\n"
"MouseMoveEvent 331 87 0 0 0 0 Shift_L\n"
"MouseMoveEvent 329 85 0 0 0 0 Shift_L\n"
"MouseMoveEvent 329 84 0 0 0 0 Shift_L\n"
"MouseMoveEvent 328 84 0 0 0 0 Shift_L\n"
"LeftButtonReleaseEvent 328 84 0 0 0 0 Shift_L\n"
;
// Callback for the tracer interaction
class vtkITWCallback : public vtkCommand
{
public:
static vtkITWCallback *New()
{ return new vtkITWCallback; }
virtual void Execute(vtkObject *caller, unsigned long, void*)
{
vtkImageTracerWidget *tracerWidget =
reinterpret_cast<vtkImageTracerWidget*>(caller);
if(!tracerWidget) { return; }
int closed = tracerWidget->IsClosed();
SplineWidget->SetClosed(closed);
if (!closed)
{
Actor->SetInput(Extract->GetOutput());
}
int npts = tracerWidget->GetNumberOfHandles();
if (npts < 2) { return; }
tracerWidget->GetPath(PathPoly);
vtkPoints* points = PathPoly->GetPoints();
if (!points){ return; }
SplineWidget->InitializeHandles(points);
if (closed)
{
SplineWidget->GetPolyData(SplinePoly);
Stencil->Update();
Actor->SetInput(Stencil->GetOutput());
}
}
vtkITWCallback():SplineWidget(0),Actor(0),Stencil(0),Extract(0),
PathPoly(0),SplinePoly(0){}
vtkSplineWidget *SplineWidget;
vtkImageActor *Actor;
vtkImageStencil *Stencil;
vtkExtractVOI *Extract;
vtkPolyData *PathPoly;
vtkPolyData *SplinePoly;
};
// Callback for the spline interaction.
// Note: this callback has to have a name different from that already
// used in another test: see TestSplineWidget.cxx!
class vtkSW2Callback : public vtkCommand
{
public:
static vtkSW2Callback *New()
{ return new vtkSW2Callback; }
virtual void Execute(vtkObject *caller, unsigned long, void*)
{
vtkSplineWidget *splineWidget =
reinterpret_cast<vtkSplineWidget*>(caller);
if(!splineWidget) { return; }
int npts = splineWidget->GetNumberOfHandles();
int closed = splineWidget->IsClosed();
Points->Reset();
for (int i = 0; i < npts; ++i)
{
Points->InsertNextPoint(splineWidget->GetHandlePosition(i));
}
if (closed)
{
if (TracerWidget->GetAutoClose())
{
Points->InsertNextPoint(splineWidget->GetHandlePosition(0));
}
splineWidget->GetPolyData(SplinePoly);
Stencil->Update();
Actor->SetInput(Stencil->GetOutput());
}
TracerWidget->InitializeHandles(Points);
}
vtkSW2Callback():Points(0),TracerWidget(0),Actor(0),Stencil(0),SplinePoly(0){}
vtkPoints *Points;
vtkImageTracerWidget *TracerWidget;
vtkImageActor *Actor;
vtkImageStencil *Stencil;
vtkPolyData *SplinePoly;
};
int TestImageTracerWidget( int argc, char *argv[] )
{
char* fname = vtkTestUtilities::ExpandDataFileName(argc, argv, "Data/headsq/quarter");
// Increase polygon offsets to support some OpenGL drivers
vtkMapper::SetResolveCoincidentTopologyToPolygonOffset();
vtkMapper::SetResolveCoincidentTopologyPolygonOffsetParameters(10,10);
// Start by loading some data.
//
vtkVolume16Reader* v16 = vtkVolume16Reader::New();
v16->SetDataDimensions(64, 64);
v16->SetDataByteOrderToLittleEndian();
v16->SetImageRange(1, 93);
v16->SetDataSpacing(3.2, 3.2, 1.5);
v16->SetFilePrefix(fname);
v16->ReleaseDataFlagOn();
v16->SetDataMask(0x7fff);
v16->Update();
delete[] fname;
vtkRenderer* ren1 = vtkRenderer::New();
vtkRenderer* ren2 = vtkRenderer::New();
vtkRenderWindow* renWin = vtkRenderWindow::New();
renWin->AddRenderer(ren1);
renWin->AddRenderer(ren2);
vtkInteractorStyleImage* interactorStyle = vtkInteractorStyleImage::New();
vtkRenderWindowInteractor* iren = vtkRenderWindowInteractor::New();
iren->SetInteractorStyle(interactorStyle);
iren->SetRenderWindow(renWin);
double range[2];
v16->GetOutput()->GetScalarRange(range);
vtkImageShiftScale* shifter = vtkImageShiftScale::New();
shifter->SetShift(-1.0*range[0]);
shifter->SetScale(255.0/(range[1]-range[0]));
shifter->SetOutputScalarTypeToUnsignedChar();
shifter->SetInputConnection(v16->GetOutputPort());
shifter->ReleaseDataFlagOff();
shifter->Update();
// Display a y-z plane.
//
vtkImageActor* imageActor1 = vtkImageActor::New();
imageActor1->SetInput(shifter->GetOutput());
imageActor1->VisibilityOn();
imageActor1->SetDisplayExtent(31, 31, 0, 63, 0, 92);
imageActor1->InterpolateOff();
vtkExtractVOI* extract = vtkExtractVOI::New();
extract->SetVOI(imageActor1->GetDisplayExtent());
extract->SetSampleRate(1, 1, 1);
extract->SetInputConnection(shifter->GetOutputPort());
extract->ReleaseDataFlagOff();
vtkImageActor* imageActor2 = vtkImageActor::New();
imageActor2->SetInput(extract->GetOutput());
imageActor2->VisibilityOn();
imageActor2->SetDisplayExtent(extract->GetVOI());
imageActor2->InterpolateOff();
// Set up the image tracer widget
//
vtkImageTracerWidget* imageTracerWidget = vtkImageTracerWidget::New();
imageTracerWidget->SetDefaultRenderer(ren1);
imageTracerWidget->SetCaptureRadius(1.5);
imageTracerWidget->GetGlyphSource()->SetColor(1, 0, 0);
imageTracerWidget->GetGlyphSource()->SetScale(3.0);
imageTracerWidget->GetGlyphSource()->SetRotationAngle(45.0);
imageTracerWidget->GetGlyphSource()->Modified();
imageTracerWidget->ProjectToPlaneOn();
imageTracerWidget->SetProjectionNormalToXAxes();
imageTracerWidget->SetProjectionPosition(imageActor1->GetBounds()[0]);
imageTracerWidget->SetViewProp(imageActor1);
imageTracerWidget->SetInput(shifter->GetOutput());
imageTracerWidget->SetInteractor(iren);
imageTracerWidget->PlaceWidget();
imageTracerWidget->SnapToImageOff();
imageTracerWidget->AutoCloseOn();
// Set up a vtkSplineWidget in the second renderer and have
// its handles set by the tracer widget.
//
vtkSplineWidget* splineWidget = vtkSplineWidget::New();
splineWidget->SetCurrentRenderer(ren2);
splineWidget->SetDefaultRenderer(ren2);
splineWidget->SetInput(extract->GetOutput());
splineWidget->SetInteractor(iren);
splineWidget->PlaceWidget(imageActor2->GetBounds());
splineWidget->ProjectToPlaneOn();
splineWidget->SetProjectionNormalToXAxes();
splineWidget->SetProjectionPosition(imageActor2->GetBounds()[0]);
vtkPolyData* pathPoly = vtkPolyData::New();
vtkPoints* points = vtkPoints::New();
vtkPolyData* splinePoly = vtkPolyData::New();
// Set up a pipleline to demonstrate extraction of a 2D
// region of interest.
//
vtkLinearExtrusionFilter* extrude = vtkLinearExtrusionFilter::New();
extrude->SetInput(splinePoly);
extrude->SetScaleFactor(1);
extrude->SetExtrusionTypeToNormalExtrusion();
extrude->SetVector(1, 0, 0);
vtkPolyDataToImageStencil* dataToStencil = vtkPolyDataToImageStencil::New();
dataToStencil->SetInputConnection(extrude->GetOutputPort());
vtkImageStencil* stencil = vtkImageStencil::New();
stencil->SetInputConnection(extract->GetOutputPort());
stencil->SetStencil(dataToStencil->GetOutput());
stencil->ReverseStencilOff();
stencil->SetBackgroundValue(128);
// Set up callbacks for widget interactions.
//
vtkITWCallback* itwCallback = vtkITWCallback::New();
itwCallback->SplineWidget = splineWidget;
itwCallback->Actor = imageActor2;
itwCallback->Stencil = stencil;
itwCallback->Extract = extract;
itwCallback->PathPoly = pathPoly;
itwCallback->SplinePoly = splinePoly;
imageTracerWidget->AddObserver(vtkCommand::EndInteractionEvent,itwCallback);
vtkSW2Callback* swCallback = vtkSW2Callback::New();
swCallback->Points = points;
swCallback->TracerWidget = imageTracerWidget;
swCallback->Actor = imageActor2;
swCallback->Stencil = stencil;
swCallback->SplinePoly = splinePoly;
splineWidget->AddObserver(vtkCommand::EndInteractionEvent,swCallback);
ren1->SetBackground(0.4, 0.4, 0.5);
ren1->SetViewport(0, 0, 0.5, 1);
ren1->AddViewProp(imageActor1);
ren2->SetBackground(0.5, 0.4, 0.4);
ren2->SetViewport(0.5, 0, 1, 1);
ren2->AddViewProp(imageActor2);
ren1->ResetCamera();
ren2->ResetCamera();
renWin->SetSize(480, 240);
imageTracerWidget->On();
splineWidget->On();
vtkCamera* cam = ren1->GetActiveCamera();
cam->SetViewUp(0, 1, 0);
cam->Azimuth(270);
cam->Roll(270);
cam->Dolly(1.7);
ren1->ResetCameraClippingRange();
cam = ren2->GetActiveCamera();
cam->SetViewUp(0, 1, 0);
cam->Azimuth(270);
cam->Roll(270);
cam->Dolly(1.7);
ren2->ResetCameraClippingRange();
vtkInteractorEventRecorder *recorder = vtkInteractorEventRecorder::New();
recorder->SetInteractor(iren);
recorder->ReadFromInputStringOn();
recorder->SetInputString(ImageTracerWidgetEventLog);
iren->Initialize();
renWin->Render();
recorder->Play();
// Remove the observers so we can go interactive. Without this the "-I"
// testing option fails.
recorder->Off();
int retVal = vtkRegressionTestImage( renWin );
if ( retVal == vtkRegressionTester::DO_INTERACTOR)
{
iren->Start();
}
// Clean up
//
recorder->Off();
recorder->Delete();
v16->Delete();
shifter->Delete();
extract->Delete();
extrude->Delete();
dataToStencil->Delete();
stencil->Delete();
imageActor1->Delete();
imageActor2->Delete();
pathPoly->Delete();
points->Delete();
splinePoly->Delete();
imageTracerWidget->RemoveObserver(itwCallback);
imageTracerWidget->Delete();
itwCallback->Delete();
splineWidget->RemoveObserver(swCallback);
splineWidget->Delete();
swCallback->Delete();
interactorStyle->Delete();
iren->Delete();
renWin->Delete();
ren1->Delete();
ren2->Delete();
return !retVal;
}