front_processing/extern/TUIO_JAVA/src/TUIO/TuioContainer.java
author bastiena
Fri, 09 Mar 2012 14:52:11 +0100
changeset 0 6fefd4afe506
child 3 92f19af39024
permissions -rw-r--r--
First Import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     1
/*
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     2
 TUIO Java backend - part of the reacTIVision project
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     3
 http://reactivision.sourceforge.net/
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     4
 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     5
 Copyright (c) 2005-2009 Martin Kaltenbrunner <mkalten@iua.upf.edu>
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     6
 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     7
 This program is free software; you can redistribute it and/or modify
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     8
 it under the terms of the GNU General Public License as published by
6fefd4afe506 First Import
bastiena
parents:
diff changeset
     9
 the Free Software Foundation; either version 2 of the License, or
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    10
 (at your option) any later version.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    11
 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    12
 This program is distributed in the hope that it will be useful,
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    13
 but WITHOUT ANY WARRANTY; without even the implied warranty of
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    14
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    15
 GNU General Public License for more details.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    16
 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    17
 You should have received a copy of the GNU General Public License
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    18
 along with this program; if not, write to the Free Software
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    19
 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    20
 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    21
package TUIO;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    22
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    23
import java.util.*;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    24
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    25
/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    26
 * The abstract TuioContainer class defines common attributes that apply to both subclasses {@link TuioObject} and {@link TuioCursor}.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    27
 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    28
 * @author Martin Kaltenbrunner
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    29
 * @version 1.4
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    30
 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    31
abstract class TuioContainer extends TuioPoint {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    32
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    33
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    34
	 * The unique session ID number that is assigned to each TUIO object or cursor.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    35
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    36
	protected long session_id;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    37
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    38
	 * The X-axis velocity value.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    39
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    40
	protected float x_speed;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    41
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    42
	 * The Y-axis velocity value.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    43
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    44
	protected float y_speed;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    45
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    46
	 * The motion speed value.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    47
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    48
	protected float motion_speed;	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    49
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    50
	 * The motion acceleration value.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    51
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    52
	protected float motion_accel;		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    53
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    54
	 * A Vector of TuioPoints containing all the previous positions of the TUIO component.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    55
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    56
	protected Vector<TuioPoint> path;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    57
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    58
	 * Defines the ADDED state.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    59
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    60
	public static final int TUIO_ADDED = 0;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    61
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    62
	 * Defines the ACCELERATING state.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    63
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    64
	public static final int TUIO_ACCELERATING = 1;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    65
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    66
	 * Defines the DECELERATING state.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    67
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    68
	public static final int TUIO_DECELERATING = 2;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    69
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    70
	 * Defines the STOPPED state.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    71
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    72
	public static final int TUIO_STOPPED = 3;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    73
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    74
	 * Defines the REMOVED state.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    75
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    76
	public static final int TUIO_REMOVED = 4;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    77
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    78
	 * Reflects the current state of the TuioComponent
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    79
	 */ 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    80
	protected int state;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    81
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    82
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    83
	 * This constructor takes a TuioTime argument and assigns it along with the provided 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    84
	 * Session ID, X and Y coordinate to the newly created TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    85
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    86
	 * @param	ttime	the TuioTime to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    87
	 * @param	si	the Session ID to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    88
	 * @param	xp	the X coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    89
	 * @param	yp	the Y coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    90
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    91
	TuioContainer(TuioTime ttime, long si, float xp, float yp) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    92
		super(ttime,xp,yp);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    93
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    94
		session_id = si;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    95
		x_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    96
		y_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    97
		motion_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    98
		motion_accel = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
    99
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   100
		path = new Vector<TuioPoint>();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   101
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   102
		state = TUIO_ADDED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   103
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   104
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   105
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   106
	 * This constructor takes the provided Session ID, X and Y coordinate 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   107
	 * and assigs these values to the newly created TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   108
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   109
	 * @param	si	the Session ID to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   110
	 * @param	xp	the X coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   111
	 * @param	yp	the Y coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   112
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   113
	TuioContainer(long si, float xp, float yp) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   114
		super(xp,yp);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   115
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   116
		session_id = si;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   117
		x_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   118
		y_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   119
		motion_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   120
		motion_accel = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   121
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   122
		path = new Vector<TuioPoint>();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   123
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   124
		state = TUIO_ADDED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   125
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   126
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   127
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   128
	 * This constructor takes the atttibutes of the provided TuioContainer 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   129
	 * and assigs these values to the newly created TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   130
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   131
	 * @param	tcon	the TuioContainer to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   132
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   133
	TuioContainer(TuioContainer tcon) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   134
		super(tcon);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   135
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   136
		session_id = tcon.getSessionID();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   137
		x_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   138
		y_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   139
		motion_speed = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   140
		motion_accel = 0.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   141
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   142
		path = new Vector<TuioPoint>();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   143
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   144
		state = TUIO_ADDED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   145
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   146
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   147
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   148
	 * Takes a TuioTime argument and assigns it along with the provided 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   149
	 * X and Y coordinate to the private TuioContainer attributes.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   150
	 * The speed and accleration values are calculated accordingly.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   151
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   152
	 * @param	ttime	the TuioTime to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   153
	 * @param	xp	the X coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   154
	 * @param	yp	the Y coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   155
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   156
	public void update(TuioTime ttime, float xp, float yp) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   157
		TuioPoint lastPoint = path.lastElement();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   158
		super.update(ttime,xp,yp);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   159
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   160
		TuioTime diffTime = currentTime.subtract(lastPoint.getTuioTime());
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   161
		float dt = diffTime.getTotalMilliseconds()/1000.0f;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   162
		float dx = this.xpos - lastPoint.getX();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   163
		float dy = this.ypos - lastPoint.getY();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   164
		float dist = (float)Math.sqrt(dx*dx+dy*dy);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   165
		float last_motion_speed = this.motion_speed;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   166
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   167
		this.x_speed = dx/dt;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   168
		this.y_speed = dy/dt;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   169
		this.motion_speed = dist/dt;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   170
		this.motion_accel = (motion_speed - last_motion_speed)/dt;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   171
		
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   172
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   173
		if (motion_accel>0) state = TUIO_ACCELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   174
		else if (motion_accel<0) state = TUIO_DECELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   175
		else state = TUIO_STOPPED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   176
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   177
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   178
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   179
	 * This method is used to calculate the speed and acceleration values of
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   180
	 * TuioContainers with unchanged positions.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   181
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   182
	public void stop(TuioTime ttime) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   183
		update(ttime,xpos,ypos);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   184
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   185
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   186
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   187
	 * Takes a TuioTime argument and assigns it along with the provided 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   188
	 * X and Y coordinate, X and Y velocity and acceleration
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   189
	 * to the private TuioContainer attributes.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   190
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   191
	 * @param	ttime	the TuioTime to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   192
	 * @param	xp	the X coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   193
	 * @param	yp	the Y coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   194
	 * @param	xs	the X velocity to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   195
	 * @param	ys	the Y velocity to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   196
	 * @param	ma	the acceleration to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   197
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   198
	public void update(TuioTime ttime, float xp, float yp , float xs, float ys, float ma) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   199
		super.update(ttime,xp,yp);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   200
		x_speed = xs;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   201
		y_speed = ys;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   202
		motion_speed = (float)Math.sqrt(x_speed*x_speed+y_speed*y_speed);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   203
		motion_accel = ma;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   204
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   205
		if (motion_accel>0) state = TUIO_ACCELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   206
		else if (motion_accel<0) state = TUIO_DECELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   207
		else state = TUIO_STOPPED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   208
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   209
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   210
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   211
	 * Assigns the provided X and Y coordinate, X and Y velocity and acceleration
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   212
	 * to the private TuioContainer attributes. The TuioTime time stamp remains unchanged.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   213
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   214
	 * @param	xp	the X coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   215
	 * @param	yp	the Y coordinate to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   216
	 * @param	xs	the X velocity to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   217
	 * @param	ys	the Y velocity to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   218
	 * @param	ma	the acceleration to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   219
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   220
	public void update(float xp, float yp,float xs,float ys,float ma) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   221
		super.update(xp,yp);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   222
		x_speed = xs;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   223
		y_speed = ys;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   224
		motion_speed = (float)Math.sqrt(x_speed*x_speed+y_speed*y_speed);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   225
		motion_accel = ma;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   226
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   227
		if (motion_accel>0) state = TUIO_ACCELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   228
		else if (motion_accel<0) state = TUIO_DECELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   229
		else state = TUIO_STOPPED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   230
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   231
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   232
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   233
	 * Takes the atttibutes of the provided TuioContainer 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   234
	 * and assigs these values to this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   235
	 * The TuioTime time stamp of this TuioContainer remains unchanged.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   236
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   237
	 * @param	tcon	the TuioContainer to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   238
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   239
	public void update (TuioContainer tcon) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   240
		super.update(tcon);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   241
		x_speed = tcon.getXSpeed();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   242
		y_speed = tcon.getYSpeed();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   243
		motion_speed = tcon.getMotionSpeed();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   244
		motion_accel = tcon.getMotionAccel();
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   245
		path.addElement(new TuioPoint(currentTime,xpos,ypos));
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   246
		if (motion_accel>0) state = TUIO_ACCELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   247
		else if (motion_accel<0) state = TUIO_DECELERATING;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   248
		else state = TUIO_STOPPED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   249
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   250
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   251
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   252
	 * Assigns the REMOVE state to this TuioContainer and sets
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   253
	 * its TuioTime time stamp to the provided TuioTime argument.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   254
	 *
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   255
	 * @param	ttime	the TuioTime to assign
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   256
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   257
	public void remove(TuioTime ttime) {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   258
		currentTime = new TuioTime(ttime);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   259
		state = TUIO_REMOVED;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   260
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   261
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   262
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   263
	 * Returns the Session ID of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   264
	 * @return	the Session ID of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   265
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   266
	public long getSessionID() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   267
		return session_id;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   268
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   269
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   270
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   271
	 * Returns the X velocity of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   272
	 * @return	the X velocity of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   273
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   274
	public float getXSpeed() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   275
		return x_speed;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   276
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   277
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   278
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   279
	 * Returns the Y velocity of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   280
	 * @return	the Y velocity of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   281
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   282
	public float getYSpeed() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   283
		return y_speed;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   284
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   285
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   286
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   287
	 * Returns the position of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   288
	 * @return	the position of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   289
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   290
	public TuioPoint getPosition() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   291
		return new TuioPoint(xpos,ypos);
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   292
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   293
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   294
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   295
	 * Returns the path of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   296
	 * @return	the path of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   297
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   298
	public Vector<TuioPoint> getPath() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   299
		return path;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   300
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   301
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   302
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   303
	 * Returns the motion speed of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   304
	 * @return	the motion speed of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   305
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   306
	public float getMotionSpeed() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   307
		return motion_speed;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   308
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   309
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   310
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   311
	 * Returns the motion acceleration of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   312
	 * @return	the motion acceleration of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   313
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   314
	public float getMotionAccel() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   315
		return motion_accel;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   316
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   317
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   318
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   319
	 * Returns the TUIO state of this TuioContainer.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   320
	 * @return	the TUIO state of this TuioContainer
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   321
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   322
	public int getTuioState() {
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   323
		return state;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   324
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   325
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   326
	/**
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   327
	 * Returns true of this TuioContainer is moving.
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   328
	 * @return	true of this TuioContainer is moving
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   329
	 */
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   330
	public boolean isMoving() { 
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   331
		if ((state==TUIO_ACCELERATING) || (state==TUIO_DECELERATING)) return true;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   332
		else return false;
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   333
	}
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   334
	
6fefd4afe506 First Import
bastiena
parents:
diff changeset
   335
}