Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "trop.h"
Toshihiro Shimizu 890ddd
#include "traster.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "tspectrumparam.h"
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
namespace {
Toshihiro Shimizu 890ddd
template <class t=""></class>
Shinya Kitaoka 120a6e
void doComputeRadialT(TRasterPT<t> ras, TPointD posTrasf,</t>
Shinya Kitaoka 120a6e
                      const TSpectrumT<t> &spectrum, double period,</t>
Shinya Kitaoka 120a6e
                      double count, double cycle, const TAffine &aff) {
Shinya Kitaoka 120a6e
  int j;
Shinya Kitaoka 120a6e
  double maxRadius = period * count;
Shinya Kitaoka 120a6e
  double freq      = 1.0 / period;
Shinya Kitaoka 120a6e
  ras->lock();
Shinya Kitaoka 120a6e
  for (j = 0; j < ras->getLy(); j++) {
Shinya Kitaoka 120a6e
    TPointD posAux = posTrasf;
Shinya Kitaoka 120a6e
    T *pix         = ras->pixels(j);
Shinya Kitaoka 120a6e
    T *endPix      = pix + ras->getLx();
Shinya Kitaoka 120a6e
    while (pix < endPix) {
Shinya Kitaoka 120a6e
      double radius = norm(posAux);
Shinya Kitaoka 120a6e
      double t      = 1;
Shinya Kitaoka 120a6e
      if (radius < maxRadius) {
Shinya Kitaoka 120a6e
        t = (radius + cycle) * freq;
Shinya Kitaoka 120a6e
        t -= floor(t);
Shinya Kitaoka 120a6e
      }
Shinya Kitaoka 120a6e
      // double polinomfactor=(-2*t+3)*(t*t);
Shinya Kitaoka 120a6e
      *pix++ = spectrum.getPremultipliedValue(t);
Shinya Kitaoka 120a6e
      posAux.x += aff.a11;
Shinya Kitaoka 120a6e
      posAux.y += aff.a21;
Shinya Kitaoka 120a6e
    }
Shinya Kitaoka 120a6e
    posTrasf.x += aff.a12;
Shinya Kitaoka 120a6e
    posTrasf.y += aff.a22;
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
  ras->unlock();
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void multiRadial(const TRasterP &ras, TPointD posTrasf,
Shinya Kitaoka 120a6e
                 const TSpectrumParamP colors, double period, double count,
Shinya Kitaoka 120a6e
                 double cycle, const TAffine &aff, double frame) {
Shinya Kitaoka 120a6e
  if ((TRaster32P)ras)
Shinya Kitaoka 120a6e
    doComputeRadialT<tpixel32>(ras, posTrasf, colors->getValue(frame), period,</tpixel32>
Shinya Kitaoka 120a6e
                               count, cycle, aff);
Shinya Kitaoka 120a6e
  else if ((TRaster64P)ras)
Shinya Kitaoka 120a6e
    doComputeRadialT<tpixel64>(ras, posTrasf, colors->getValue64(frame), period,</tpixel64>
Shinya Kitaoka 120a6e
                               count, cycle, aff);
Shinya Kitaoka 120a6e
  else
Shinya Kitaoka 120a6e
    throw TException("MultiRadialGradientFx: unsupported Pixel Type");
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
namespace {
Toshihiro Shimizu 890ddd
template <class t=""></class>
Shinya Kitaoka 120a6e
void doComputeLinearT(TRasterPT<t> ras, TPointD posTrasf,</t>
Shinya Kitaoka 120a6e
                      const TSpectrumT<t> &spectrum, double period,</t>
Shinya Kitaoka 120a6e
                      double count, double w_amplitude, double w_freq,
Shinya Kitaoka 120a6e
                      double w_phase, double cycle, const TAffine &aff) {
Shinya Kitaoka 120a6e
  double shift     = 0;
Shinya Kitaoka 120a6e
  double maxRadius = period * count / 2.;
Shinya Kitaoka 120a6e
  double freq      = 1.0 / period;
Shinya Kitaoka 120a6e
  int j;
Shinya Kitaoka 120a6e
  ras->lock();
Shinya Kitaoka 120a6e
  for (j = 0; j < ras->getLy(); j++) {
Shinya Kitaoka 120a6e
    TPointD posAux = posTrasf;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
    // TPointD pos = tile.m_pos;
Shinya Kitaoka 120a6e
    // pos.y += j;
Shinya Kitaoka 120a6e
    T *pix    = ras->pixels(j);
Shinya Kitaoka 120a6e
    T *endPix = pix + ras->getLx();
Shinya Kitaoka 120a6e
    while (pix < endPix) {
Shinya Kitaoka 120a6e
      if (w_amplitude) shift = w_amplitude * sin(w_freq * posAux.y + w_phase);
Shinya Kitaoka 120a6e
      double radius          = posAux.x + shift;
Shinya Kitaoka 120a6e
      double t               = 1;
Shinya Kitaoka 120a6e
      if (fabs(radius) < maxRadius) {
Shinya Kitaoka 120a6e
        t = (radius + maxRadius + cycle) * freq;
Shinya Kitaoka 120a6e
        t -= floor(t);
Shinya Kitaoka 120a6e
      } else if (radius < 0)
Shinya Kitaoka 120a6e
        t                  = 0;
Shinya Kitaoka 120a6e
      double polinomfactor = (-2 * t + 3) * (t * t);
Shinya Kitaoka 120a6e
      // pos.x += 1.0;
Shinya Kitaoka 120a6e
      *pix++ = spectrum.getPremultipliedValue(polinomfactor);
Shinya Kitaoka 120a6e
      posAux.x += aff.a11;
Shinya Kitaoka 120a6e
      posAux.y += aff.a21;
Shinya Kitaoka 120a6e
    }
Shinya Kitaoka 120a6e
    posTrasf.x += aff.a12;
Shinya Kitaoka 120a6e
    posTrasf.y += aff.a22;
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
  ras->unlock();
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
//------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void multiLinear(const TRasterP &ras, TPointD posTrasf,
Shinya Kitaoka 120a6e
                 const TSpectrumParamP colors, double period, double count,
Shinya Kitaoka 120a6e
                 double amplitude, double freq, double phase, double cycle,
Shinya Kitaoka 120a6e
                 const TAffine &aff, double frame) {
Shinya Kitaoka 120a6e
  if ((TRaster32P)ras)
Shinya Kitaoka 120a6e
    doComputeLinearT<tpixel32>(ras, posTrasf, colors->getValue(frame), period,</tpixel32>
Shinya Kitaoka 120a6e
                               count, amplitude, freq, phase, cycle, aff);
Shinya Kitaoka 120a6e
  else if ((TRaster64P)ras)
Shinya Kitaoka 120a6e
    doComputeLinearT<tpixel64>(ras, posTrasf, colors->getValue64(frame), period,</tpixel64>
Shinya Kitaoka 120a6e
                               count, amplitude, freq, phase, cycle, aff);
Shinya Kitaoka 120a6e
  else
Shinya Kitaoka 120a6e
    throw TException("MultiLinearGradientFx: unsupported Pixel Type");
Toshihiro Shimizu 890ddd
}