Shinya Kitaoka 810553
#pragma once
Shinya Kitaoka 810553
Toshihiro Shimizu 890ddd
/*------------------------------------------------------------
Toshihiro Shimizu 890ddd
 Iwa_PNPerspectiveFx
Toshihiro Shimizu 890ddd
 PerlinNoise/SimplexNoiseパターンを生成、透視投影する
Toshihiro Shimizu 890ddd
------------------------------------------------------------*/
Toshihiro Shimizu 890ddd
#ifndef IWA_PN_PERSPECTIVE_H
Toshihiro Shimizu 890ddd
#define IWA_PN_PERSPECTIVE_H
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "tfxparam.h"
Toshihiro Shimizu 890ddd
#include "stdfx.h"
Toshihiro Shimizu 890ddd
#include "tparamset.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
struct float2 {
Shinya Kitaoka 120a6e
  float x, y;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
struct float3 {
Shinya Kitaoka 120a6e
  float x, y, z;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
struct float4 {
Shinya Kitaoka 120a6e
  float x, y, z, w;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/*計算に用いるパラメータ群*/
Toshihiro Shimizu 890ddd
struct PN_Params {
Shinya Kitaoka 120a6e
  int renderMode;
Shinya Kitaoka 120a6e
  int noiseType;     /* 0:Perlin, 1: Simplex */
Shinya Kitaoka 120a6e
  float size;        /* 第1世代のノイズサイズ */
Shinya Kitaoka 120a6e
  int octaves;       /* 世代数 */
Shinya Kitaoka 120a6e
  float2 offset;     /* 第1世代のオフセット */
Shinya Kitaoka 120a6e
  float p_intensity; /* 世代間の強度比 */
Shinya Kitaoka 120a6e
  float p_size;      /* 世代間のサイズ比 */
Shinya Kitaoka 120a6e
  float p_offset;    /* 世代間のオフセット比 */
Shinya Kitaoka 120a6e
  float2 eyeLevel;   /* 視点位置 */
Shinya Kitaoka 120a6e
  int drawLevel;     /* 描画範囲の下からの距離 描画を開始するスキャンライン位置 */
Shinya Kitaoka 120a6e
  bool alp_rend_sw;
Shinya Kitaoka 120a6e
  float waveHeight; /* warpHV / フレネル反射のときのみ使う */
Shinya Kitaoka 120a6e
  float fy_2;
Shinya Kitaoka 120a6e
  float A;
Shinya Kitaoka 120a6e
  float3 cam_pos;
Shinya Kitaoka 120a6e
  float base_fresnel_ref; /* フレネル反射のときのみ使う */
Shinya Kitaoka 120a6e
  float int_sum;
Shinya Kitaoka 120a6e
  float a11, a12, a13;
Shinya Kitaoka 120a6e
  float a21, a22, a23;
Shinya Kitaoka 120a6e
  float time;
Shinya Kitaoka 120a6e
  float p_evolution;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
class Iwa_PNPerspectiveFx : public TStandardZeraryFx {
Shinya Kitaoka 120a6e
  FX_PLUGIN_DECLARATION(Iwa_PNPerspectiveFx)
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TIntEnumParamP
Shinya Kitaoka 120a6e
      m_renderMode; /* 描画モード
Shinya Kitaoka 120a6e
                                                                           -
Shinya Kitaoka 120a6e
                       強度
Shinya Kitaoka 120a6e
                                                                           -
Shinya Kitaoka 120a6e
                       強度(リサンプルなし)
Shinya Kitaoka 120a6e
                                                                           -
Shinya Kitaoka 120a6e
                       WarpHV用オフセット
Shinya Kitaoka 120a6e
                                                                           -
Shinya Kitaoka 120a6e
                       フレネル反射 */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TIntEnumParamP
Shinya Kitaoka 120a6e
      m_noiseType; /* ノイズのタイプ
Shinya Kitaoka 120a6e
                                                                           -
Shinya Kitaoka 120a6e
                      Perlin Noise
Shinya Kitaoka 120a6e
                                                                           -
Shinya Kitaoka 120a6e
                      Simplex Noise */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TDoubleParamP m_size;      /* ベースとなる大きさ */
Shinya Kitaoka 120a6e
  TDoubleParamP m_evolution; /* 展開 */
Shinya Kitaoka 120a6e
  TIntEnumParamP m_octaves;  /* 世代数 */
Shinya Kitaoka 120a6e
  TPointParamP m_offset;     /* ノイズのオフセット */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TDoubleParamP m_persistance_intensity; /* 次の世代での振幅の倍率 */
Shinya Kitaoka 120a6e
  TDoubleParamP m_persistance_size;      /* 次の世代での波長の倍率 */
Shinya Kitaoka 120a6e
  TDoubleParamP m_persistance_evolution; /* 次の世代での展開周期の倍率 */
Shinya Kitaoka 120a6e
  TDoubleParamP m_persistance_offset; /* 次の世代でのオフセット距離の倍率 */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TDoubleParamP m_fov;     /* カメラ画角 */
Shinya Kitaoka 120a6e
  TPointParamP m_eyeLevel; /* 消失点の位置 */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TBoolParamP
Shinya Kitaoka 120a6e
      m_alpha_rendering; /* アルファチャンネルもノイズを与えるかどうか */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  TDoubleParamP m_waveHeight; /* 波の高さ */
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /* 出力結果をChannel値に変換して格納 */
Shinya Kitaoka 120a6e
  template <typename pixel="" raster,="" typename=""></typename>
Shinya Kitaoka 120a6e
  void setOutputRaster(float4 *srcMem, const RASTER dstRas, TDimensionI dim,
Shinya Kitaoka 120a6e
                       int drawLevel, const bool alp_rend_sw);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /* PerlinNoiseのパラメータを取得 */
Shinya Kitaoka 120a6e
  void getPNParameters(TTile &tile, double frame,
Shinya Kitaoka 120a6e
                       const TRenderSettings &settings, PN_Params ¶ms,
Shinya Kitaoka 120a6e
                       TDimensionI &dimOut);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /* 通常のノイズのCPU計算 */
Shinya Kitaoka 120a6e
  void calcPerinNoise_CPU(float4 *out_host, TDimensionI &dimOut, PN_Params &p,
Shinya Kitaoka 120a6e
                          bool doResample);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /* WarpHVモード、Fresnel反射モード */
Shinya Kitaoka 120a6e
  void calcPNNormal_CPU(float4 *out_host, TDimensionI &dimOut, PN_Params &p,
Shinya Kitaoka 120a6e
                        bool isSubWave = false);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
public:
Shinya Kitaoka 120a6e
  Iwa_PNPerspectiveFx();
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  bool doGetBBox(double frame, TRectD &bBox, const TRenderSettings &info) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  bool canHandle(const TRenderSettings &info, double frame) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  void doCompute(TTile &tile, double frame, const TRenderSettings &rend_sets) override;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  void doCompute_CPU(TTile &tile, double frame, const TRenderSettings &settings,
Shinya Kitaoka 120a6e
                     float4 *out_host, TDimensionI &dimOut,
Shinya Kitaoka 120a6e
                     PN_Params &pnParams);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 473e70
  void getParamUIs(TParamUIConcept *&concepts, int &length) override;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#endif