Shinya Kitaoka 810553
#pragma once
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#ifndef STROKE_PARAMETRIC_DEFORMER_H
Toshihiro Shimizu 890ddd
#define STROKE_PARAMETRIC_DEFORMER_H
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 "tcommon.h"
Toshihiro Shimizu 890ddd
#include "tstrokedeformations.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#undef DVAPI
Toshihiro Shimizu 890ddd
#undef DVVAR
Toshihiro Shimizu 890ddd
#ifdef TNZEXT_EXPORTS
Toshihiro Shimizu 890ddd
#define DVAPI DV_EXPORT_API
Toshihiro Shimizu 890ddd
#define DVVAR DV_EXPORT_VAR
Toshihiro Shimizu 890ddd
#else
Toshihiro Shimizu 890ddd
#define DVAPI DV_IMPORT_API
Toshihiro Shimizu 890ddd
#define DVVAR DV_IMPORT_VAR
Toshihiro Shimizu 890ddd
#endif
Toshihiro Shimizu 890ddd
Shinya Kitaoka 9f5a1b
#if defined(_WIN32) && (_MSC_VER <= 1200)
Toshihiro Shimizu 890ddd
// to avoid annoying warning
Toshihiro Shimizu 890ddd
#pragma warning(push)
Toshihiro Shimizu 890ddd
#pragma warning(disable : 4290)
Toshihiro Shimizu 890ddd
#endif
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
class TStroke;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
namespace ToonzExt {
Toshihiro Shimizu 890ddd
class Potential;
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief This class implements new deformer.
Shinya Kitaoka 120a6e
   *
Toshihiro Shimizu 890ddd
   * New stroke deformer doesn't change last point of stroke.
Toshihiro Shimizu 890ddd
   */
Shinya Kitaoka 120a6e
class DVAPI StrokeParametricDeformer : public TStrokeDeformation {
Toshihiro Shimizu 890ddd
public:
Shinya Kitaoka 120a6e
  StrokeParametricDeformer(double actionLenght, double startParameter,
Shinya Kitaoka 120a6e
                           TStroke *s, Potential *);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  ~StrokeParametricDeformer();
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief Set mouse movement from last valid position.
Shinya Kitaoka 120a6e
*@param vx  horyzontal
Shinya Kitaoka 120a6e
*@param vy  vertical
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 120a6e
  void setMouseMove(double vx, double vy);
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief Return displacement to use with function increaseControlPoints
Shinya Kitaoka 120a6e
*@param stroke to test
Shinya Kitaoka 120a6e
*@param w stroke parameter
Shinya Kitaoka 120a6e
*@return displacement to apply to obtain deformation
Shinya Kitaoka 120a6e
*@sa increaseControlPoints
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 473e70
  TThickPoint getDisplacement(const TStroke &stroke, double w) const override;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief Return displacement to use with function  modifyControlPoints
Shinya Kitaoka 120a6e
*@param stroke to test
Shinya Kitaoka 120a6e
*@param n control point to get
Shinya Kitaoka 120a6e
*@return displacement to apply to obtain deformation
Shinya Kitaoka 120a6e
*@sa modifyControlPoints
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 120a6e
  TThickPoint getDisplacementForControlPoint(const TStroke &stroke,
Shinya Kitaoka 473e70
                                             UINT n) const override;
Shinya Kitaoka 120a6e
  TThickPoint getDisplacementForControlPointLen(const TStroke &stroke,
Shinya Kitaoka 473e70
                                                double cpLen) const override;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief This method compute the delta (gradient) referred to stroke in
Shinya Kitaoka 120a6e
*       at parameter w.
Shinya Kitaoka 120a6e
*
Shinya Kitaoka 120a6e
* This value is the result of \f$ \frac{getDisplacement(stroke,w)}{dw} \f$.
Shinya Kitaoka 120a6e
*@note Sometimes this value can be approximated.
Shinya Kitaoka 120a6e
*@param stroke Stroke to test
Shinya Kitaoka 120a6e
*@param w Stroke parameter
Shinya Kitaoka 120a6e
*@return the @b gradient in w
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 473e70
  double getDelta(const TStroke &stroke, double w) const override;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief Max diff of delta (This value indicates when it's necessary
Shinya Kitaoka 120a6e
*  to insert control point)
Shinya Kitaoka 120a6e
*@return max displacement permitted
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 473e70
  double getMaxDiff() const override;
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  // just for debug
Shinya Kitaoka 120a6e
  const Potential *getPotential() const { return pot_; }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief Change sensibility of deformer (just for debug).
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 120a6e
  void setDiff(double diff) { diff_ = diff; }
Shinya Kitaoka 120a6e
Shinya Kitaoka 120a6e
  /**
Shinya Kitaoka 120a6e
*@brief Retrieve the parameters range where is applied deformation.
Shinya Kitaoka 120a6e
*/
Shinya Kitaoka 120a6e
  void getRange(double &from, double &to);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
private:
Shinya Kitaoka 120a6e
  StrokeParametricDeformer(const StrokeParametricDeformer &);
Shinya Kitaoka 120a6e
  StrokeParametricDeformer &operator=(const StrokeParametricDeformer &);
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // mouse incremental movement
Shinya Kitaoka 120a6e
  double vx_, vy_;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // parameter where is applicated action
Shinya Kitaoka 120a6e
  double startParameter_;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // like startParameter_ but recover lenght
Shinya Kitaoka 120a6e
  double startLenght_;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // how many traits move
Shinya Kitaoka 120a6e
  double actionLenght_;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // deformation shape
Shinya Kitaoka 120a6e
  Potential *pot_;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  // sensibility of deformer
Shinya Kitaoka 120a6e
  // Indica il valore minimo a partire dal quale
Shinya Kitaoka 120a6e
  //  l'inseritore comincia a mettere punti di controllo
Shinya Kitaoka 120a6e
  double diff_;
Toshihiro Shimizu 890ddd
Shinya Kitaoka 120a6e
  TStroke *ref_copy_;
Toshihiro Shimizu 890ddd
};
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Shinya Kitaoka 9f5a1b
#if defined(_WIN32) && (_MSC_VER <= 1200)
Toshihiro Shimizu 890ddd
#pragma warning(pop)
Toshihiro Shimizu 890ddd
#endif
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#endif /* STROKE_PARAMETRIC_DEFORMER_H */
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
//  End Of File
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------