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.
176 lines
5.8 KiB
176 lines
5.8 KiB
2 years ago
|
/*=========================================================================
|
||
|
|
||
|
Program: Visualization Toolkit
|
||
|
Module: $RCSfile: vtkBooleanTexture.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 "vtkBooleanTexture.h"
|
||
|
|
||
|
#include "vtkImageData.h"
|
||
|
#include "vtkInformation.h"
|
||
|
#include "vtkInformationVector.h"
|
||
|
#include "vtkObjectFactory.h"
|
||
|
#include "vtkStreamingDemandDrivenPipeline.h"
|
||
|
#include "vtkPointData.h"
|
||
|
#include "vtkUnsignedCharArray.h"
|
||
|
|
||
|
vtkCxxRevisionMacro(vtkBooleanTexture, "$Revision: 1.44 $");
|
||
|
vtkStandardNewMacro(vtkBooleanTexture);
|
||
|
|
||
|
vtkBooleanTexture::vtkBooleanTexture()
|
||
|
{
|
||
|
this->SetNumberOfInputPorts(0);
|
||
|
this->Thickness = 0;
|
||
|
|
||
|
this->XSize = this->YSize = 12;
|
||
|
|
||
|
this->InIn[0] = this->InIn[1] = 255;
|
||
|
this->InOut[0] = this->InOut[1] = 255;
|
||
|
this->OutIn[0] = this->OutIn[1] = 255;
|
||
|
this->OutOut[0] = this->OutOut[1] = 255;
|
||
|
this->OnOn[0] = this->OnOn[1] = 255;
|
||
|
this->OnIn[0] = this->OnIn[1] = 255;
|
||
|
this->OnOut[0] = this->OnOut[1] = 255;
|
||
|
this->InOn[0] = this->InOn[1] = 255;
|
||
|
this->OutOn[0] = this->OutOn[1] = 255;
|
||
|
}
|
||
|
|
||
|
//----------------------------------------------------------------------------
|
||
|
int vtkBooleanTexture::RequestInformation (
|
||
|
vtkInformation * vtkNotUsed(request),
|
||
|
vtkInformationVector** vtkNotUsed( inputVector ),
|
||
|
vtkInformationVector *outputVector)
|
||
|
{
|
||
|
// get the info objects
|
||
|
vtkInformation* outInfo = outputVector->GetInformationObject(0);
|
||
|
|
||
|
int wExt[6];
|
||
|
wExt[0] = 0;
|
||
|
wExt[1] = this->XSize - 1;
|
||
|
wExt[2] = 0;
|
||
|
wExt[3] = this->YSize - 1;
|
||
|
wExt[4] = 0;
|
||
|
wExt[5] = 0;
|
||
|
|
||
|
outInfo->Set(vtkStreamingDemandDrivenPipeline::WHOLE_EXTENT(),wExt,6);
|
||
|
vtkDataObject::SetPointDataActiveScalarInfo(outInfo, VTK_UNSIGNED_CHAR, 2);
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
void vtkBooleanTexture::ExecuteData(vtkDataObject *outp)
|
||
|
{
|
||
|
int i, j;
|
||
|
int midILower, midJLower, midIUpper, midJUpper;
|
||
|
vtkImageData *output = this->AllocateOutputData(outp);
|
||
|
vtkUnsignedCharArray *newScalars =
|
||
|
vtkUnsignedCharArray::SafeDownCast(output->GetPointData()->GetScalars());
|
||
|
|
||
|
if (!newScalars || this->XSize*this->YSize < 1 )
|
||
|
{
|
||
|
vtkErrorMacro(<<"Bad texture (xsize,ysize) specification!");
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Compute size of various regions
|
||
|
//
|
||
|
midILower = (int) ((float)(this->XSize - 1) / 2.0 - this->Thickness / 2.0);
|
||
|
midJLower = (int) ((float)(this->YSize - 1) / 2.0 - this->Thickness / 2.0);
|
||
|
midIUpper = (int) ((float)(this->XSize - 1) / 2.0 + this->Thickness / 2.0);
|
||
|
midJUpper = (int) ((float)(this->YSize - 1) / 2.0 + this->Thickness / 2.0);
|
||
|
//
|
||
|
// Create texture map
|
||
|
//
|
||
|
int count = 0;
|
||
|
for (j = 0; j < this->YSize; j++)
|
||
|
{
|
||
|
for (i = 0; i < this->XSize; i++)
|
||
|
{
|
||
|
if (i < midILower && j < midJLower)
|
||
|
{
|
||
|
newScalars->SetValue(count,this->InIn[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->InIn[1]);
|
||
|
}
|
||
|
else if (i > midIUpper && j < midJLower)
|
||
|
{
|
||
|
newScalars->SetValue(count,this->OutIn[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->OutIn[1]);
|
||
|
}
|
||
|
else if (i < midILower && j > midJUpper)
|
||
|
{
|
||
|
newScalars->SetValue(count,this->InOut[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->InOut[1]);
|
||
|
}
|
||
|
else if (i > midIUpper && j > midJUpper)
|
||
|
{
|
||
|
newScalars->SetValue(count,this->OutOut[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->OutOut[1]);
|
||
|
}
|
||
|
else if ((i >= midILower && i <= midIUpper) && (j >= midJLower && j <= midJUpper))
|
||
|
{
|
||
|
newScalars->SetValue(count,this->OnOn[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->OnOn[1]);
|
||
|
}
|
||
|
else if ((i >= midILower && i <= midIUpper) && j < midJLower)
|
||
|
{
|
||
|
newScalars->SetValue(count,this->OnIn[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->OnIn[1]);
|
||
|
}
|
||
|
else if ((i >= midILower && i <= midIUpper) && j > midJUpper)
|
||
|
{
|
||
|
newScalars->SetValue(count,this->OnOut[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->OnOut[1]);
|
||
|
}
|
||
|
else if (i < midILower && (j >= midJLower && j <= midJUpper))
|
||
|
{
|
||
|
newScalars->SetValue(count,this->InOn[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->InOn[1]);
|
||
|
}
|
||
|
else if (i > midIUpper && (j >= midJLower && j <= midJUpper))
|
||
|
{
|
||
|
newScalars->SetValue(count,this->OutOn[0]);
|
||
|
count++;
|
||
|
newScalars->SetValue(count,this->OutOn[1]);
|
||
|
}
|
||
|
count++;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
void vtkBooleanTexture::PrintSelf(ostream& os, vtkIndent indent)
|
||
|
{
|
||
|
this->Superclass::PrintSelf(os,indent);
|
||
|
|
||
|
os << indent << "X Size: " << this->XSize << "\n";
|
||
|
os << indent << "Y Size: " << this->YSize << "\n";
|
||
|
|
||
|
os << indent << "Thickness: " << this->Thickness << "\n";
|
||
|
os << indent << "In/In: (" << this->InIn[0] << "," << this->InIn[1] << ")\n";
|
||
|
os << indent << "In/Out: (" << this->InOut[0] << "," << this->InOut[1] << ")\n";
|
||
|
os << indent << "Out/In: (" << this->OutIn[0] << "," << this->OutIn[1] << ")\n";
|
||
|
os << indent << "Out/Out: (" << this->OutOut[0] << "," << this->OutOut[1] << ")\n";
|
||
|
os << indent << "On/On: (" << this->OnOn[0] << "," << this->OnOn[1] << ")\n";
|
||
|
os << indent << "On/In: (" << this->OnIn[0] << "," << this->OnIn[1] << ")\n";
|
||
|
os << indent << "On/Out: (" << this->OnOut[0] << "," << this->OnOut[1] << ")\n";
|
||
|
os << indent << "In/On: (" << this->InOn[0] << "," << this->InOn[1] << ")\n";
|
||
|
os << indent << "Out/On: (" << this->OutOn[0] << "," << this->OutOn[1] << ")\n";
|
||
|
}
|
||
|
|