Blob Blame Raw
#pragma once

#ifndef PERLINNOISE_H
#define PERLINOISE_H

#include <memory>

#include "tfxparam.h"
#include "tspectrumparam.h"

enum { PNOISE_CLOUDS, PNOISE_WOODS };

class PerlinNoise {
  static int Size;
  static int TimeSize;
  static int Offset;
  static double Pixel_size;
  std::unique_ptr<float[]> Noise;
  double LinearNoise(double x, double y, double t);

public:
  PerlinNoise();
  double Turbolence(double u, double v, double k, double grain);
  double Turbolence(double u, double v, double k, double grain, double min,
                    double max);
  double Marble(double u, double v, double k, double grain);
  double Marble(double u, double v, double k, double grain, double min,
                double max);
};
/*---------------------------------------------------------------------------*/
void doClouds(const TRasterP &ras, const TSpectrumParamP colors, TPointD pos,
              double evolution, double size, double min, double max, int type,
              double scale, double frame);

#endif