Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
 * @author  Fabrizio Morciano <fabrizio.morciano@gmail.com></fabrizio.morciano@gmail.com>
Toshihiro Shimizu 890ddd
 */
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "ext/StrokeParametricDeformer.h"
Toshihiro Shimizu 890ddd
#include "ext/NotSimmetricExpPotential.h"
Toshihiro Shimizu 890ddd
//#include "ext/NotSimmetricBezierPotential.h"
Toshihiro Shimizu 890ddd
//#include "ext/SquarePotential.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include <sstream></sstream>
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include <tstroke.h></tstroke.h>
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
using namespace std;
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
ToonzExt::StrokeParametricDeformer::StrokeParametricDeformer(
Shinya Kitaoka 120a6e
    double actionLenght, double startParameter, TStroke *s, Potential *pot)
Shinya Kitaoka 120a6e
    : startParameter_(startParameter)
Shinya Kitaoka 120a6e
    , actionLenght_(actionLenght)
Shinya Kitaoka 120a6e
    , vx_(1.0)
Shinya Kitaoka 120a6e
    , vy_(1.0)
Shinya Kitaoka 120a6e
    , pot_(0) {
Shinya Kitaoka 120a6e
  diff_ = 0.001;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  try {
Shinya Kitaoka 120a6e
    ref_copy_ = new TStroke(*s);
Shinya Kitaoka 120a6e
  } catch (std::bad_alloc &) {
Shinya Kitaoka 120a6e
    throw std::invalid_argument("Not possible to have a copy of stroke!!!");
Shinya Kitaoka 120a6e
  }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  assert(0.0 <= startParameter_ && startParameter_ <= 1.0);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // double
Shinya Kitaoka 120a6e
  //  max_length = s->getLength();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  //  if( actionLenght == -1 )
Shinya Kitaoka 120a6e
  //  {
Shinya Kitaoka 120a6e
  //    assert(false && "Rispristina la vecchia gestione");
Shinya Kitaoka 120a6e
  //    actionLenght_ = 2.0 * max_length;
Shinya Kitaoka 120a6e
  //  }
Shinya Kitaoka 120a6e
  //  else
Shinya Kitaoka 120a6e
  //  {
Shinya Kitaoka 120a6e
  assert(0.0 <= actionLenght_);
Shinya Kitaoka 120a6e
  // && actionLenght_ <= max_length );
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  if (0.0 > actionLenght_) actionLenght_ = 0.0;
Shinya Kitaoka 120a6e
  // else if ( actionLenght_ > max_length )
Shinya Kitaoka 120a6e
  //  actionLenght_ = max_length;
Shinya Kitaoka 120a6e
  //}
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  pot_ = pot;
Shinya Kitaoka 120a6e
  if (!pot_)
Shinya Kitaoka 120a6e
    throw std::invalid_argument("Not Possible to have a ref of Potential!!!");
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  pot_->setParameters(ref_copy_, startParameter_, actionLenght_);
Shinya Kitaoka 120a6e
  assert(pot_);
Shinya Kitaoka 120a6e
  startLenght_ = startParameter_;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void ToonzExt::StrokeParametricDeformer::setMouseMove(double vx, double vy) {
Shinya Kitaoka 120a6e
  vx_ = vx;
Shinya Kitaoka 120a6e
  vy_ = vy;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
ToonzExt::StrokeParametricDeformer::~StrokeParametricDeformer() {
Shinya Kitaoka 120a6e
  delete pot_;
Shinya Kitaoka 120a6e
  delete ref_copy_;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
TThickPoint ToonzExt::StrokeParametricDeformer::getDisplacement(
Shinya Kitaoka 120a6e
    const TStroke &stroke, double w) const {
Shinya Kitaoka 120a6e
  // conversion in absolute system for shape deformation
Shinya Kitaoka 120a6e
  double val = pot_->value(w);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  assert(val >= 0);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // amplify movement
Shinya Kitaoka 120a6e
  return TThickPoint(vx_ * val, vy_ * val, 0.0);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
TThickPoint ToonzExt::StrokeParametricDeformer::getDisplacementForControlPoint(
Shinya Kitaoka 120a6e
    const TStroke &stroke, UINT n) const {
Shinya Kitaoka 120a6e
  double w = stroke.getParameterAtControlPoint(n);
Shinya Kitaoka 120a6e
  return this->getDisplacement(stroke, w);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
TThickPoint
Toshihiro Shimizu 890ddd
ToonzExt::StrokeParametricDeformer::getDisplacementForControlPointLen(
Shinya Kitaoka 120a6e
    const TStroke &stroke, double cpLen) const {
Shinya Kitaoka 120a6e
  return this->getDisplacement(stroke, cpLen);
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
double ToonzExt::StrokeParametricDeformer::getDelta(const TStroke &stroke,
Shinya Kitaoka 120a6e
                                                    double w) const {
Toshihiro Shimizu 890ddd
#if 0
Toshihiro Shimizu 890ddd
  double  w0 = w;
Toshihiro Shimizu 890ddd
  if(w0 == 1.0)
Toshihiro Shimizu 890ddd
    return norm( stroke.getSpeed(1.0));
Toshihiro Shimizu 890ddd
  double tmp = stroke.getLength(w0);
Toshihiro Shimizu 890ddd
  tmp+=1.0;
Toshihiro Shimizu 890ddd
  double w1 = stroke.getParameterAtLength(tmp);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  /*
Toshihiro Shimizu 890ddd
  double  w1 = w + 0.01;  
Toshihiro Shimizu 890ddd
  if(w1>1.0)
Toshihiro Shimizu 890ddd
  {
Toshihiro Shimizu 890ddd
    w0 = 1.0 - 0.01;
Toshihiro Shimizu 890ddd
    w1 = 1.0;
Toshihiro Shimizu 890ddd
  }
Toshihiro Shimizu 890ddd
  */
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  const double  dx = 1.0; //stroke.getLength(w0,w1);
Toshihiro Shimizu 890ddd
  TThickPoint pnt = this->getDisplacement(stroke,w1) - 
Toshihiro Shimizu 890ddd
                    this->getDisplacement(stroke,w0);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  double  dy =  sqrt( sq(pnt.x) + sq(pnt.y) + sq(pnt.thick) );
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  assert(dx!=0.0);
Toshihiro Shimizu 890ddd
  return dy/dx;
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  /*
Toshihiro Shimizu 890ddd
  // the increaser is wrong than this value need to be the deformation
Toshihiro Shimizu 890ddd
  //  value 
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  // is norm 
Toshihiro Shimizu 890ddd
  TThickPoint pnt = this->getDisplacement(stroke,
Toshihiro Shimizu 890ddd
                                          w);
Toshihiro Shimizu 890ddd
  return sqrt( sq(pnt.x) + sq(pnt.y) + sq(pnt.thick) );
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
  //return pot_->gradient(w);
Toshihiro Shimizu 890ddd
  */
Toshihiro Shimizu 890ddd
#endif
Shinya Kitaoka 120a6e
  return this->getDisplacement(stroke, w).y;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
double ToonzExt::StrokeParametricDeformer::getMaxDiff() const { return diff_; }
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
void ToonzExt::StrokeParametricDeformer::getRange(double &from, double &to) {
Shinya Kitaoka 120a6e
  double x     = ref_copy_->getLength(startParameter_);
Shinya Kitaoka 120a6e
  double delta = x - actionLenght_ * 0.5;
Shinya Kitaoka 120a6e
  if (delta > 0)
Shinya Kitaoka 120a6e
    from = ref_copy_->getParameterAtLength(delta);
Shinya Kitaoka 120a6e
  else
Shinya Kitaoka 120a6e
    from = 0.0;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  delta = x + actionLenght_ * 0.5;
Shinya Kitaoka 120a6e
  if (delta < ref_copy_->getLength())
Shinya Kitaoka 120a6e
    to = ref_copy_->getParameterAtLength(delta);
Shinya Kitaoka 120a6e
  else
Shinya Kitaoka 120a6e
    to = 1.0;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
//  End Of File
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------