/* * Copyright (c) 2015 Tricoire Sebastien 3dsman@free.fr * * This software is provided 'as-is', without any express or implied * warranty. In no event will the authors be held liable for any damages * arising from the use of this software. * * Permission is granted to anyone to use this software for any purpose, * including commercial applications, and to alter it and redistribute it * freely, subject to the following restrictions: * * 1. The origin of this software must not be misrepresented; you must not * claim that you wrote the original software. If you use this software * in a product, an acknowledgment in the product documentation would be * appreciated but is not required. * 2. Altered source versions must be plainly marked as such, and must not be * misrepresented as being the original software. * 3. This notice may not be removed or altered from any source distribution. * */ #include "OE_document.h" #include "stitchs/OE_linestitch.h" #include #include OE_document::OE_document() { pthread_mutex_init(&writeLock, 0); OE_linestitch::initMotifs(); //ctor } OE_document::~OE_document() { } void OE_document::lock() { pthread_mutex_lock(&writeLock); } void OE_document::unlock() { pthread_mutex_unlock(&writeLock); } int OE_document::trylock() { pthread_mutex_trylock(&writeLock); } void OE_document::getBound(float* xMin, float* yMin, float* xMax, float* yMax) { float tmpXMin, tmpYMin, tmpXMax, tmpYMax; if (curves.size()) { std::list::iterator curve = curves.begin(); (*curve)->getBound(xMin, yMin, xMax, yMax); curve++; while (curve != curves.end()) { //for (unsigned i=0; igetBound(&tmpXMin, &tmpYMin, &tmpXMax, &tmpYMax); *xMin = minf(*xMin,tmpXMin); *yMin = minf(*yMin,tmpYMin); *xMax = maxf(*xMax,tmpXMax); *yMax = maxf(*yMax,tmpYMax); curve++; } std::list::iterator stitch = stitchs.begin(); while (stitch != stitchs.end()) { //for (unsigned i=0; igetBound(&tmpXMin, &tmpYMin, &tmpXMax, &tmpYMax); *xMin = minf(*xMin,tmpXMin); *yMin = minf(*yMin,tmpYMin); *xMax = maxf(*xMax,tmpXMax); *yMax = maxf(*yMax,tmpYMax); stitch++; } } } vector_2d OE_document::getHoopSize() { return hoopSize; } unsigned int OE_document::getPulseByMm() { return pulseByMm; } vector_2d OE_document::getZeroPoint() { return zeroPoint; } void OE_document::setHoopSize(vector_2d hoopSize) { this->hoopSize = hoopSize; } void OE_document::setPulseByMm(unsigned int pbm) { pulseByMm = pbm; } void OE_document::setZeroPoint(vector_2d zeroPoint) { this->zeroPoint = zeroPoint; } bool OE_document::addCurve(OE_curve * curve) { lock(); curves.push_back(curve); unlock(); return true; } bool OE_document::addStitch(OE_stitchs * stitch) { lock(); stitchs.push_back(stitch); unlock(); return true; } bool OE_document::addThread(OE_thread * thread) { lock(); threads.push_back(thread); unlock(); return true; } bool OE_document::removeCurve(OE_curve * curve) { lock(); curves.remove(curve); unlock(); } bool OE_document::removeStitch(OE_stitchs * stitch) { lock(); stitchs.remove(stitch); unlock(); } bool OE_document::removeThread(OE_thread * thread) { lock(); threads.remove(thread); unlock(); } bool OE_document::refresh() { return true; } /* bool OE_document::draw(float dpi) { for (unsigned i=0; idraw(); } return true; }*/