front_idill/extern/fajran-npTuioClient/TuioClient/TuioPoint.h
author bastiena
Fri, 06 Apr 2012 18:32:13 +0200
changeset 25 a7b0e40bcab0
parent 24 2bdf5d51d434
child 28 9ccef81f02ab
permissions -rw-r--r--
Front IDILL : Basic JS TUIO lib loaded

/*
	TUIO C++ Library - part of the reacTIVision project
	http://reactivision.sourceforge.net/

	Copyright (c) 2005-2008 Martin Kaltenbrunner <mkalten@iua.upf.edu>
	
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

#ifndef INCLUDED_TUIOPOINT_H
#define INCLUDED_TUIOPOINT_H

#define TUIO_UNDEFINED -1

class TuioPoint {

	protected:
		float xpos, ypos, zpos;
		long timestamp;
	
	public:
	TuioPoint (float xpos, float ypos) {
		this->xpos = xpos;
		this->ypos = ypos;
		timestamp = TUIO_UNDEFINED;
	};

	/*
	* Surcharg� par alexandre.bastien@iri.centrepompidou.fr
	*/
	TuioPoint (float xpos, float ypos, float zpos) {
		this->xpos = xpos;
		this->ypos = ypos;
		this->zpos = zpos;
		timestamp = TUIO_UNDEFINED;
	};

	/*
	* Modifi� par alexandre.bastien@iri.centrepompidou.fr
	*/
	TuioPoint (TuioPoint *tuioPoint) {
		this->xpos = tuioPoint->getX();
		this->ypos = tuioPoint->getY();
		this->zpos = tuioPoint->getZ();
		timestamp = TUIO_UNDEFINED;
	};
	
	~TuioPoint(){};

	/*
	* Modifi� par alexandre.bastien@iri.centrepompidou.fr
	*/
	void update (TuioPoint *tuioPoint) {
		this->xpos = tuioPoint->getX();
		this->ypos = tuioPoint->getY();
		this->zpos = tuioPoint->getZ();
		timestamp = TUIO_UNDEFINED;
	};
	
	void update (float xpos, float ypos) {
		this->xpos = xpos;
		this->ypos = ypos;
		timestamp = TUIO_UNDEFINED;
	};

	/*
	* Surcharg� par alexandre.bastien@iri.centrepompidou.fr
	*/
	void update (float xpos, float ypos, float zpos) {
		this->xpos = xpos;
		this->ypos = ypos;
		this->zpos = zpos;
		timestamp = TUIO_UNDEFINED;
	};
	
	float getX() { return xpos; };
	float getY() { return ypos; };
	/*
	* Ajout� par alexandre.bastien@iri.centrepompidou.fr
	*/
	float getZ() { return zpos; };

	float getDistance(float x, float y) {
		float dx = xpos-x;
		float dy = ypos-y;
		return sqrtf(dx*dx+dy*dy);
	}
	
	/*
	* Surcharg� par alexandre.bastien@iri.centrepompidou.fr
	*/
	float getDistance(float x, float y, float z) {
		float dx = xpos-x;
		float dy = ypos-y;
		float dz = zpos-z;
		return sqrtf(dx*dx+dy*dy+dz*dz);
	}

	/*
	* Modifi� par alexandre.bastien@iri.centrepompidou.fr
	*/
	float getDistance(TuioPoint *tuioPoint) {
		float dx = xpos-tuioPoint->getX();
		float dy = ypos-tuioPoint->getY();
		float dz = zpos-tuioPoint->getZ();
		return sqrtf(dx*dx+dy*dy+dz*dz);
	}

	/*
	* Modifi� par alexandre.bastien@iri.centrepompidou.fr
	*/
	/*float getDistance3D(TuioPoint *tuioPoint) {
		float dx = xpos-tuioPoint->getX();
		float dy = ypos-tuioPoint->getY();
		float dz = zpos-tuioPoint->getZ();
		return sqrtf(dx*dx+dy*dy+dz*dz);
	}*/

	float getAngle(TuioPoint *tuioPoint) {
		
		float side = tuioPoint->getX()-xpos;
		float height = tuioPoint->getY()-ypos;
		float distance = tuioPoint->getDistance(xpos,ypos);
		
		float angle = (float)(asin(side/distance)+M_PI/2);
		if (height<0) angle = 2.0f*(float)M_PI-angle;
		
		return angle;
	}
	
	float getAngleDegrees(TuioPoint *tuioPoint) {
		return ((getAngle(tuioPoint)/(float)M_PI)*180.0f);
	}
	
	float getScreenX(int w) { return xpos*w; };
	float getScreenY(int h) { return ypos*h; };
	
	long getUpdateTime() { return timestamp; };
	void setUpdateTime(long timestamp) { this->timestamp = timestamp; };

};

#endif