1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
/*=========================================================================
Program: Visualization Toolkit
Module: vtkQuantizePolyDataPoints.cxx
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 "vtkQuantizePolyDataPoints.h"
#include "vtkMergePoints.h"
#include "vtkObjectFactory.h"
vtkStandardNewMacro(vtkQuantizePolyDataPoints);
//--------------------------------------------------------------------------
// Construct object with initial QFactor of 0.25
vtkQuantizePolyDataPoints::vtkQuantizePolyDataPoints()
{
this->QFactor = 0.25;
this->Tolerance = 0.0;
}
//--------------------------------------------------------------------------
void vtkQuantizePolyDataPoints::OperateOnPoint(double in[3], double out[3])
{
out[0] = floor(in[0]/this->QFactor + 0.5)*this->QFactor;
out[1] = floor(in[1]/this->QFactor + 0.5)*this->QFactor;
out[2] = floor(in[2]/this->QFactor + 0.5)*this->QFactor;
}
//-------------------------------------------------------------------------
void vtkQuantizePolyDataPoints::OperateOnBounds(double in[6], double out[6])
{
out[0] = floor(in[0]/this->QFactor + 0.5)*this->QFactor;
out[1] = floor(in[1]/this->QFactor + 0.5)*this->QFactor;
out[2] = floor(in[2]/this->QFactor + 0.5)*this->QFactor;
out[3] = floor(in[3]/this->QFactor + 0.5)*this->QFactor;
out[4] = floor(in[4]/this->QFactor + 0.5)*this->QFactor;
out[5] = floor(in[5]/this->QFactor + 0.5)*this->QFactor;
}
//--------------------------------------------------------------------------
void vtkQuantizePolyDataPoints::PrintSelf(ostream& os, vtkIndent indent)
{
this->Superclass::PrintSelf(os,indent);
os << indent << "QFactor: " << this->QFactor << "\n";
}
|