Skip to content
OE_controller.cpp 5.68 KiB
Newer Older
/*
 * 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_controller.h"
#include <iostream>
#include <typeinfo>


OE_controller::OE_controller(OE_display * display, OE_document* document )
{
	this->display = display;
	this->document = document;
	OE_linestitch::initMotifs();
}

OE_controller::~OE_controller()
{
}
        
bool OE_controller::test()
{
	// test motifs
	if (document)
	{
		//addLineStitch(document->curves.at(0),0,0,1,0,1,0.1);
		addLineStitch(document->curves.at(13),0,0,1,0.5,1,0.1);
		//addLineStitch(document->curves.at(15),1.5,3.5,1,0,0,0.1);
		addLineStitch();
		setLineStitchCurve(0, document->curves.at(0));
		setLineStitchMotif(0, 1);
		setLineStitchSize(0,2,2);
		setLineStitchCurve(1, document->curves.at(1));
		setLineStitchSize(1,3,2);
		addLineStitch(document->curves.at(2),0.1,0.8,0.5,1,1,-0.5);
		
		addBirailStitch(document->curves.at(0), document->curves.at(1), 0, 0, 2, 2,false,true, 0, 0, 1.5);
		addBirailStitch(document->curves.at(0), document->curves.at(1), 2, 2, 4, 4,false,true, 0, 0, 1.5);
		addBirailStitch(document->curves.at(2), document->curves.at(2), 0.1, 2, 0.8, 3, false, true, -1.2, -1.2, 1.5);
	}
	// fin motifs
	return false;
}

bool OE_controller::setDefault()
{
	OE_birailstitch::defaultLen = 1;
	OE_birailstitch::defaultMaxlen = 0;
OE_linestitch* OE_controller::getLineStitch (unsigned index)
{
	if ((document)&&(index<document->stitchs.size()))
		return (dynamic_cast<OE_linestitch*> (document->stitchs.at(index)));

	return nullptr;
}

OE_birailstitch* OE_controller::getBirailStitch (unsigned index)
{
	if ((document)&&(index<document->stitchs.size()))
		return (dynamic_cast<OE_birailstitch*> (document->stitchs.at(index)));

	return nullptr;
}
		
bool OE_controller::addCurve( std::vector<vector_2d> points, bool closed)
{
	if (document)
	{
		return document->addCurve( new OE_curve(points, closed));
	}
	return false;
}

bool OE_controller::addLineStitch()
{
	if (document)
		return document->addStitch(new OE_linestitch());

	return false;
}

bool OE_controller::addLineStitch( OE_curve* curve,float curveStart, float curveEnd, float len, float width, unsigned motif, float offset)
{
	if (document)
		return document->addStitch(new OE_linestitch(curve,curveStart, curveEnd, len, width, motif, offset));

	return false;
}

bool OE_controller::addBirailStitch()
{
	if (document)
		return document->addStitch(new OE_birailstitch());

	return false;
}
bool OE_controller::addBirailStitch(OE_curve* curve1, OE_curve* curve2, float curve1Start, float curve2Start, float curve1End, float curve2End, bool reverse1, bool reverse2, float offset1, float offset2, float len)
		return document->addStitch(new OE_birailstitch(curve1, curve2, curve1Start, curve2Start, curve1End, curve2End, reverse1, reverse2, offset1, offset2, len));
bool OE_controller::setLineStitchMotif( unsigned index, unsigned motif)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setMotif(motif);
	tmpstitch->needRefresh=true;
	return true;
}

bool OE_controller::setLineStitchCurve( unsigned index, OE_curve* curve)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setCurve(curve);
	tmpstitch->needRefresh=true;
	return true;
}

bool OE_controller::setLineStitchSub( unsigned index, float start, float end)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setStart(start);
	tmpstitch->setEnd(end);
	tmpstitch->needRefresh=true;
	return true;
}

bool OE_controller::setLineStitchSize( unsigned index, float len, float width)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setLen(len);
	tmpstitch->setWidth(width);
	tmpstitch->needRefresh=true;
	return true;
}

bool OE_controller::setBirailStitchCurves( unsigned index, OE_curve* curve1, OE_curve* curve2)
{
	OE_birailstitch * tmpstitch = getBirailStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setCurve1(curve1);
	tmpstitch->setCurve2(curve2);
	tmpstitch->needRefresh=true;
	return true;
}

bool OE_controller::setBirailStitchSub( unsigned index, float start1, float end1, bool reverse1, float start2, float end2, bool reverse2)
{
	OE_birailstitch * tmpstitch = getBirailStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setStart1(start1);
	tmpstitch->setEnd1(end1);
	tmpstitch->setReverse1(reverse1);
	tmpstitch->setStart1(start2);
	tmpstitch->setEnd1(end2);
	tmpstitch->setReverse1(reverse2);
	tmpstitch->needRefresh=true;
	return true;
}

bool OE_controller::setBirailStitchSize( unsigned index, float len, float offset1, float offset2)
{
	OE_birailstitch * tmpstitch = getBirailStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setLen(len);
	tmpstitch->setOffset1(offset1);
	tmpstitch->setOffset2(offset2);
	tmpstitch->needRefresh=true;
	return true;
}