Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#ifndef TNZ_EXTUTIL_H
Toshihiro Shimizu 890ddd
#define TNZ_EXTUTIL_H
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
 * @author  Fabrizio Morciano <fabrizio.morciano@gmail.com>
Toshihiro Shimizu 890ddd
 */
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#include "tcommon.h"
Toshihiro Shimizu 890ddd
#include <tvectorimage.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
Toshihiro Shimizu 890ddd
#include "ext/Types.h"
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
namespace ToonzExt
Toshihiro Shimizu 890ddd
{
Toshihiro Shimizu 890ddd
// Functions for straight corners management.
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Like cornersDetector but for straight corners.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
straightCornersDetector(const TStroke *stroke,
Toshihiro Shimizu 890ddd
						std::vector<double> &corners);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Find intervals where stroke is a straight line.
Toshihiro Shimizu 890ddd
   *
Toshihiro Shimizu 890ddd
   * These intervals are stored in an @c vector od Interval.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
detectStraightIntervals(const TStroke *stroke,
Toshihiro Shimizu 890ddd
						ToonzExt::Intervals &intervals,
Toshihiro Shimizu 890ddd
						double tolerance = TConsts::epsilon);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Retrieve parameters for straight intervals 
Toshihiro Shimizu 890ddd
   * near actualW parameter.
Toshihiro Shimizu 890ddd
   *
Toshihiro Shimizu 890ddd
   * @return If not found return [-1,-1] interval, else 
Toshihiro Shimizu 890ddd
   *         the correct interval.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
findNearestStraightCorners(const TStroke *s,
Toshihiro Shimizu 890ddd
						   double actualW,
Toshihiro Shimizu 890ddd
						   Interval &out,
Toshihiro Shimizu 890ddd
						   const ToonzExt::Intervals *const cl = 0,
Toshihiro Shimizu 890ddd
						   double tolerance = TConsts::epsilon);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
isAStraightCorner(const TStroke *s,
Toshihiro Shimizu 890ddd
				  double actualW,
Toshihiro Shimizu 890ddd
				  const ToonzExt::Intervals *const cl = 0,
Toshihiro Shimizu 890ddd
				  double tolerance = TConsts::epsilon);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
// Functions for spire corners management.
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Enhanced version of Toonz detect corners.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
cornersDetector(const TStroke *stroke,
Toshihiro Shimizu 890ddd
				int minDegree,
Toshihiro Shimizu 890ddd
				std::vector<double> &corners);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Find intervals where stroke has limited from spire.
Toshihiro Shimizu 890ddd
   *
Toshihiro Shimizu 890ddd
   * These intervals are stored in an @c vector od Interval.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
detectSpireIntervals(const TStroke *stroke,
Toshihiro Shimizu 890ddd
					 ToonzExt::Intervals &intervals,
Toshihiro Shimizu 890ddd
					 int minDegree);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Retrieve parameters for corners near actualW parameter.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
findNearestSpireCorners(const TStroke *s,
Toshihiro Shimizu 890ddd
						double actualW,
Toshihiro Shimizu 890ddd
						Interval &out,
Toshihiro Shimizu 890ddd
						int cornerSize,
Toshihiro Shimizu 890ddd
						const ToonzExt::Intervals *const cl = 0,
Toshihiro Shimizu 890ddd
						double tolerance = TConsts::epsilon);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
isASpireCorner(const TStroke *s,
Toshihiro Shimizu 890ddd
			   double w,
Toshihiro Shimizu 890ddd
			   int cornerSize,
Toshihiro Shimizu 890ddd
			   const ToonzExt::Intervals *const cl = 0,
Toshihiro Shimizu 890ddd
			   double tolerance = TConsts::epsilon);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Retrieve corners of a TStroke.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI void
Toshihiro Shimizu 890ddd
findCorners(const TStroke *stroke,
Toshihiro Shimizu 890ddd
			Intervals &corners,
Toshihiro Shimizu 890ddd
			Intervals &intervals,
Toshihiro Shimizu 890ddd
			int angle,
Toshihiro Shimizu 890ddd
			double tolerance);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Retrieve corners of a TStroke.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
findNearestCorners(const TStroke *stroke,
Toshihiro Shimizu 890ddd
				   double w,
Toshihiro Shimizu 890ddd
				   Interval &out,
Toshihiro Shimizu 890ddd
				   const Intervals &values,
Toshihiro Shimizu 890ddd
				   double tolerance = TConsts::epsilon);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//  Stroke related functions.
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Rotate the control point at even position [0,2,4,...] in a
Toshihiro Shimizu 890ddd
   * new position along the close path of a selfLoop stroke.
Toshihiro Shimizu 890ddd
   *
Toshihiro Shimizu 890ddd
   * The new position is: @b atLenght.
Toshihiro Shimizu 890ddd
   * @return 0 if some problem occurs, else the new stroke.
Toshihiro Shimizu 890ddd
   * @todo Some refactoring required, code duplication.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI TStroke *
Toshihiro Shimizu 890ddd
rotateControlPoint(const TStroke *stroke,
Toshihiro Shimizu 890ddd
				   const ToonzExt::EvenInt &even,
Toshihiro Shimizu 890ddd
				   double atLenght);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * Retrieve all parameters where stroke has a minimum.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
getAllW(const TStroke *stroke,
Toshihiro Shimizu 890ddd
		const TPointD &pnt,
Toshihiro Shimizu 890ddd
		double &dist2,
Toshihiro Shimizu 890ddd
		std::vector<double> &parameters);
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Replace a stroke in a vector image.
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
DVAPI bool
Toshihiro Shimizu 890ddd
replaceStroke(TStroke *old_stroke,
Toshihiro Shimizu 890ddd
			  TStroke *new_stroke,
Toshihiro Shimizu 890ddd
			  unsigned int n_,
Toshihiro Shimizu 890ddd
			  TVectorImageP &vi);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
/**
Toshihiro Shimizu 890ddd
   * @brief Copy several parameters that are not 
Toshihiro Shimizu 890ddd
   *        copied with operator= 
Toshihiro Shimizu 890ddd
   */
Toshihiro Shimizu 890ddd
void cloneStrokeStatus(const TStroke *from,
Toshihiro Shimizu 890ddd
					   TStroke *to);
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//---------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
template <class T>
Toshihiro Shimizu 890ddd
inline bool
Toshihiro Shimizu 890ddd
isValid(const T *s)
Toshihiro Shimizu 890ddd
{
Toshihiro Shimizu 890ddd
	assert(0 != s);
Toshihiro Shimizu 890ddd
	if (!s)
Toshihiro Shimizu 890ddd
		return false;
Toshihiro Shimizu 890ddd
	return true;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//---------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
inline bool
Toshihiro Shimizu 890ddd
isValid(double w)
Toshihiro Shimizu 890ddd
{
Toshihiro Shimizu 890ddd
	assert(0.0 <= w &&
Toshihiro Shimizu 890ddd
		   w <= 1.0);
Toshihiro Shimizu 890ddd
	if (w < 0.0 ||
Toshihiro Shimizu 890ddd
		w > 1.0)
Toshihiro Shimizu 890ddd
		return false;
Toshihiro Shimizu 890ddd
	return true;
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
//---------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
}
Toshihiro Shimizu 890ddd
Toshihiro Shimizu 890ddd
#endif /* TNZ_EXTUTIL_H */
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------
Toshihiro Shimizu 890ddd
//  End Of File
Toshihiro Shimizu 890ddd
//-----------------------------------------------------------------------------