vtkGeoTransform.h 3.27 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
/*=========================================================================

  Program:   Visualization Toolkit
  Module:    vtkGeoTransform.h

  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.

=========================================================================*/
/*-------------------------------------------------------------------------
  Copyright 2008 Sandia Corporation.
  Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
  the U.S. Government retains certain rights in this software.
-------------------------------------------------------------------------*/
20 21 22 23 24 25 26
/**
 * @class   vtkGeoTransform
 * @brief   A transformation between two geographic coordinate systems
 *
 * This class takes two geographic projections and transforms point
 * coordinates between them.
*/
27

28 29
#ifndef vtkGeoTransform_h
#define vtkGeoTransform_h
30

31
#include "vtkGeovisCoreModule.h" // For export macro
32 33 34 35
#include "vtkAbstractTransform.h"

class vtkGeoProjection;

36
class VTKGEOVISCORE_EXPORT vtkGeoTransform : public vtkAbstractTransform
37 38 39
{
public:
  static vtkGeoTransform* New();
40
  void PrintSelf( ostream& os, vtkIndent indent ) override;
41
  vtkTypeMacro(vtkGeoTransform,vtkAbstractTransform);
42

43 44 45 46
  //@{
  /**
   * The source geographic projection.
   */
47 48
  void SetSourceProjection(vtkGeoProjection* source);
  vtkGetObjectMacro(SourceProjection,vtkGeoProjection);
49
  //@}
50

51 52 53 54
  //@{
  /**
   * The target geographic projection.
   */
55 56
  void SetDestinationProjection(vtkGeoProjection* dest);
  vtkGetObjectMacro(DestinationProjection,vtkGeoProjection);
57
  //@}
58

59 60 61
  /**
   * Transform many points at once.
   */
62
  void TransformPoints( vtkPoints* src, vtkPoints* dst ) override;
63

64 65 66
  /**
   * Invert the transformation.
   */
67
  void Inverse() override;
68

69 70 71 72 73
  //@{
  /**
   * This will calculate the transformation without calling Update.
   * Meant for use only within other VTK classes.
   */
74 75
  void InternalTransformPoint( const float in[3], float out[3] ) override;
  void InternalTransformPoint( const double in[3], double out[3] ) override;
76 77 78 79 80 81 82 83 84
  //@}

  //@{
  /**
   * This will transform a point and, at the same time, calculate a
   * 3x3 Jacobian matrix that provides the partial derivatives of the
   * transformation at that point.  This method does not call Update.
   * Meant for use only within other VTK classes.
   */
85 86
  void InternalTransformDerivative( const float in[3], float out[3], float derivative[3][3] ) override;
  void InternalTransformDerivative( const double in[3], double out[3], double derivative[3][3] ) override;
87
  //@}
88

89 90 91
  /**
   * Make another transform of the same type.
   */
92
  vtkAbstractTransform* MakeTransform() override;
93 94 95

protected:
  vtkGeoTransform();
96
  ~vtkGeoTransform() override;
97 98 99 100 101 102 103

  void InternalTransformPoints( double* ptsInOut, vtkIdType numPts, int stride );

  vtkGeoProjection* SourceProjection;
  vtkGeoProjection* DestinationProjection;

private:
104 105
  vtkGeoTransform( const vtkGeoTransform& ) = delete;
  void operator = ( const vtkGeoTransform& ) = delete;
106 107
};

108
#endif // vtkGeoTransform_h