00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef NOISE_MODEL_SPHERE_H
00024 #define NOISE_MODEL_SPHERE_H
00025
00026 #include <assert.h>
00027 #include "../module/modulebase.h"
00028
00029 namespace CS {
00030 namespace Math {
00031 namespace Noise {
00032 namespace Model {
00033
00036
00039
00056 class CS_CRYSTALSPACE_EXPORT Sphere
00057 {
00058
00059 public:
00060
00062 Sphere ();
00063
00068 Sphere (const CS::Math::Noise::Module::Module& module);
00069
00076 const CS::Math::Noise::Module::Module& GetModule () const
00077 {
00078 assert (m_pModule != NULL);
00079 return *m_pModule;
00080 }
00081
00101 double GetValue (double lat, double lon) const;
00102
00110 void SetModule (const CS::Math::Noise::Module::Module& module)
00111 {
00112 m_pModule = &module;
00113 }
00114
00115 private:
00116
00118 const CS::Math::Noise::Module::Module* m_pModule;
00119
00120 };
00121
00123
00125
00126 }
00127 }
00128 }
00129 }
00130
00131 #endif