Blob Blame Raw
#pragma once

#ifndef igs_rotate_blur_h
#define igs_rotate_blur_h

#ifndef IGS_ROTATE_BLUR_EXPORT
#define IGS_ROTATE_BLUR_EXPORT
#endif

#include "tgeometry.h"

namespace igs {
namespace rotate_blur {
IGS_ROTATE_BLUR_EXPORT void convert(
    const float* in, float* out, const int margin,
    const TDimension out_dim,             /* 求める画像(out)のサイズ */
    const int channels, const float* ref, /* outと同じ高さ、幅 */
    const TPointD center, const double degree = 30.0, /* ぼかしの回転角度 */
    const double blur_radius = 0.0, /* ぼかしの始まる半径 */
    const double spin_radius = 0.0, /* ゼロ以上でspin指定となり、
                            かつぼかし強弱の一定になる半径となる */
    const int type = 0,  // 0: Accelerator, 1: Uniform Angle, 2: Uniform Length
    const bool antialias_sw =
        true, /* when true, sampled pixel will be bilinear-interpolated */
    const bool alpha_rendering_sw     = true,
    const double ellipse_aspect_ratio = 1.0, const double ellipse_angle = 0.0);
#if 0   //------------------- comment out start ------------------------
  IGS_ROTATE_BLUR_EXPORT int enlarge_margin(
	 const int height	/* 求める画像(out)の高さ */
	,const int width	/* 求める画像(out)の幅 */
	,const double xc
	,const double yc
	,const double degree	/* ぼかしの回転角度 */
	,const double blur_radius	/* ぼかしの始まる半径 */
	,const double spin_radius	/* ゼロ以上でspin指定となり、
				かつぼかし強弱の一定になる半径となる */
	,const int sub_div	/* 1ならJaggy、2以上はAntialias */
  );
#endif  //------------------- comment out end -------------------------
IGS_ROTATE_BLUR_EXPORT int reference_margin(
    const int height, /* 求める画像(out)の高さ */
    const int width,  /* 求める画像(out)の幅 */
    const TPointD center, const double degree, /* ぼかしの回転角度 */
    const double blur_radius,                  /* ぼかしの始まる半径 */
    const double spin_radius, /* ゼロ以上でspin指定となり、
                            かつぼかし強弱の一定になる半径となる */
    const int type,  // 0: Accelerator, 1: Uniform Angle, 2: Uniform Length
    const double ellipse_aspect_ratio = 1.0);
}  // namespace rotate_blur
}  // namespace igs

#endif /* !igs_rotate_blur_h */