Toshihiro Shimizu 890ddd
/*------------------------------------
Toshihiro Shimizu 890ddd
 Iwa_PerspectiveDistortFx 
Toshihiro Shimizu 890ddd
 奥行き方向に台形歪みを行うエフェクト
Toshihiro Shimizu 890ddd
 ディティールを保持するため、引き伸ばす量に応じて素材の解像度を上げる
Toshihiro Shimizu 890ddd
------------------------------------*/
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#ifndef IWA_PERSPECTIVE_DISTORT_H
Toshihiro Shimizu 890ddd
#define IWA_PERSPECTIVE_DISTORT_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 float4 {
Toshihiro Shimizu 890ddd
	float x, y, z, w;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
class Iwa_PerspectiveDistortFx : public TStandardRasterFx
Toshihiro Shimizu 890ddd
{
Toshihiro Shimizu 890ddd
	FX_PLUGIN_DECLARATION(Iwa_PerspectiveDistortFx)
Toshihiro Shimizu 890ddd
protected:
Toshihiro Shimizu 890ddd
	TRasterFxPort m_source; /*- 入力画像 -*/
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	TPointParamP m_vanishingPoint; /*- 消失点 -*/
Toshihiro Shimizu 890ddd
	TPointParamP m_anchorPoint;	/*- 基準点 -*/
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	TDoubleParamP m_precision; /*- 細かさ。解像度の引き上げ度合い -*/
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	/*- 出力結果をChannel値に変換して格納 -*/
Toshihiro Shimizu 890ddd
	template <typename RASTER, typename PIXEL>
Toshihiro Shimizu 890ddd
	void setOutputRaster(float4 *srcMem,
Toshihiro Shimizu 890ddd
						 const RASTER dstRas,
Toshihiro Shimizu 890ddd
						 TDimensionI dim,
Toshihiro Shimizu 890ddd
						 int drawLevel);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	/*- タイルの画像を0〜1に正規化してホストメモリに読み込む -*/
Toshihiro Shimizu 890ddd
	template <typename RASTER, typename PIXEL>
Toshihiro Shimizu 890ddd
	void setSourceRaster(const RASTER srcRas,
Toshihiro Shimizu 890ddd
						 float4 *dstMem,
Toshihiro Shimizu 890ddd
						 TDimensionI dim);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
public:
Toshihiro Shimizu 890ddd
	Iwa_PerspectiveDistortFx();
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	bool doGetBBox(
Toshihiro Shimizu 890ddd
		double frame, TRectD &bBox, const TRenderSettings &info);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	bool canHandle(
Toshihiro Shimizu 890ddd
		const TRenderSettings &info, double frame);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	void doCompute(
Toshihiro Shimizu 890ddd
		TTile &tile, double frame, const TRenderSettings &rend_sets);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	void doCompute_CPU(TTile &tile,
Toshihiro Shimizu 890ddd
					   const double frame,
Toshihiro Shimizu 890ddd
					   const TRenderSettings &settings,
Toshihiro Shimizu 890ddd
					   TPointD &vanishingPoint,
Toshihiro Shimizu 890ddd
					   TPointD &anchorPoint,
Toshihiro Shimizu 890ddd
					   float4 *source_host,
Toshihiro Shimizu 890ddd
					   float4 *result_host,
Toshihiro Shimizu 890ddd
					   TDimensionI &sourceDim,
Toshihiro Shimizu 890ddd
					   TDimensionI &resultDim,
Toshihiro Shimizu 890ddd
					   const double precision,
Toshihiro Shimizu 890ddd
					   const double offs);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
	void getParamUIs(TParamUIConcept *&concepts, int &length);
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#endif