00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: $RCSfile: vtkWarpLens.h,v $ 00005 Language: C++ 00006 00007 00008 Copyright (c) 1993-2001 Ken Martin, Will Schroeder, Bill Lorensen 00009 All rights reserved. 00010 00011 Redistribution and use in source and binary forms, with or without 00012 modification, are permitted provided that the following conditions are met: 00013 00014 * Redistributions of source code must retain the above copyright notice, 00015 this list of conditions and the following disclaimer. 00016 00017 * Redistributions in binary form must reproduce the above copyright notice, 00018 this list of conditions and the following disclaimer in the documentation 00019 and/or other materials provided with the distribution. 00020 00021 * Neither name of Ken Martin, Will Schroeder, or Bill Lorensen nor the names 00022 of any contributors may be used to endorse or promote products derived 00023 from this software without specific prior written permission. 00024 00025 * Modified source versions must be plainly marked as such, and must not be 00026 misrepresented as being the original software. 00027 00028 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' 00029 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00030 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00031 ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR 00032 ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00033 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 00034 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00035 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00036 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 00037 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00038 00039 =========================================================================*/ 00053 #ifndef __vtkWarpLens_h 00054 #define __vtkWarpLens_h 00055 00056 #include "vtkPointSetToPointSetFilter.h" 00057 00058 class VTK_GRAPHICS_EXPORT vtkWarpLens : public vtkPointSetToPointSetFilter 00059 { 00060 public: 00061 static vtkWarpLens *New(); 00062 vtkTypeMacro(vtkWarpLens,vtkPointSetToPointSetFilter); 00063 void PrintSelf(ostream& os, vtkIndent indent); 00064 00066 00068 void SetKappa(float kappa); 00069 float GetKappa(); 00071 00073 00075 void SetCenter(float centerX, float centerY); 00076 float *GetCenter(); 00078 00080 00081 vtkSetVector2Macro(PrincipalPoint,float); 00082 vtkGetVectorMacro(PrincipalPoint,float,2); 00084 00086 00087 vtkSetMacro(K1,float); 00088 vtkGetMacro(K1,float); 00089 vtkSetMacro(K2,float); 00090 vtkGetMacro(K2,float); 00092 00094 00095 vtkSetMacro(P1,float); 00096 vtkGetMacro(P1,float); 00097 vtkSetMacro(P2,float); 00098 vtkGetMacro(P2,float); 00100 00102 00103 vtkSetMacro(FormatWidth,float); 00104 vtkGetMacro(FormatWidth,float); 00105 vtkSetMacro(FormatHeight,float); 00106 vtkGetMacro(FormatHeight,float); 00108 00110 00111 vtkSetMacro(ImageWidth,int); 00112 vtkGetMacro(ImageWidth,int); 00113 vtkSetMacro(ImageHeight,int); 00114 vtkGetMacro(ImageHeight,int); 00116 00117 00118 protected: 00119 vtkWarpLens(); 00120 ~vtkWarpLens() {}; 00121 00122 void Execute(); 00123 00124 float PrincipalPoint[2]; // The calibrated principal point of camera/lens in mm 00125 float K1; // Symmetric radial distortion parameters 00126 float K2; 00127 float P1; // Decentering distortion parameters 00128 float P2; 00129 float FormatWidth; // imager format width in mm 00130 float FormatHeight; // imager format height in mm 00131 int ImageWidth; // image width in pixels 00132 int ImageHeight; // image height in pixels 00133 private: 00134 vtkWarpLens(const vtkWarpLens&); // Not implemented. 00135 void operator=(const vtkWarpLens&); // Not implemented. 00136 }; 00137 00138 #endif