Blob Blame Raw


// TnzCore includes
#include "trop.h"
#include "tpixelutils.h"

// TnzBase includes
#include "tparamset.h"
#include "tdoubleparam.h"
#include "tfxparam.h"
#include "tparamuiconcept.h"

#include "tbasefx.h"
#include "tzeraryfx.h"

//==================================================================

class ColorCardFx final : public TBaseZeraryFx {
  FX_DECLARATION(ColorCardFx)

  TPixelParamP m_color;

public:
  ColorCardFx() : m_color(TPixel32::Green) {
    bindParam(this, "color", m_color);
    m_color->setDefaultValue(TPixel32::Green);
    setName(L"ColorCardFx");
    enableComputeInFloat(true);
  }

  bool canHandle(const TRenderSettings &info, double frame) override {
    return true;
  }

  bool doGetBBox(double frame, TRectD &bBox,
                 const TRenderSettings &info) override {
    bBox = TConsts::infiniteRectD;
    return true;
  }

  void doCompute(TTile &tile, double frame,
                 const TRenderSettings &ri) override {
    TRaster32P ras32 = tile.getRaster();
    TRaster64P ras64 = tile.getRaster();
    TRasterFP rasF   = tile.getRaster();
    // currently the tile should always be nonlinear
    assert(!tile.getRaster()->isLinear());
    if (!tile.getRaster()->isLinear()) {
      if (ras32)
        ras32->fill(m_color->getPremultipliedValue(frame));
      else if (ras64)
        ras64->fill(toPixel64(m_color->getPremultipliedValue(frame)));
      else if (rasF)
        rasF->fill(toPixelF(m_color->getPremultipliedValue(frame)));
      else
        throw TException("ColorCardFx unsupported pixel type");
    } else {  // linear color space
      if (ras32)
        ras32->fill(toLinear(m_color->getPremultipliedValue(frame),
                             ri.m_colorSpaceGamma));
      else if (ras64)
        ras64->fill(toLinear(toPixel64(m_color->getPremultipliedValue(frame)),
                             ri.m_colorSpaceGamma));
      else if (rasF)
        rasF->fill(toLinear(toPixelF(m_color->getPremultipliedValue(frame)),
                            ri.m_colorSpaceGamma));
      else
        throw TException("ColorCardFx unsupported pixel type");
    }
  }
};

//==================================================================

class CheckBoardFx final : public TBaseZeraryFx {
  FX_DECLARATION(CheckBoardFx)

  TPixelParamP m_color1, m_color2;
  TDoubleParamP m_size;

public:
  CheckBoardFx()
      : m_color1(TPixel32::Black), m_color2(TPixel32::White), m_size(50) {
    m_size->setMeasureName("fxLength");
    bindParam(this, "color1", m_color1);
    bindParam(this, "color2", m_color2);
    bindParam(this, "size", m_size);
    m_color1->setDefaultValue(TPixel32::Black);
    m_color2->setDefaultValue(TPixel32::White);
    m_size->setValueRange(1, 1000);
    m_size->setDefaultValue(50);
    setName(L"CheckBoardFx");
    enableComputeInFloat(true);
  }

  bool canHandle(const TRenderSettings &info, double frame) override {
    return false;
  }

  bool doGetBBox(double, TRectD &bBox, const TRenderSettings &info) override {
    bBox = TConsts::infiniteRectD;
    return true;
  }

  void doCompute(TTile &tile, double frame,
                 const TRenderSettings &info) override {
    bool isLinear = tile.getRaster()->isLinear();
    // currently the tile should always be nonlinear
    assert(!isLinear);
    const TPixel32 &c1 =
        m_color1->getValue(frame, isLinear, info.m_colorSpaceGamma);
    const TPixel32 &c2 =
        m_color2->getValue(frame, isLinear, info.m_colorSpaceGamma);

    double size = m_size->getValue(frame);

    assert(info.m_shrinkX == info.m_shrinkY);
    size *= info.m_affine.a11 / info.m_shrinkX;

    TDimensionD dim(size, size);
    TRop::checkBoard(tile.getRaster(), c1, c2, dim, tile.m_pos);
  }

  void getParamUIs(TParamUIConcept *&concepts, int &length) override {
    concepts = new TParamUIConcept[length = 1];

    concepts[0].m_type  = TParamUIConcept::SIZE;
    concepts[0].m_label = "Size";
    concepts[0].m_params.push_back(m_size);
  }
};

//==================================================================

FX_IDENTIFIER(ColorCardFx, "colorCardFx")
FX_IDENTIFIER(CheckBoardFx, "checkBoardFx")