Blob Blame Raw
#pragma once

/*------------------------------------
 Iwa_GradientWarpFx
 参照画像の勾配方向にWarpするエフェクト
------------------------------------*/

#ifndef IWA_GRADIENT_WARP_H
#define IWA_GRADIENT_WARP_H

#include "tfxparam.h"
#include "stdfx.h"

struct float2 {
  float x, y;
};
struct float4 {
#if defined(TNZ_MACHINE_CHANNEL_ORDER_BGRM)
  float z, y, x, w;
#elif defined(TNZ_MACHINE_CHANNEL_ORDER_MBGR)
  float w, x, y, x;
#elif defined(TNZ_MACHINE_CHANNEL_ORDER_RGBM)
  float x, y, x, w;
#elif defined(TNZ_MACHINE_CHANNEL_ORDER_MRGB)
  float w, x, y, z;
#endif
};
struct int2 {
  int x, y;
};

class Iwa_GradientWarpFx final : public TStandardRasterFx {
  FX_PLUGIN_DECLARATION(Iwa_GradientWarpFx)

protected:
  TRasterFxPort m_source; /*- 入力画像 -*/
  TRasterFxPort m_warper; /*- 参照画像 -*/

  TDoubleParamP m_h_maxlen;
  TDoubleParamP m_v_maxlen;
  TDoubleParamP
      m_scale; /*- ワープ量を増やすスカラー値。この値はマージン値には影響しない
                  -*/
  TDoubleParamP m_sampling_size;

  void get_render_real_hv(const double frame, const TAffine affine,
                          double &h_maxlen, double &v_maxlen);

  void get_render_enlarge(const double frame, const TAffine affine,
                          TRectD &bBox);

  /*- タイルの画像を0〜1に正規化してホストメモリに読み込む -*/
  template <typename RASTER, typename PIXEL>
  void setSourceRaster(const RASTER srcRas, float4 *dstMem, TDimensionI dim);

  /*- タイルの画像の輝度値を0〜1に正規化してホストメモリに読み込む -*/
  template <typename RASTER, typename PIXEL>
  void setWarperRaster(const RASTER srcRas, float *dstMem, TDimensionI dim);

  /*- 出力結果をChannel値に変換して格納 -*/
  template <typename RASTER, typename PIXEL>
  void setOutputRaster(float4 *srcMem, const RASTER dstRas, TDimensionI dim,
                       int2 margin);

  void doCompute_CPU(TTile &tile, const double frame,
                     const TRenderSettings &settings, double hLength,
                     double vLength, int margin, TDimensionI &enlargedDim,
                     float4 *source_host, float *warper_host,
                     float4 *result_host, double sampling_size,
                     double grad_factor);

  float4 getSourceVal_CPU(float4 *source_host, TDimensionI &enlargedDim,
                          int pos_x, int pos_y);

  float4 interp_CPU(float4 val1, float4 val2, float ratio);

public:
  Iwa_GradientWarpFx();

  void doCompute(TTile &tile, double frame,
                 const TRenderSettings &settings) override;

  bool doGetBBox(double frame, TRectD &bBox,
                 const TRenderSettings &info) override;

  bool canHandle(const TRenderSettings &info, double frame) override;

  void onFxVersionSet() final override;
};

#endif