00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef INC_MI32_ASURFACE_H
00023 #define INC_MI32_ASURFACE_H
00024
00025 #include <mi32/trans2dc.h>
00026
00027 #include <rvc/raster.h>
00028
00029 class ABSTRACT_SURFACE {
00030
00031 public:
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045 virtual ~ABSTRACT_SURFACE (
00046 ) {
00047 };
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058 virtual ERRVALUE GetIntersection (
00059 const DPOINT3D& pointFrom,
00060 const DPOINT3D& pointTo,
00061 const MAPPROJPARM& mapprojparm,
00062 DPOINT3D& intersection
00063 ) const = 0;
00064
00065 };
00066
00067
00068 class RASTER_SURFACE : public ABSTRACT_SURFACE {
00069
00070 public:
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084 RASTER_SURFACE (
00085 const RVC::RASTER& raster
00086 );
00087
00088 ~RASTER_SURFACE (
00089 );
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101 ERRVALUE GetIntersection (
00102 const DPOINT3D& pointFrom,
00103 const DPOINT3D& pointTo,
00104 const MAPPROJPARM& mapprojparm,
00105 DPOINT3D& intersection
00106 ) const;
00107
00108
00109 private:
00110 #ifndef GENERATING_DOXYGEN_OUTPUT
00111
00112
00113
00114
00115
00116
00117
00118
00119 const RVC::RASTER m_Raster;
00120
00121 double m_XScale;
00122 double m_YScale;
00123 double m_ZScale;
00124 double m_ZOffset;
00125 double m_MaxElevation;
00126 double m_MinElevation;
00127 bool m_HasNull;
00128 double m_NullValue;
00129
00130 TRANS2D_MAPGEN m_TransMap;
00131
00132
00133
00134
00135
00136
00137
00138
00139
00140 #endif // GENERATING_DOXYGEN_OUTPUT
00141 };
00142
00143
00144 #endif
00145