tahoma2d/toonz/sources/stdfx/iwa_directionalblurfx.h

75 lines
2.4 KiB
C
Raw Normal View History

2016-05-17 03:04:11 +12:00
#pragma once
2016-03-19 06:57:51 +13:00
/*------------------------------------
Iwa_DirectionalBlurFx
DirectionalBlur
//------------------------------------*/
#ifndef IWA_DIRECTIONAL_BLUR_H
#define IWA_DIRECTIONAL_BLUR_H
#include "tfxparam.h"
#include "stdfx.h"
struct float2 {
2016-06-15 18:43:10 +12:00
float x, y;
2016-03-19 06:57:51 +13:00
};
struct float4 {
2016-06-15 18:43:10 +12:00
float x, y, z, w;
2016-03-19 06:57:51 +13:00
};
struct int2 {
2016-06-15 18:43:10 +12:00
int x, y;
2016-03-19 06:57:51 +13:00
};
class Iwa_DirectionalBlurFx final : public TStandardRasterFx {
2016-06-15 18:43:10 +12:00
FX_PLUGIN_DECLARATION(Iwa_DirectionalBlurFx)
TRasterFxPort m_input;
TRasterFxPort m_reference;
TDoubleParamP m_angle;
TDoubleParamP m_intensity;
TBoolParamP m_bidirectional;
/*- リニア/ガウシアン/平均化 -*/
TIntEnumParamP m_filterType;
/*- 参照画像の輝度を0〜1に正規化してホストメモリに読み込む -*/
template <typename RASTER, typename PIXEL>
void setReferenceRaster(const RASTER srcRas, float *dstMem, TDimensionI dim);
/*- ソース画像を0〜1に正規化してホストメモリに読み込む -*/
template <typename RASTER, typename PIXEL>
void setSourceRaster(const RASTER srcRas, float4 *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, double frame, const TRenderSettings &settings,
TPointD &blur, bool bidirectional, int marginLeft,
int marginRight, int marginTop, int marginBottom,
TDimensionI &enlargedDimIn, TTile &enlarge_tile,
TDimensionI &dimOut, TDimensionI &filterDim,
float *reference_host);
void makeDirectionalBlurFilter_CPU(float *filter, TPointD &blur,
bool bidirectional, int marginLeft,
int marginRight, int marginTop,
int marginBottom, TDimensionI &filterDim);
2016-03-19 06:57:51 +13:00
public:
2016-06-15 18:43:10 +12:00
Iwa_DirectionalBlurFx();
2016-03-19 06:57:51 +13:00
2016-06-20 14:23:05 +12:00
void doCompute(TTile &tile, double frame,
const TRenderSettings &settings) override;
2016-03-19 06:57:51 +13:00
2016-06-20 14:23:05 +12:00
bool doGetBBox(double frame, TRectD &bBox,
const TRenderSettings &info) override;
2016-03-19 06:57:51 +13:00
2016-06-19 20:06:29 +12:00
bool canHandle(const TRenderSettings &info, double frame) override;
2016-03-19 06:57:51 +13:00
2016-06-19 20:06:29 +12:00
void getParamUIs(TParamUIConcept *&concepts, int &length) override;
2016-03-19 06:57:51 +13:00
};
#endif