Blob Blame Raw
#pragma once

#ifndef T_COLOR_FUNCTIONS_INCLUDED
#define T_COLOR_FUNCTIONS_INCLUDED

#include "tpixel.h"

#undef DVAPI
#undef DVVAR
#ifdef TCOLOR_EXPORTS
#define DVAPI DV_EXPORT_API
#define DVVAR DV_EXPORT_VAR
#else
#define DVAPI DV_IMPORT_API
#define DVVAR DV_IMPORT_VAR
#endif

//-----------------------------------------------------------------------------

class DVAPI TColorFunction {
public:
  virtual TPixel32 operator()(
      const TPixel32 &color) const = 0;  // {return color;};

  struct Parameters {  // outX = tcrop(inX * m_mX + m_cX, 0, 1); 0<=inX<=1
    double m_mR, m_mG, m_mB, m_mM;
    double m_cR, m_cG, m_cB, m_cM;
    Parameters()
        : m_mR(1)
        , m_mG(1)
        , m_mB(1)
        , m_mM(1)
        , m_cR(0)
        , m_cG(0)
        , m_cB(0)
        , m_cM(0) {}
  };

  virtual TColorFunction *clone() const = 0;
  virtual bool getParameters(
      Parameters &p) const = 0;  //{ p = Parameters(); return true; }

  virtual ~TColorFunction() {}
};

//-----------------------------------------------------------------------------

class DVAPI TGenericColorFunction final : public TColorFunction {
  double m_m[4], m_c[4];

public:
  TGenericColorFunction(const double m[4], const double c[4]);

  TColorFunction *clone() const override {
    return new TGenericColorFunction(m_m, m_c);
  }

  TPixel32 operator()(const TPixel32 &color) const override;
  bool getParameters(Parameters &p) const override;
};

//-----------------------------------------------------------------------------

class DVAPI TColorFader final : public TColorFunction {
  TPixel32 m_color;
  double m_fade;

public:
  TColorFader() : m_color(), m_fade(0.5) {}
  TColorFader(const TPixel32 &color, double fade)
      : m_color(color), m_fade(fade) {}

  TColorFunction *clone() const override {
    return new TColorFader(m_color, m_fade);
  }

  TPixel32 operator()(const TPixel32 &color) const override;
  bool getParameters(Parameters &p) const override;
};

//-----------------------------------------------------------------------------

class DVAPI TOnionFader final : public TColorFunction {
  TPixel32 m_color;
  double m_fade;

public:
  TOnionFader() : m_color(), m_fade(0.5) {}
  TOnionFader(const TPixel32 &color, double fade)
      : m_color(color), m_fade(fade) {}

  TColorFunction *clone() const override {
    return new TOnionFader(m_color, m_fade);
  }

  TPixel32 operator()(const TPixel32 &color) const override;
  bool getParameters(Parameters &p) const override;
};

class DVAPI TTranspFader final : public TColorFunction {
  double m_transp;

public:
  TTranspFader() : m_transp(0.5) {}
  TTranspFader(double transp) : m_transp(transp) {}

  TColorFunction *clone() const override { return new TTranspFader(m_transp); }

  TPixel32 operator()(const TPixel32 &color) const override;
  bool getParameters(Parameters &p) const override;
};

//-----------------------------------------------------------------------------

class DVAPI TColumnColorFilterFunction final : public TColorFunction {
  TPixel32 m_colorScale;

public:
  TColumnColorFilterFunction() : m_colorScale() {}
  TColumnColorFilterFunction(const TPixel32 &color) : m_colorScale(color) {}

  TColorFunction *clone() const override {
    return new TColumnColorFilterFunction(m_colorScale);
  }

  TPixel32 operator()(const TPixel32 &color) const override;
  bool getParameters(Parameters &p) const override;
};

#endif