Skip to content
OE_controller.cpp 22 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 ) : comm("/dev/ttyUSB0", 80, 10)
OE_controller::OE_controller(OE_display * display, OE_document* document ) : comm("20:15:05:11:28:40", 80, 30)
{
	this->display = display;
	this->document = document;
	OE_linestitch::initMotifs();
	addThread(100,100,100,2);
}

OE_controller::~OE_controller()
{
}
        
bool OE_controller::testLogo2()
{
	// test motifs
	if (document)
	{
		
		addThread(220,120,20,2);
		document->setZeroPoint(vector_2d(0,1050));
		/*
		// bordure rectange haut
		addCurve(new OE_subcurve(getCurve(2),0.1, 0.8, false));
		//selectCurve(getCurve(document->curves.size()-1), true);
		addLineStitch(getCurve(document->curves.size()-1),1,2,4,-0.2);
		curStitch = document->stitchs.size()-1;
		setStitchThread(curStitch, getThread(1));*/
		// interrieur premier rectangle
		/*addCurve(new OE_subcurve(getCurve(2),0.1, 0.8, true));
		addCurve(new OE_subcurve(getCurve(2),2, 3, false));
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2), false, false, -0.2, -0.2, 1.0);
		curStitch = document->stitchs.size()-1;*/
		
		// interrieur 1er rectangle
		addCurve(new OE_subcurve(getCurve(2),2, 3, false));
		addCurve(new OE_subcurve(getCurve(2),0, 1, true));
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2), false, false, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		setStitchThread(curStitch, getThread(1));
		
		// interrieur 2eme rectangle
		addCurve(new OE_subcurve(getCurve(7),2, 4, true));
		addCurve(new OE_subcurve(getCurve(7),6, 1, false));
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2), false, false, 0.2, 0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		setStitchThread(curStitch, getThread(1));
		
		// interrieur 3eme rectangle
		addCurve(new OE_subcurve(getCurve(5),0, 1, false));
		addCurve(new OE_subcurve(getCurve(5),2, 3, true));
		addBirailStitch(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2), false, false, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		setStitchThread(curStitch, getThread(1));
		addLineStitch(getCurve(5));
		curStitch = document->stitchs.size()-1;
		//setLineStitchCurve(curStitch, getCurve(5));
		setLineStitchSize(curStitch,1,0.5);
		setStitchThread(curStitch, getThread(2));
		addCurve(new OE_subcurve(getCurve(1),0, 2, true));
		addCurve(new OE_subcurve(getCurve(1),2, 4, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-2),getCurve(document->curves.size()-1)));		
		addBirailStitch(getCurve(0), getCurve(document->curves.size()-1),false,false, 0.2, 0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		setStitchMaxLen(curStitch, 5);
		setStitchThread(curStitch, getThread(1));
		//selectCurve(getCurve(document->curves.size()-1), true);
		//E	
		addCurve(new OE_subcurve(getCurve(9),9, 10, false));
		addCurve(new OE_subcurve(getCurve(9),11, 12, true));
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, 0.2, 0.2, 0.5);
		addCurve(new OE_subcurve(getCurve(9),0, 2, false));
		addCurve(new OE_subcurve(getCurve(9),7, 9, false));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(9),3, 6, true));
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, 0.2, 0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		//l
		addCurve(new OE_subcurve(getCurve(11),3, 0, true));
		addCurve(new OE_subcurve(getCurve(11),1, 2, false));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		//e
		addCurve(new OE_subcurve(getCurve(13),0, 2, false));
		addCurve(new OE_joincurve(getCurve(12),getCurve(document->curves.size()-1)));
		addCurve(new OE_subcurve(getCurve(13),3, 9, true));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, 0.2, 0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		//c
		addCurve(new OE_subcurve(getCurve(16),10, 4, false));
		addCurve(new OE_subcurve(getCurve(16),5, 9, true));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, 0.2, 0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		
		//t
		addCurve(new OE_subcurve(getCurve(17),1, 2, true));	
		addCurve(new OE_subcurve(getCurve(17),5, 6, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(17),7,8, true));
		addCurve(new OE_subcurve(getCurve(17),15,16, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));	
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-4),false,true, 0.2, 0.2, 0.5);
		
		addCurve(new OE_subcurve(getCurve(17),2, 3, false));
		addCurve(new OE_subcurve(getCurve(17),12,15, false));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));	
		addCurve(new OE_subcurve(getCurve(17),4, 5, true));
		addCurve(new OE_subcurve(getCurve(17),8,11, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));	
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-4),true,true, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		
		//r
		
		addCurve(new OE_subcurve(getCurve(19),6, 7, true));
		addCurve(new OE_subcurve(getCurve(19),2, 3, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(19),4, 5, false));		
		addBirailStitch(getCurve(document->curves.size()-2),getCurve(document->curves.size()-1),false,false, 0.2, 0.2, 0.5);
		addCurve(new OE_subcurve(getCurve(19),0, 2, true));
		addCurve(new OE_subcurve(getCurve(19),7, 9, false));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		
		//o
		addCurve(new OE_subcurve(getCurve(22),0, 4, false));
		addCurve(new OE_subcurve(getCurve(21),0, 4, true));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, 0.2, 0.2, 0.5);
		
		//l
		addCurve(new OE_subcurve(getCurve(23),3, 0, true));
		addCurve(new OE_subcurve(getCurve(23),1, 2, false));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		
		//a
		
		addCurve(new OE_subcurve(getCurve(27),11, 12, true));
		addCurve(new OE_subcurve(getCurve(27),0, 2, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		
		addCurve(new OE_subcurve(getCurve(27),8, 10, false));
		addCurve(new OE_subcurve(getCurve(25),4, 0, false));	
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(27),3, 4, false));	
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addBirailStitch(getCurve(document->curves.size()-6), getCurve(document->curves.size()-1),true,true, -0.2, -0.2, 0.5);
		
		addCurve(new OE_subcurve(getCurve(25),0, 4, true));
		addCurve(new OE_subcurve(getCurve(27),4, 8, false));		
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-2),false,false, -0.2, -0.2, 0.5);
		curStitch = document->stitchs.size()-1;
		
		//b
		
		addCurve(new OE_subcurve(getCurve(29),6, 7, true));
		addCurve(new OE_subcurve(getCurve(28),2, 3, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(29),2, 3, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(29),4, 5, false));
		addBirailStitch(getCurve(document->curves.size()-2),getCurve(document->curves.size()-1),true,true, -0.2, -0.2, 0.5);
		
		addCurve(new OE_subcurve(getCurve(28),3, 5, true));
		addCurve(new OE_subcurve(getCurve(28),0, 2, true));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addCurve(new OE_subcurve(getCurve(29),0, 2, false));
		addCurve(new OE_subcurve(getCurve(29),7, 9, false));
		addCurve(new OE_joincurve(getCurve(document->curves.size()-1),getCurve(document->curves.size()-2)));
		addBirailStitch(getCurve(document->curves.size()-1), getCurve(document->curves.size()-4),true,true, 0.2, 0.2, 0.5);

		
		addLineStitch(getCurve(30),1.2,0.2,1,0);
		addLineStitch(getCurve(31),1.2,0.2,1,0);
		addLineStitch(getCurve(32),1.2,0.2,1,0);
		addLineStitch(getCurve(33),1.2,0.2,1,0);
		
		addLineStitch(getCurve(62),1.4,0.2,1,0);
		addLineStitch(getCurve(60),1.4,0.2,1,0);
		addLineStitch(getCurve(58),1.4,0.2,1,0);
		addLineStitch(getCurve(56),1.4,0.2,1,0);
		addLineStitch(getCurve(54),1.4,0.2,1,0);
		addCurve(new OE_subcurve(getCurve(52),4, 4, true));
		addLineStitch(getCurve(document->curves.size()-1),1.4,0.2,1,0);
		addLineStitch(getCurve(50),1.4,0.2,1,0);
		addCurve(new OE_subcurve(getCurve(48),9, 9, true));
		addLineStitch(getCurve(document->curves.size()-1),1.4,0.2,1,0);
		addCurve(new OE_subcurve(getCurve(46),4, 4, true));
		addLineStitch(getCurve(document->curves.size()-1),1.4,0.2,1,0);
		
		addLineStitch(getCurve(44),1.4,0.2,1,0);
		addCurve(new OE_subcurve(getCurve(42),4, 4, true));
		addLineStitch(getCurve(document->curves.size()-1),1.4,0.2,1,0);
		addLineStitch(getCurve(40),1.4,0.2,1,0);
		addLineStitch(getCurve(38),1.4,0.2,1,0);
		addLineStitch(getCurve(36),1.4,0.2,1,0);
		addCurve(new OE_subcurve(getCurve(34),7, 7, true));
		addLineStitch(getCurve(document->curves.size()-1),1.4,0.2,1,0);
		//addLineStitch(document->curves.at(15),1.5,3.5,1,0,0,0.1);
		/*
		setLineStitchCurve(0, getCurve(0));
		setLineStitchMotif(0, 1);
		setLineStitchSize(0,2,2);
		setStitchThread(0, getCurve(0));*/
		addLineStitch(getCurve(13),1,0.5,1,0.1);
		curStitch = document->stitchs.size()-1;
		setStitchThread(curStitch, getThread(0));
	}
	// fin motifs
	return false;
}

bool OE_controller::setDefault()
{
	OE_birailstitch::defaultLen = 1;
	OE_birailstitch::defaultMaxlen = 0;
OE_curve* OE_controller::getCurve (unsigned index)
{
	if ((document)&&(index<document->curves.size()))
	{
		std::list<OE_curve*>::iterator curve = document->curves.begin();
		for(unsigned i=0; i<index;i++)
			curve++;
		return (*curve);
	}

	return nullptr;
}

OE_pointcurve* OE_controller::getPointcurve (unsigned index)
{
	//if ((document)&&(index<document->curves.size()))
		return (dynamic_cast<OE_pointcurve*> (getCurve (index)));
}

OE_subcurve* OE_controller::getSubcurve (unsigned index)
{
	//if ((document)&&(index<document->curves.size()))
		return (dynamic_cast<OE_subcurve*> (getCurve (index)));
}

OE_joincurve* OE_controller::getJoincurve (unsigned index)
{
	//if ((document)&&(index<document->curves.size()))
		return (dynamic_cast<OE_joincurve*> (getCurve (index)));
OE_stitchs* OE_controller::getStitch (unsigned index)
{
	if ((document)&&(index<document->stitchs.size()))
	{
		std::list<OE_stitchs*>::iterator stitch = document->stitchs.begin();
		for(unsigned i=0; i<index;i++)
			stitch++;
		return (*stitch);
	}
		//return document->stitchs.at(index);
OE_linestitch* OE_controller::getLineStitch (unsigned index)
	//if ((document)&&(index<document->stitchs.size()))
		return (dynamic_cast<OE_linestitch*> (getStitch(index)));
}

OE_birailstitch* OE_controller::getBirailStitch (unsigned index)
{
	//if ((document)&&(index<document->stitchs.size()))
		return (dynamic_cast<OE_birailstitch*> (getStitch(index)));
OE_linkstitch* OE_controller::getLinkStitch (unsigned index)
{
	//if ((document)&&(index<document->stitchs.size()))
		return (dynamic_cast<OE_linkstitch*> (getStitch(index)));
OE_thread* OE_controller::getThread (unsigned index)
{
	if ((document)&&(index<document->threads.size()))
	{
		std::list<OE_thread*>::iterator thread = document->threads.begin();
		for(unsigned i=0; i<index;i++)
			thread++;
		return (*thread);
	}
		//return document->threads.at(index);

bool OE_controller::addStitch(OE_stitchs * stitch)
{
	if (document)
	{
		if (document->stitchs.size() > 0)
		{
			OE_stitchs* tmpstitch = document->stitchs.back();
			document->addStitch( new OE_linkstitch(tmpstitch, stitch));
			
		}
		
bool OE_controller::addCurve( std::vector<vector_2d> points, bool closed)
{
	if (document)
	{
		return document->addCurve( new OE_pointcurve(points, closed));
	}
	return false;
}

bool OE_controller::addCurve( OE_curve* curve)
{
	if (document)
	{
		return document->addCurve( curve);
bool OE_controller::addLineStitch(OE_curve* curve)
	return addLineStitch( curve, 1, 0, 0, 0);
bool OE_controller::addLineStitch( OE_curve* curve, float len, float width, unsigned motif, float offset)
{
	if (document)
		return addStitch(new OE_linestitch(document->threads.front(), curve, len, width, motif, offset));
bool OE_controller::addBirailStitch(OE_curve* curve1, OE_curve* curve2, bool reverse1, bool reverse2, float offset1, float offset2, float len)
		return addStitch(new OE_birailstitch(document->threads.front(), curve1, curve2, reverse1, reverse2, offset1, offset2, len));
bool OE_controller::addThread()
{
	if (document)
		return document->addThread(new OE_thread());

	return false;
}

bool OE_controller::addThread(unsigned char r, unsigned char g, unsigned char b, float width )
{
	if (document)
		return document->addThread(new OE_thread(r, g, b, width));

	return false;
}

bool OE_controller::selectCurve( OE_curve* curve, bool add)
{
	if (document)
	{
		if (!add) document->selectedCurves.clear();
		document->selectedCurves.push_back(curve);
		return true;
	}
	return false;
}

bool OE_controller::selectStitch( OE_stitchs* stitch, bool add)
{
	if (document)
	{
		if (!add) document->selectedStitchs.clear();
		document->selectedStitchs.push_back(stitch);
		return true;
	}
	return false;
}

bool OE_controller::refreshStitchs()
{
	if (document)
	{
		std::list<OE_stitchs*>::iterator stitch = document->stitchs.begin();
		
		while (stitch != document->stitchs.end())
		{
		//for(unsigned i = 0; i < document->stitchs.size();i++)
			(*stitch)->refresh();
			stitch++;
		}
bool OE_controller::setStitchMaxLen( unsigned index, float maxLen)
{
	if ((document)&&(index<document->stitchs.size()))
	{
		getStitch(index)->setMaxLen(maxLen);
bool OE_controller::setLineStitchMotif( unsigned index, unsigned motif)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setMotif(motif);
	return true;
}

bool OE_controller::setLineStitchCurve( unsigned index, OE_curve* curve)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setCurve(curve);
	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);
	return true;
}
bool OE_controller::setLineStitchSizeReverse(unsigned index, bool reverse)
{
	OE_linestitch * tmpstitch = getLineStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setReverse(reverse);
	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);
	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);
	return true;
}
bool OE_controller::setLinkStitchStitch( unsigned index, OE_stitchs* stitchStart, OE_stitchs* stitchEnd)
{
	OE_linkstitch * tmpstitch = getLinkStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setStitchStart(stitchStart);
	tmpstitch->setStitchStart(stitchEnd);
	return true;
}

bool OE_controller::setStitchThread(unsigned index, OE_thread * thread)
{
	OE_stitchs * tmpstitch = getStitch(index);
	if (!tmpstitch)return false;
	
	tmpstitch->setThread(thread);

	return true;
}

bool OE_controller::setThreadColor(unsigned index, unsigned char r, unsigned char g, unsigned char b )
{
	OE_thread * tmpthread = getThread(index);
	if (!tmpthread)return false;
	
	tmpthread->setColor(r, g, b);

	return true;
}

bool OE_controller::setThreadWidth(unsigned index, float width)
{
	OE_thread * tmpthread = getThread(index);
	if (!tmpthread)return false;
	
	tmpthread->setWidth(width);

	return true;
}

bool OE_controller::setsubcurvePos( unsigned index, float start, float end)
{
	OE_subcurve * tmpcurve = getSubcurve(index);
	if (!tmpcurve)return false;
	
	tmpcurve->setStart(start);
	tmpcurve->setEnd(end);
	return true;
}

bool OE_controller::generateInstructions()
{
		
	if (document)
	{
		document->instPoints.clear();
		for (unsigned i = 0; i < document->instCommand.size(); i++) {
			delete (document->instCommand.at(i));
		}
		document->instCommand.clear();
		
		std::list<OE_stitchs*>::iterator stitch = document->stitchs.begin();
		
		OE_thread * instThread = (*stitch)->getThread();
		if(!instThread)
			instThread = document->threads.front();
		
		document->instCommand.push_back(new OE_start(document->instPoints.size(), instThread->getColor()));
		
		while (stitch != document->stitchs.end())
		{
			(*stitch)->refresh();
			if((*stitch)->check()&&(*stitch)->getNpts()>0)
			{
				OE_thread * curThread = (*stitch)->getThread();
				if (!curThread)
					curThread = document->threads.front();
				if ((curThread!=instThread))
					instThread = curThread;
					document->instCommand.push_back(new OE_waitcolor(document->instPoints.size(), instThread->getColor()));
				}								
				std::vector<vector_2d> points = (*stitch)->getPoints();
			
				document->instPoints.insert( document->instPoints.end(), points.begin(), points.end() );

			}
			stitch++;
		}
		
		vector_2d zero = document->getZeroPoint();
		float size = document->getPulseByMm();
		for ( unsigned i = 0; i < document->instPoints.size(); i++)
		{
			document->instPoints.at(i) = (document->instPoints.at(i) - zero)*size;
		}
	}
	return true;
}

3dsman's avatar
3dsman committed
uint8_t int7(int i) // transform int32 to int7
{
	if (i>=0)
		return i;
	int8_t i8 = 2*i;
	return (*(uint8_t*)&i8)>>1;
}

void OE_controller::sendInstPoint()
{
	static bool running = false;
	static int oldX, oldY;
	static unsigned sndPoint;
	static uint8_t dxys[32];
	static bool started = false;

	if (!running)
	{
3dsman's avatar
3dsman committed
		std::cout << "sendInstPoint x " << document->instPoints.size() <<std::endl;
		comm.stopMove();
		if (!comm.ack()) std::cerr << "Can't set pos" << std::endl;
		comm.setPos(0, 0);
		if (!comm.ack()) std::cerr << "Can't set pos" << std::endl;
		comm.setNPoint(0);
		if (!comm.ack()) std::cerr << "Can't set point" << std::endl;
		comm.deletePoints();
		if (!comm.ack()) std::cerr << "Can't delete points" << std::endl;
		oldX = oldY = 0;
		sndPoint = 0;
		running = true;
	} else {
		document->curPoint = comm.info.nPoint;
		int x, y, dx, dy, bigdx, bigdy;
		unsigned cmdPoints = 0;
		if (!started && comm.info.spaceSize && (comm.info.freeSpace<512)) {
			comm.startMove();
			if (!comm.ack()) std::cerr << "Can't start" << std::endl;
			started = true;
		}
		if ((sndPoint<document->instPoints.size()) && comm.info.spaceSize && (comm.info.freeSpace>64))
3dsman's avatar
3dsman committed
		{
			while (sndPoint<document->instPoints.size())
3dsman's avatar
3dsman committed
			{
				x = roundf(document->instPoints.at(sndPoint).x);
				y = roundf(-document->instPoints.at(sndPoint).y);
				dx = x-oldX;
				dy = y-oldY;
				if ((dx<-64)||(63<dx)||(dy<-64)||(63<dy))
3dsman's avatar
3dsman committed
				{
					bigdx = (dx+(dx>=0?0:1))/64;
					bigdy = (dy+(dy>=0?0:1))/64;
					dx -= 64*bigdx;
					dy -= 64*bigdy;
					if (cmdPoints==15)
					{
						comm.addPoints(dxys, 15);
						if (!comm.ack()) std::cerr << "Can't add points" << std::endl;
						return;
					}
					dxys[2*cmdPoints] = 0x80|int7(bigdx);
					dxys[2*cmdPoints+1] = int7(bigdy);
					cmdPoints++;
3dsman's avatar
3dsman committed
				}
				dxys[2*cmdPoints] = int7(dx);
				dxys[2*cmdPoints+1] = int7(dy);
3dsman's avatar
3dsman committed
				cmdPoints++;
				sndPoint++;
				oldX = x;
				oldY = y;
				if (cmdPoints==16)
				{
					comm.addPoints(dxys, 16);
					if (!comm.ack()) std::cerr << "Can't add points" << std::endl;
					return;
				}
3dsman's avatar
3dsman committed
			}
3dsman's avatar
3dsman committed
			{
				comm.addPoints(dxys, cmdPoints);
3dsman's avatar
3dsman committed
				if (!comm.ack()) std::cerr << "Can't add points" << std::endl;
3dsman's avatar
3dsman committed
			}
		}