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.
 
 
 
 
 
 

97 lines
3.1 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkWarpLens.h,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.
=========================================================================*/
// .NAME vtkWarpLens - deform geometry by applying lens distortion
// .SECTION Description
// vtkWarpLens is a filter that modifies point coordinates by moving
// in accord with a lens distortion model.
#ifndef __vtkWarpLens_h
#define __vtkWarpLens_h
#include "vtkPointSetAlgorithm.h"
class VTK_GRAPHICS_EXPORT vtkWarpLens : public vtkPointSetAlgorithm
{
public:
static vtkWarpLens *New();
vtkTypeRevisionMacro(vtkWarpLens,vtkPointSetAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Specify second order symmetric radial lens distortion parameter.
// This is obsoleted by newer instance variables.
void SetKappa(double kappa);
double GetKappa();
// Description:
// Specify the center of radial distortion in pixels.
// This is obsoleted by newer instance variables.
void SetCenter(double centerX, double centerY);
double *GetCenter();
// Description:
// Specify the calibrated principal point of the camera/lens
vtkSetVector2Macro(PrincipalPoint,double);
vtkGetVectorMacro(PrincipalPoint,double,2);
// Description:
// Specify the symmetric radial distortion parameters for the lens
vtkSetMacro(K1,double);
vtkGetMacro(K1,double);
vtkSetMacro(K2,double);
vtkGetMacro(K2,double);
// Description:
// Specify the decentering distortion parameters for the lens
vtkSetMacro(P1,double);
vtkGetMacro(P1,double);
vtkSetMacro(P2,double);
vtkGetMacro(P2,double);
// Description:
// Specify the imager format width / height in mm
vtkSetMacro(FormatWidth,double);
vtkGetMacro(FormatWidth,double);
vtkSetMacro(FormatHeight,double);
vtkGetMacro(FormatHeight,double);
// Description:
// Specify the image width / height in pixels
vtkSetMacro(ImageWidth,int);
vtkGetMacro(ImageWidth,int);
vtkSetMacro(ImageHeight,int);
vtkGetMacro(ImageHeight,int);
protected:
vtkWarpLens();
~vtkWarpLens() {};
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
double PrincipalPoint[2]; // The calibrated principal point of camera/lens in mm
double K1; // Symmetric radial distortion parameters
double K2;
double P1; // Decentering distortion parameters
double P2;
double FormatWidth; // imager format width in mm
double FormatHeight; // imager format height in mm
int ImageWidth; // image width in pixels
int ImageHeight; // image height in pixels
private:
vtkWarpLens(const vtkWarpLens&); // Not implemented.
void operator=(const vtkWarpLens&); // Not implemented.
};
#endif