|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
// StrokeDeformation.cpp: implementation of the StrokeDeformation class.
|
|
Toshihiro Shimizu |
890ddd |
//
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
#ifdef _DEBUG
|
|
Toshihiro Shimizu |
890ddd |
#define _STLP_DEBUG 1
|
|
Toshihiro Shimizu |
890ddd |
#endif
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/StrokeDeformation.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/SquarePotential.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/StrokeParametricDeformer.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/NotSimmetricBezierPotential.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/SmoothDeformation.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/ContextStatus.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/Designer.h"
|
|
Toshihiro Shimizu |
890ddd |
//#include "ext/TriParam.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/StraightCornerDeformation.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/CornerDeformation.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/SmoothDeformation.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include "ext/StrokeDeformationImpl.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "DeformationSelector.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include <tcurves.h></tcurves.h>
|
|
Toshihiro Shimizu |
890ddd |
#include <tstrokeutil.h></tstrokeutil.h>
|
|
Toshihiro Shimizu |
890ddd |
#include <tmathutil.h></tmathutil.h>
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include <algorithm></algorithm>
|
|
Toshihiro Shimizu |
890ddd |
#include <iterator></iterator>
|
|
Toshihiro Shimizu |
890ddd |
#include <vector></vector>
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#include "tthreadmessage.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
using namespace ToonzExt;
|
|
Toshihiro Shimizu |
890ddd |
using namespace std;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/**
|
|
Toshihiro Shimizu |
890ddd |
* @brief Manage a mutable context.
|
|
Toshihiro Shimizu |
890ddd |
*/
|
|
Toshihiro Shimizu |
890ddd |
static TThread::Mutex s_mutex;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
StrokeDeformation::StrokeDeformation() {
|
|
Shinya Kitaoka |
120a6e |
state_ = CREATED;
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_ = SmoothDeformation::instance();
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
StrokeDeformation::~StrokeDeformation() {}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
void StrokeDeformation::activate(const ContextStatus *status) {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
assert(status && "Status is null!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!status) return;
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
if (state_ == RESETTED) delete this->deactivate();
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
if (state_ == CREATED || state_ == DEACTIVE) {
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_ = this->retrieveDeformator(status);
|
|
Shinya Kitaoka |
120a6e |
} else {
|
|
Shinya Kitaoka |
120a6e |
// if it is a not valid entry state_ recover
|
|
Shinya Kitaoka |
120a6e |
assert(deformationImpl_ && "Can not find a valid deformator!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) return;
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->reset();
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_ = DeformationSelector::instance()->getDeformation(status);
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
assert(deformationImpl_ && "Deformation is null!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) return;
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_->activate_impl(status)) {
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->reset();
|
|
Shinya Kitaoka |
120a6e |
state_ = DEACTIVE;
|
|
Shinya Kitaoka |
120a6e |
return;
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
state_ = ACTIVE;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
void StrokeDeformation::update(const TPointD &delta) {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
assert(deformationImpl_ && "Deformation is null!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) {
|
|
Shinya Kitaoka |
120a6e |
state_ = DEACTIVE;
|
|
Shinya Kitaoka |
120a6e |
return;
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
if (state_ != ACTIVE && state_ != UPDATING) {
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->reset();
|
|
Shinya Kitaoka |
120a6e |
state_ = ACTIVE;
|
|
Shinya Kitaoka |
120a6e |
return;
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->update_impl(delta);
|
|
Shinya Kitaoka |
120a6e |
state_ = UPDATING;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
TStroke *StrokeDeformation::deactivate() {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) {
|
|
Shinya Kitaoka |
120a6e |
state_ = DEACTIVE;
|
|
Shinya Kitaoka |
120a6e |
return 0;
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
if (state_ != ACTIVE && state_ != UPDATING) {
|
|
Shinya Kitaoka |
120a6e |
state_ = DEACTIVE;
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->reset();
|
|
Shinya Kitaoka |
120a6e |
return 0;
|
|
Shinya Kitaoka |
120a6e |
}
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
state_ = DEACTIVE;
|
|
Shinya Kitaoka |
120a6e |
TStroke *out = deformationImpl_->deactivate_impl();
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_ = 0;
|
|
Shinya Kitaoka |
120a6e |
return out;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
void StrokeDeformation::reset() {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
state_ = RESETTED;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
void StrokeDeformation::draw(Designer *designer) {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
assert(designer && "Designer is null!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_ || !designer) return;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
// this is to draw the icon
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->draw(designer);
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
// this is to draw stroke when change something
|
|
Shinya Kitaoka |
120a6e |
designer->draw(this);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
void StrokeDeformation::check(const ContextStatus *status) {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (state_ != UPDATING) deformationImpl_ = this->retrieveDeformator(status);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
const TStroke *StrokeDeformation::getCopiedStroke() const {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (deformationImpl_) return deformationImpl_->getCopiedStroke();
|
|
Shinya Kitaoka |
120a6e |
return 0;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
const TStroke *StrokeDeformation::getStroke() const {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (deformationImpl_) return deformationImpl_->getStrokeSelected();
|
|
Shinya Kitaoka |
120a6e |
return 0;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
const TStroke *StrokeDeformation::getTransformedStroke() const {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (deformationImpl_) return deformationImpl_->getTransformedStroke();
|
|
Shinya Kitaoka |
120a6e |
return 0;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
void StrokeDeformation::recover() {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
assert(deformationImpl_ && "Deformation is null!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) return;
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
deformationImpl_->reset();
|
|
Shinya Kitaoka |
120a6e |
// this->clearStatus();
|
|
Shinya Kitaoka |
120a6e |
|
|
Shinya Kitaoka |
120a6e |
// deformationImpl_ = DeformationSelector::instance()->getDeformation(status);
|
|
Shinya Kitaoka |
120a6e |
// assert(deformationImpl_ && "Deformation is null!!!" );
|
|
Shinya Kitaoka |
120a6e |
// if( !deformationImpl_ )
|
|
Shinya Kitaoka |
120a6e |
// return;
|
|
Shinya Kitaoka |
120a6e |
// deformationImpl_->activate_impl(status);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
const ContextStatus *StrokeDeformation::getStatus() const {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (deformationImpl_) return deformationImpl_->getImplStatus();
|
|
Shinya Kitaoka |
120a6e |
return 0;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
ToonzExt::Interval StrokeDeformation::getExtremes() const {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) return Interval(-1, -1);
|
|
Shinya Kitaoka |
120a6e |
return deformationImpl_->getExtremes();
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
StrokeDeformationImpl *StrokeDeformation::retrieveDeformator(
|
|
Shinya Kitaoka |
120a6e |
const ContextStatus *status) {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
return DeformationSelector::instance()->getDeformation(status);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
int StrokeDeformation::getCursorId() const {
|
|
Shinya Kitaoka |
120a6e |
QMutexLocker sl(&s_mutex);
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) return -1;
|
|
Shinya Kitaoka |
120a6e |
return deformationImpl_->getCursorId();
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
#ifdef _DEBUG
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
const Potential *StrokeDeformation::getPotential() const {
|
|
Shinya Kitaoka |
120a6e |
assert(deformationImpl_ && "Deformation is null!!!");
|
|
Shinya Kitaoka |
120a6e |
if (!deformationImpl_) return 0;
|
|
Shinya Kitaoka |
120a6e |
return deformationImpl_->getPotential();
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
|
|
Shinya Kitaoka |
120a6e |
const StrokeDeformationImpl *StrokeDeformation::getDeformationImpl() const {
|
|
Shinya Kitaoka |
120a6e |
return deformationImpl_;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
#endif
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|
|
Toshihiro Shimizu |
890ddd |
// End Of File
|
|
Toshihiro Shimizu |
890ddd |
//-----------------------------------------------------------------------------
|