Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "ext/SquarePotential.h"
Toshihiro Shimizu 890ddd
#include <tmathutil.h></tmathutil.h>
Toshihiro Shimizu 890ddd
#include <algorithm></algorithm>
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
using namespace std;
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void ToonzExt::SquarePotential::setParameters_(const TStroke *ref, double par,
Shinya Kitaoka 120a6e
                                               double al) {
Shinya Kitaoka 120a6e
  ref_          = ref;
Shinya Kitaoka 120a6e
  par_          = par;
Shinya Kitaoka 120a6e
  actionLength_ = al;
Shinya Kitaoka 120a6e
  assert(ref_);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  strokeLength_  = ref->getLength();
Shinya Kitaoka 120a6e
  lenghtAtParam_ = ref->getLength(par);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // lunghezza dal pto di click all'inizio della curva
Shinya Kitaoka 120a6e
  leftFactor_ = min(lenghtAtParam_,
Shinya Kitaoka 120a6e
                    actionLength_ * 0.5);  // lenghtAtParam_ / strokeLength_;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // lunghezza dal pto di click alla fine
Shinya Kitaoka 120a6e
  rightFactor_ = min(strokeLength_ - lenghtAtParam_, actionLength_ * 0.5);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // considero come intervallo di mapping [-range,range].
Shinya Kitaoka 120a6e
  //  4 ha come valore c.a. 10exp-6
Shinya Kitaoka 120a6e
  //  cioƩ sposterei un pixel su un movimento di un milione di pixel
Shinya Kitaoka 120a6e
  range_ = 2.8;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
ToonzExt::SquarePotential::~SquarePotential() {}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
double ToonzExt::SquarePotential::value_(double value2test) const {
Shinya Kitaoka 120a6e
  return this->compute_value(value2test);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
// normalization of parameter in range interval
Shinya Kitaoka 120a6e
double ToonzExt::SquarePotential::compute_shape(double value2test) const {
Shinya Kitaoka 120a6e
  double x                       = ref_->getLength(value2test);
Shinya Kitaoka 120a6e
  double shape                   = this->actionLength_ * 0.5;
Shinya Kitaoka 120a6e
  if (isAlmostZero(shape)) shape = 1.0;
Shinya Kitaoka 120a6e
  x                              = ((x - lenghtAtParam_) * range_) / shape;
Shinya Kitaoka 120a6e
  return x;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
double ToonzExt::SquarePotential::compute_value(double value2test) const {
Shinya Kitaoka 120a6e
  // use
Shinya Kitaoka 120a6e
  //     2
Shinya Kitaoka 120a6e
  //  1-x
Shinya Kitaoka 120a6e
  //
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  double x   = 0.0;
Shinya Kitaoka 120a6e
  double res = 0.0;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // lenght  at parameter
Shinya Kitaoka 120a6e
  x = ref_->getLength(value2test);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  double tmp_al = actionLength_ * 0.5;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // compute correct parameter considering offset
Shinya Kitaoka 120a6e
  // try to have a square curve like shape
Shinya Kitaoka 120a6e
  //
Shinya Kitaoka 120a6e
  //       2
Shinya Kitaoka 120a6e
  //  m = x
Shinya Kitaoka 120a6e
  //
Shinya Kitaoka 120a6e
  if (leftFactor_ == 0.0)
Shinya Kitaoka 120a6e
    x = 1.0 - x / tmp_al;
Shinya Kitaoka 120a6e
  else if (rightFactor_ == 0.0)
Shinya Kitaoka 120a6e
    x = (x - (strokeLength_ - tmp_al)) / tmp_al;
Shinya Kitaoka 120a6e
  else {
Shinya Kitaoka 120a6e
    if (x <= lenghtAtParam_ && ((lenghtAtParam_ - x) <= leftFactor_))
Shinya Kitaoka 120a6e
      x = (x - (lenghtAtParam_ - leftFactor_)) / leftFactor_;
Shinya Kitaoka 120a6e
    else if (x > lenghtAtParam_ && ((x - lenghtAtParam_) < rightFactor_))
Shinya Kitaoka 120a6e
      x = (rightFactor_ - (x - lenghtAtParam_)) / rightFactor_;
Shinya Kitaoka 120a6e
    else
Shinya Kitaoka 120a6e
      x = -1;
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  if (x < 0.0) return 0.0;
Shinya Kitaoka 120a6e
  // assert( 0.0 <= x &&
Shinya Kitaoka 120a6e
  //  x <= 1.0 + TConsts::epsilon );
Shinya Kitaoka 120a6e
  res = sq(x);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  return res;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
ToonzExt::Potential *ToonzExt::SquarePotential::clone() {
Shinya Kitaoka 120a6e
  return new SquarePotential;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
//  End Of File
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------