[80a6a52] | 1 | #pragma once
|
---|
| 2 |
|
---|
| 3 | #include <mars_calc.h>
|
---|
| 4 |
|
---|
| 5 | #include "geomorph.h"
|
---|
| 6 | #include "gwutil.h"
|
---|
| 7 | #include "linalgadapt.h"
|
---|
| 8 | #include "gmregistry.h"
|
---|
| 9 | #include "fluidyn.h"
|
---|
| 10 | #include "geoworld.h"
|
---|
| 11 |
|
---|
| 12 | namespace geoworld
|
---|
| 13 | {
|
---|
| 14 | class VolcanoGM : public HeightMapGeoMorph, public BoundedGeoMorph
|
---|
| 15 | {
|
---|
| 16 | private:
|
---|
| 17 | typedef mars::GaussianFn <float> ConeFn;
|
---|
| 18 | typedef mars::ParabolicFn <float, +1> CalderaFn;
|
---|
| 19 | typedef mars::MidpointDisplacementGrid< float > FlowPerturbation;
|
---|
| 20 |
|
---|
| 21 | typedef mars::SolutionEquation< float, ConeFn, CalderaFn > ConeCalderaSolnEq;
|
---|
| 22 | typedef mars::BisectMethod <float, ConeCalderaSolnEq, 10> ConeCalderaSolver;
|
---|
| 23 | typedef VectorTag< float >::V3 Vector3;
|
---|
| 24 | typedef VectorTag< float >::V2 Vector2;
|
---|
| 25 |
|
---|
| 26 | typedef mars::ParabolicFn<float, -1> EaseInFn; // Used for tapering the flow line
|
---|
| 27 | typedef mars::ParabolicFn<float, -1> EaseOutFn; // Used for tapering the flow line
|
---|
| 28 |
|
---|
| 29 | class ConeZone : public geoworld::CylindricalZone <ConeZone>
|
---|
| 30 | {
|
---|
| 31 | private:
|
---|
| 32 | class Intersect
|
---|
| 33 | {
|
---|
| 34 | public:
|
---|
| 35 | const mars::Magnitudinal< float > val;
|
---|
| 36 | const geoworld::TaperFn taper;
|
---|
| 37 | const float outside;
|
---|
| 38 |
|
---|
| 39 | Intersect ()
|
---|
| 40 | : val(0), outside(0) {}
|
---|
| 41 | Intersect (const mars::Magnitudinal< float > & val, const float fScale, const float fFalloff)
|
---|
| 42 | : val(val), taper(geoworld::TaperFn::createTaperFn(fFalloff * fScale, val)), outside(fFalloff * fScale + val) {}
|
---|
| 43 |
|
---|
| 44 | inline Intersect & operator = (const Intersect & copy)
|
---|
| 45 | {
|
---|
| 46 | const_cast< mars::Magnitudinal< float > & > (val) = copy.val;
|
---|
| 47 | const_cast< geoworld::TaperFn & > (taper) = copy.taper;
|
---|
| 48 | const_cast< float & > (outside) = copy.outside;
|
---|
| 49 | return *this;
|
---|
| 50 | }
|
---|
| 51 | } _intersect;
|
---|
| 52 |
|
---|
| 53 | inline float area (const float fUntil) const
|
---|
| 54 | { return cone.f2(fUntil) - cone.f2(_intersect.val) + caldera.f2(_intersect.val); }
|
---|
| 55 |
|
---|
| 56 | inline static Intersect createIntersect (const ConeFn & cone, const CalderaFn & caldera, const float fFalloffFactor)
|
---|
| 57 | { return Intersect(ConeCalderaSolver ::solve(ConeCalderaSolnEq(cone, caldera), 0, cone.scale *2), cone.scale, fFalloffFactor); }
|
---|
| 58 |
|
---|
| 59 | public:
|
---|
| 60 | const ConeFn cone;
|
---|
| 61 | const CalderaFn caldera;
|
---|
| 62 | const Vector2 delta;
|
---|
| 63 | const float falloff;
|
---|
| 64 |
|
---|
| 65 | ConeZone () : falloff(0) {}
|
---|
| 66 | ConeZone (const ConeFn & cone, const CalderaFn & caldera, const float fFalloffFactor, const Vector2 & delta = Vector2())
|
---|
| 67 | : cone(cone), caldera(caldera), delta(delta), falloff(fFalloffFactor),
|
---|
| 68 | _intersect(createIntersect(cone, caldera, fFalloffFactor))
|
---|
| 69 | {}
|
---|
| 70 |
|
---|
| 71 | inline ConeZone & operator = (const ConeZone & copy)
|
---|
| 72 | {
|
---|
| 73 | const_cast< ConeFn & > (cone) = copy.cone;
|
---|
| 74 | const_cast< CalderaFn & > (caldera) = copy.caldera;
|
---|
| 75 | const_cast< Vector2 & > (delta) = copy.delta;
|
---|
| 76 | const_cast< float & > (falloff) = copy.falloff;
|
---|
| 77 | _intersect = copy._intersect;
|
---|
| 78 | return *this;
|
---|
| 79 | }
|
---|
| 80 | inline mars::ObjectStream & operator << (mars::ObjectStream & ins)
|
---|
| 81 | {
|
---|
| 82 | float fScale, fConeAmplitude, fConeBroadness, fCalderaBroadness, fCalderaDepth;
|
---|
| 83 |
|
---|
| 84 | ins >> fScale >> fConeAmplitude >> fConeBroadness >> fCalderaBroadness >> fCalderaDepth
|
---|
| 85 | >> const_cast< float & > (falloff)
|
---|
| 86 | >> const_cast< Vector2 & > (delta);
|
---|
| 87 | const_cast< ConeFn & > (cone) = ConeFn(fScale, fConeAmplitude, fConeBroadness);
|
---|
| 88 | const_cast< CalderaFn & > (caldera) = CalderaFn(fScale, fCalderaBroadness, fCalderaDepth);
|
---|
| 89 | _intersect = createIntersect(cone, caldera, falloff);
|
---|
| 90 | return ins;
|
---|
| 91 | }
|
---|
| 92 | inline mars::ObjectStream & operator >> (mars::ObjectStream & outs) const
|
---|
| 93 | {
|
---|
| 94 | outs << cone.scale << cone.amplitude << cone.broadness << caldera.broadness << caldera.depth << falloff << delta;
|
---|
| 95 | return outs;
|
---|
| 96 | }
|
---|
| 97 |
|
---|
| 98 | inline float taper (const float x, const float y) const
|
---|
| 99 | { return _intersect.taper.f(x, y); }
|
---|
| 100 |
|
---|
| 101 | inline const mars::Magnitudinal< float > & getIntersect() const
|
---|
| 102 | { return _intersect.val; }
|
---|
| 103 |
|
---|
| 104 | inline float full (const float frDepth) const
|
---|
| 105 | { return caldera.f(0) + (cone.f(0) - caldera.f(0)) * frDepth; }
|
---|
| 106 | inline float outside () const { return _intersect.outside; }
|
---|
| 107 | inline float inside () const { return 0; }
|
---|
| 108 | inline float downside (const float x, const float y) const { return 0; }
|
---|
| 109 | inline float upside (const float x, const float y) const { return std::min(cone.f(x, y), caldera.f(x, y)); }
|
---|
| 110 | inline float area () const { return area(_intersect.outside); }
|
---|
| 111 | } _czone;
|
---|
| 112 |
|
---|
| 113 | GWSurfacePos
|
---|
| 114 | _ptOrigin;
|
---|
| 115 | float _frCalderaFull;
|
---|
| 116 | mars::RangeX< float >
|
---|
| 117 | _mmfInnerConeRelativeScale,
|
---|
| 118 | _mmfInnerConeBroadness,
|
---|
| 119 | _mmfInnerConeAmplitude,
|
---|
| 120 | _mmfInnerCalderaBroadness,
|
---|
| 121 | _mmfrInnerCalderaDepthRatio,
|
---|
| 122 | _mmfrInnerConeDisplaceRatio;
|
---|
| 123 |
|
---|
| 124 | mars::BBox< long > _bbox;
|
---|
| 125 |
|
---|
| 126 | typedef std::vector< ConeZone > InnersList;
|
---|
| 127 | InnersList _inners;
|
---|
| 128 |
|
---|
| 129 | class FluiDynQueryBridge : public fldyn::IQueryBridge <FluiDynQueryBridge, FieldReal, GeoHeightMap::Precision>
|
---|
| 130 | {
|
---|
| 131 | private:
|
---|
| 132 | const IGeoWorldAccessor * _pAccessor;
|
---|
| 133 | const GMScalarField * _pfsDensity;
|
---|
| 134 | const GWSurfacePos _ptOffset;
|
---|
| 135 |
|
---|
| 136 | public:
|
---|
| 137 | inline FluiDynQueryBridge (const IGeoWorldAccessor * pAccessor, const GWSurfacePos & ptOffset)
|
---|
| 138 | : _pAccessor (pAccessor), _pfsDensity(pAccessor->queryField(FT_Density)), _ptOffset(ptOffset) {}
|
---|
| 139 |
|
---|
| 140 | inline DensityPrecision density (const GeoHeightMap::Precision x, const GeoHeightMap::Precision y, const GeoHeightMap::Precision z) const
|
---|
| 141 | { return (*_pfsDensity) (x + _ptOffset.x, y + _ptOffset.y, z); }
|
---|
| 142 | inline DensityPrecision density (const GeoHeightMap::Precision x, const GeoHeightMap::Precision y) const
|
---|
| 143 | { return (*_pfsDensity) (x + _ptOffset.x, y + _ptOffset.y, (*_pAccessor)(x + _ptOffset.x, y + _ptOffset.y)); }
|
---|
| 144 | inline GeoHeightMap::Precision elevation (const unsigned int x, const unsigned int y) const
|
---|
| 145 | { return _pAccessor->mean(x + _ptOffset.x, y + _ptOffset.y); }
|
---|
| 146 | };
|
---|
| 147 |
|
---|
| 148 | class LavaFlowData
|
---|
| 149 | {
|
---|
| 150 | public:
|
---|
| 151 | GeoHeightMap::View & view;
|
---|
| 152 | GeoHeightMap hmbb, hmbbb;
|
---|
| 153 |
|
---|
| 154 | LavaFlowData (GeoHeightMap::View * pView)
|
---|
| 155 | : view(*pView), hmbb(*pView), hmbbb(*pView) {}
|
---|
| 156 | ~LavaFlowData()
|
---|
| 157 | { view << hmbbb; }
|
---|
| 158 | };
|
---|
| 159 |
|
---|
| 160 | typedef fldyn::ChannelSet <FluiDynQueryBridge, float, typename GeoHeightMap::Precision, LavaFlowData> ChannelSetType;
|
---|
| 161 |
|
---|
| 162 | class MyChannelSet : public ChannelSetType
|
---|
| 163 | {
|
---|
| 164 | private:
|
---|
| 165 | class HumpyBevelFn
|
---|
| 166 | {
|
---|
| 167 | private:
|
---|
| 168 | const float _fBL2;
|
---|
| 169 |
|
---|
| 170 | inline static float createBL2 () { return 1-(1/exp(1.0f)); }
|
---|
| 171 |
|
---|
| 172 | public:
|
---|
| 173 | const float amplitude;
|
---|
| 174 |
|
---|
| 175 | HumpyBevelFn ()
|
---|
| 176 | : _fBL2(createBL2()), amplitude(0) {}
|
---|
| 177 | HumpyBevelFn(const float amplitude)
|
---|
| 178 | : _fBL2(createBL2()), amplitude(amplitude) {}
|
---|
| 179 |
|
---|
| 180 | inline const float f (const float x) const
|
---|
| 181 | {
|
---|
| 182 | using namespace mars;
|
---|
| 183 | return GaussianFn< float >::f(x, 1.0f, 0.5f * GaussianFn< float >::f(x, 1.0f, _fBL2, amplitude, 0.0f), amplitude, 0.0f);
|
---|
| 184 | }
|
---|
| 185 | };
|
---|
| 186 |
|
---|
| 187 | class FlowBevelFn : public mars::CacheFnProxy< float, HumpyBevelFn >
|
---|
| 188 | {
|
---|
| 189 | private:
|
---|
| 190 | static inline CacheFnProxy createCacheFnProxy (const float fAmplitude, const unsigned short nResolution)
|
---|
| 191 | { return CacheFnProxy(HumpyBevelFn(fAmplitude), 0, 1, nResolution); }
|
---|
| 192 |
|
---|
| 193 | public:
|
---|
| 194 | const float amplitude;
|
---|
| 195 |
|
---|
| 196 | FlowBevelFn (const unsigned short nResolution, const float fAmplitude)
|
---|
| 197 | : CacheFnProxy(createCacheFnProxy(fAmplitude, nResolution)), amplitude(fAmplitude) {}
|
---|
| 198 | FlowBevelFn (const float fMaxRadius, const float fAmplitude)
|
---|
| 199 | : CacheFnProxy(createCacheFnProxy(fAmplitude, static_cast< unsigned short > (ceil(fMaxRadius)))), amplitude(fAmplitude) {}
|
---|
| 200 | } * _pfnBevel;
|
---|
| 201 |
|
---|
| 202 | class WaveFn : private mars::GaussianFn< float >
|
---|
| 203 | {
|
---|
| 204 | private:
|
---|
| 205 | float _fScale;
|
---|
| 206 |
|
---|
| 207 | inline static GaussianFn< float > createGaussian (const float fViscosity)
|
---|
| 208 | { return GaussianFn(1.0f, 1.0f / fViscosity, 1.0f/3.0f, 0.0f); }
|
---|
| 209 |
|
---|
| 210 | public:
|
---|
| 211 | const float waves, wavesize, perturbance, waveamplitude, viscosity;
|
---|
| 212 |
|
---|
| 213 | WaveFn ()
|
---|
| 214 | : waves(0), wavesize(0), perturbance(0), waveamplitude(0), viscosity(0), _fScale(0) {}
|
---|
| 215 | WaveFn (
|
---|
| 216 | const float frWaveSize,
|
---|
| 217 | const float fWaveAmplitude,
|
---|
| 218 | const float fViscosity,
|
---|
| 219 | const float frPerturbance,
|
---|
| 220 | const float fScale = 1.0f
|
---|
| 221 | )
|
---|
| 222 | : GaussianFn(createGaussian(fViscosity)), viscosity(fViscosity), _fScale(fScale), waves(1.0f / frWaveSize), wavesize(frWaveSize),
|
---|
| 223 | perturbance (frPerturbance), waveamplitude(fWaveAmplitude)
|
---|
| 224 | {}
|
---|
| 225 |
|
---|
| 226 | // r : Distance from spine (radi)
|
---|
| 227 | // t : The total distance traveled thus-far in the current spline
|
---|
| 228 | // rT : The total radius of the flow
|
---|
| 229 | inline float f (const float r, const float t, const float rT, const FlowPerturbation & perturb) const
|
---|
| 230 | {
|
---|
| 231 | // TODO: Externalize a wave amplitude parameter, right now depends on pre-configured scale
|
---|
| 232 | // TODO: Scale parameter isn't used, always 1.0, causes perturbance to become dependent on actual scale to have any real effect
|
---|
| 233 | return cosf(
|
---|
| 234 | (
|
---|
| 235 | (
|
---|
| 236 | t
|
---|
| 237 | - GaussianFn::f(r / rT) * rT // Cancels broadness feature of Gaussian
|
---|
| 238 | + perturb(
|
---|
| 239 | mars::RNDi(r), // TODO: Verify use of RNDi
|
---|
| 240 | mars::RNDi(t)
|
---|
| 241 | ) * perturbance
|
---|
| 242 | ) / static_cast< float > (mars::PI) * waves
|
---|
| 243 | ) / _fScale
|
---|
| 244 | ) * waveamplitude / 2.0f * _fScale;
|
---|
| 245 | }
|
---|
| 246 |
|
---|
| 247 | mars::ObjectStream & operator >> (mars::ObjectStream & outs) const
|
---|
| 248 | { return outs << _fScale << waves << wavesize << perturbance << waveamplitude << viscosity; }
|
---|
| 249 |
|
---|
| 250 | mars::ObjectStream & operator << (mars::ObjectStream & ins)
|
---|
| 251 | {
|
---|
| 252 | ins
|
---|
| 253 | >> _fScale
|
---|
| 254 | >> const_cast< float & > (waves)
|
---|
| 255 | >> const_cast< float & > (wavesize)
|
---|
| 256 | >> const_cast< float & > (perturbance)
|
---|
| 257 | >> const_cast< float & > (waveamplitude)
|
---|
| 258 | >> const_cast< float & > (viscosity);
|
---|
| 259 |
|
---|
| 260 | GaussianFn::operator = (createGaussian(viscosity));
|
---|
| 261 | return ins;
|
---|
| 262 | }
|
---|
| 263 | } _fnWave;
|
---|
| 264 |
|
---|
| 265 | const EaseInFn _fnEaseIn;
|
---|
| 266 | const EaseOutFn _fnEaseOut;
|
---|
| 267 | geoworld::NoiseGenerator< float > _ngenPert;
|
---|
| 268 |
|
---|
| 269 | inline static EaseInFn createEaseInFn () { return EaseInFn(1, 1.1f, -1.001f); }
|
---|
| 270 | inline static EaseOutFn createEaseOutFn () { return EaseOutFn(1, 1.1f, -1.001f); }
|
---|
| 271 |
|
---|
| 272 | protected:
|
---|
| 273 | virtual void applyFlowLine (const FlowLineType & fl, LavaFlowData * pData) const;
|
---|
| 274 |
|
---|
| 275 | public:
|
---|
| 276 | MyChannelSet();
|
---|
| 277 | MyChannelSet(
|
---|
| 278 | const mars::RangeX< float > & mmfBendZenith,
|
---|
| 279 | const unsigned int nBendZenithSteps,
|
---|
| 280 | const unsigned int nCandidateSampleAmt,
|
---|
| 281 | const mars::RangeX< float > & mmfSplineSeg,
|
---|
| 282 | const float fGravitySlopeGrace,
|
---|
| 283 | const float frSnapToGuide,
|
---|
| 284 | const mars::RangeX< float > & mmfFlowLineWidth,
|
---|
| 285 | const mars::RangeX< unsigned int > & mmnKidsPerLevel,
|
---|
| 286 | const float fwStraightness,
|
---|
| 287 | const float fwElevationInfluence,
|
---|
| 288 | const float fwDensityInfluence,
|
---|
| 289 | const float fwChaosInfluence,
|
---|
| 290 | const float fLavaFlowHeight,
|
---|
| 291 | const float fWaveScale,
|
---|
| 292 | const float fPhase,
|
---|
| 293 | const float fAmplitude,
|
---|
| 294 | const float fViscosity,
|
---|
| 295 | const float fPerturbance,
|
---|
| 296 | const float fPertNoise
|
---|
| 297 | );
|
---|
| 298 |
|
---|
| 299 | ~MyChannelSet();
|
---|
| 300 |
|
---|
| 301 | void init ( const mars::ptr< FluiDynQueryBridge > & pQuery, const unsigned int nLevels, const mars::BBox< float > & bboxSearch );
|
---|
| 302 | void run ( LockedGWSection::View * pView ) const;
|
---|
| 303 |
|
---|
| 304 | mars::ObjectStream & operator >> (mars::ObjectStream & outs) const;
|
---|
| 305 | mars::ObjectStream & operator << (mars::ObjectStream & ins);
|
---|
| 306 |
|
---|
| 307 | } _chans;
|
---|
| 308 |
|
---|
| 309 | unsigned int _nNumLavaFlows;
|
---|
| 310 | geoworld::NoiseGenerator< float > _noise;
|
---|
| 311 | mars::RangeX< unsigned int > _mmnLevels;
|
---|
| 312 |
|
---|
| 313 | inline void addInner (
|
---|
| 314 | const float frdScale,
|
---|
| 315 | const float fAmplitude,
|
---|
| 316 | const float fConeBroadness,
|
---|
| 317 | const float fCaldBroadness,
|
---|
| 318 | const float frCaldDepthRatio,
|
---|
| 319 | const float fFalloffFactor,
|
---|
| 320 | VectorTag< float >::PC dpc
|
---|
| 321 | )
|
---|
| 322 | {
|
---|
| 323 | const float fScale = _czone.caldera.scale * frdScale;
|
---|
| 324 | dpc.p *= _czone.caldera.scale;
|
---|
| 325 | const Vector2 dpos = dpc;
|
---|
| 326 |
|
---|
| 327 | _inners.push_back(
|
---|
| 328 | ConeZone(
|
---|
| 329 | ConeFn(
|
---|
| 330 | fScale,
|
---|
| 331 | fAmplitude,
|
---|
| 332 | fConeBroadness,
|
---|
| 333 | -ConeFn(
|
---|
| 334 | fScale,
|
---|
| 335 | fAmplitude,
|
---|
| 336 | fConeBroadness,
|
---|
| 337 | 0
|
---|
| 338 | ).f(_czone.getIntersect() + mars::MAG(dpos)) / fScale
|
---|
| 339 | ),
|
---|
| 340 | CalderaFn(
|
---|
| 341 | fScale,
|
---|
| 342 | fCaldBroadness,
|
---|
| 343 | fAmplitude * frCaldDepthRatio
|
---|
| 344 | ),
|
---|
| 345 | fFalloffFactor,
|
---|
| 346 | dpos
|
---|
| 347 | )
|
---|
| 348 | );
|
---|
| 349 | }
|
---|
| 350 |
|
---|
| 351 | VolcanoGM ();
|
---|
| 352 |
|
---|
| 353 | public:
|
---|
| 354 | VolcanoGM (
|
---|
| 355 | const GWSurfacePos & ptOrigin,
|
---|
| 356 | const float frNoise,
|
---|
| 357 | const float fScale,
|
---|
| 358 | const float fConeBroadness,
|
---|
| 359 | const float fConeAmplitude,
|
---|
| 360 | const float fCalderaBroadness,
|
---|
| 361 | const float frCalderaDepthRatio,
|
---|
| 362 | const float frCalderaFull,
|
---|
| 363 | const float fConeFalloffFactor,
|
---|
| 364 | const unsigned int nNumInnerCones,
|
---|
| 365 | const mars::RangeX< float > & mmfInnerConeRelativeScale,
|
---|
| 366 | const mars::RangeX< float > & mmfInnerConeBroadness,
|
---|
| 367 | const mars::RangeX< float > & mmfInnerConeAmplitude,
|
---|
| 368 | const mars::RangeX< float > & mmfInnerCalderaBroadness,
|
---|
| 369 | const mars::RangeX< float > & mmfrInnerCalderaDepthRatio,
|
---|
| 370 | const mars::RangeX< float > & mmfrInnerConeDisplaceRatio,
|
---|
| 371 | // Lava flow configs
|
---|
| 372 | // TODO: Sort out this mess of parameters, way too many!
|
---|
| 373 | const unsigned int nNumLavaFlows,
|
---|
| 374 | const float fLavaWaveScale,
|
---|
| 375 | const float fLavaWavePhase,
|
---|
| 376 | const float fLavaWaveAmplitude,
|
---|
| 377 | const float fLavaViscosity,
|
---|
| 378 | const float frLavaWavePerturbance,
|
---|
| 379 | const float fLavaFlowHeight,
|
---|
| 380 | // FluiDyn configs
|
---|
| 381 | const mars::RangeX< float > & mmfBendZenith,
|
---|
| 382 | const unsigned short nBendZenithSteps,
|
---|
| 383 | const unsigned short nCandidateSampleAmt,
|
---|
| 384 | const mars::RangeX< float > & mmfSplineSeg,
|
---|
| 385 | const float fGravitySlopeGrace,
|
---|
| 386 | const float frSnapToGuide,
|
---|
| 387 | const mars::RangeX< float > & mmfFlowLineWidth,
|
---|
| 388 | const mars::RangeX< unsigned int > & mmnLevels,
|
---|
| 389 | const mars::RangeX< unsigned int > & mmnKidsPerLevel,
|
---|
| 390 | const float fwStraightness,
|
---|
| 391 | const float fwElevationInfluence,
|
---|
| 392 | const float fwDensityInfluence,
|
---|
| 393 | const float fwChaosInfluence
|
---|
| 394 | );
|
---|
| 395 |
|
---|
| 396 | virtual void init (SynthesisSession & manager, const IGeoWorldAccessor & accessor, const unsigned short nMaxWidth, const unsigned short nMaxHeight);
|
---|
| 397 | virtual void doMorph (LockedGWSection & section) const;
|
---|
| 398 | virtual mars::BBox< long > getBBox () const { return _bbox; }
|
---|
| 399 |
|
---|
| 400 | static VolcanoGM * createInstance (mars::ObjectStream & ins);
|
---|
| 401 | mars::ObjectStream & operator >> (mars::ObjectStream & outs) const;
|
---|
| 402 | };
|
---|
| 403 |
|
---|
| 404 | inline mars::ObjectStream & operator << (VolcanoGM *& pGM, mars::ObjectStream & ins)
|
---|
| 405 | {
|
---|
| 406 | pGM = VolcanoGM::createInstance(ins);
|
---|
| 407 | return ins;
|
---|
| 408 | }
|
---|
| 409 |
|
---|
| 410 | class VolcanoGMFactory : public GeoMorphFactory, public IPersistentGeoMorphFactory, public ISurfaceBoundedGeoMorphFactory
|
---|
| 411 | {
|
---|
| 412 | private:
|
---|
| 413 | float
|
---|
| 414 | _frNoise,
|
---|
| 415 | _fConeFalloffFactor,
|
---|
| 416 |
|
---|
| 417 | _frLavaWavePerturbance,
|
---|
| 418 |
|
---|
| 419 | _fGravitySlopeGrace,
|
---|
| 420 | _frSnapToGuide,
|
---|
| 421 |
|
---|
| 422 | _fwStraightness,
|
---|
| 423 | _fwElevationInfluence,
|
---|
| 424 | _fwDensityInfluence,
|
---|
| 425 | _fwChaosInfluence;
|
---|
| 426 |
|
---|
| 427 | mars::RangeX< float >
|
---|
| 428 | _mmfScale,
|
---|
| 429 | _mmfConeBroadness,
|
---|
| 430 | _mmfConeAmplitude,
|
---|
| 431 | _mmfCalderaBroadness,
|
---|
| 432 | _mmfrCalderaDepthRatio,
|
---|
| 433 | _mmfrCalderaFull,
|
---|
| 434 |
|
---|
| 435 | _mmfInnerConeRelativeScale,
|
---|
| 436 | _mmfInnerConeBroadness,
|
---|
| 437 | _mmfInnerConeAmplitude,
|
---|
| 438 | _mmfInnerCalderaBroadness,
|
---|
| 439 | _mmfrInnerCalderaDepthRatio,
|
---|
| 440 | _mmfrInnerConeDisplaceRatio,
|
---|
| 441 |
|
---|
| 442 | _mmfLavaWaveScale,
|
---|
| 443 | _mmfLavaWavePhase,
|
---|
| 444 | _mmfLavaWaveAmplitude,
|
---|
| 445 | _mmfLavaViscosity,
|
---|
| 446 | _mmfLavaFlowHeight,
|
---|
| 447 |
|
---|
| 448 | _mmfBendZenith,
|
---|
| 449 | _mmfSplineSeg,
|
---|
| 450 | _mmfFlowLineWidth;
|
---|
| 451 |
|
---|
| 452 | mars::RangeX< unsigned int >
|
---|
| 453 | _mmnLevels,
|
---|
| 454 | _mmnKidsPerLevel,
|
---|
| 455 | _mmnNumInnerCones,
|
---|
| 456 |
|
---|
| 457 | _mmnNumLavaFlows;
|
---|
| 458 |
|
---|
| 459 | unsigned short
|
---|
| 460 | _nBendZenithSteps,
|
---|
| 461 | _nCandidateSampleAmt;
|
---|
| 462 |
|
---|
| 463 | public:
|
---|
| 464 | virtual GeoMorph * createRandomInstance(const long x, const long y) const;
|
---|
| 465 | virtual void configure( IConfigGMFactory * pFactoryConfig, const IConfigGMFactory::Settings & settings );
|
---|
| 466 | virtual void save (const GeoMorph * pGM, mars::ObjectStream & outs) const;
|
---|
| 467 | virtual const GeoMorph * restore (mars::ObjectStream & ins) const;
|
---|
| 468 | };
|
---|
| 469 | }
|
---|