|
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> ¶meters);
|
|
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 |
//-----------------------------------------------------------------------------
|