All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ery.jvrpn.1.0.0.source-code.TrackerRemoteListener Maven / Gradle / Ivy

There is a newer version: 1.2.0
Show newest version
/***************************************************************************
 * Use this class to store Tracker-, Velocity- and AcceleraionUpdates in a 
 * vector and get them when you want.  It is most useful if you don't want 
 * to worry about your code running in a multi-threaded environment and 
 * about vrpn possibly delivering device updates at arbitrary times.
 *
 * The Listener can be configured to buffer and return either all
 * updates or only the last (the most recent) update.  Tracker, velocity
 * and acceleration messages are buffered independently.  By default, the
 * Listener keeps only the last update of each.
 * 
 * It is not intended that Listeners be shared among objects.  Each 
 * entity in a program that is interested in hearing about updates 
 * from some vrpn Tracker device (and which wishes to use this Listener
 * mechanism) should create its own listener (even if multiple entities 
 * wish to hear from the same device).
 ***************************************************************************/

package vrpn;
import java.util.Vector;

public class TrackerRemoteListener
	implements TrackerRemote.PositionChangeListener, 
	TrackerRemote.VelocityChangeListener, 
	TrackerRemote.AccelerationChangeListener
{
	public static final int ALL_UPDATES = 0;
	public static final int LAST_UPDATE = 1;
	
	
	public TrackerRemoteListener( TrackerRemote tracker )
	{
		
		trackerUpdates = new Vector();
		velocityUpdates = new Vector();
		accelerationUpdates = new Vector();
		
		trackerBufferMode = LAST_UPDATE;
		velocityBufferMode = LAST_UPDATE;
		accelerationBufferMode = LAST_UPDATE;

		tracker.addPositionChangeListener(this);
		tracker.addVelocityChangeListener(this);
		tracker.addAccelerationChangeListener(this);
	}
	
	
	/**
	 * Sets the buffering mode of the Listener to record and return only 
	 * the most recent (the last, the latest) TrackerUpdate.
	 */
	public synchronized void setModeLastTrackerUpdate()
	{
		trackerBufferMode = LAST_UPDATE;
		if( !trackerUpdates.isEmpty() )
		{
			Object temp = trackerUpdates.lastElement();
			trackerUpdates.removeAllElements();
			trackerUpdates.addElement(temp);
		}
	}
	
	
	/**
	 * Sets the buffering mode of the Listener to record and return only 
	 * the most recent (the last, the latest) VelocityUpdate.
	 */
	public synchronized void setModeLastVelocityUpdate()
	{
		velocityBufferMode = LAST_UPDATE;
		if( !velocityUpdates.isEmpty() )
		{
			Object temp = velocityUpdates.lastElement();
			velocityUpdates.removeAllElements();
			velocityUpdates.addElement(temp);
		}
	}
	
	
	/**
	 * Sets the buffering mode of the Listener to record and return only 
	 * the most recent (the last, the latest) AccelerationUpdate.
	 */
	public synchronized void setModeLastAccelerationUpdate()
	{
		accelerationBufferMode = LAST_UPDATE;
		if( !accelerationUpdates.isEmpty() )
		{
			Object temp = accelerationUpdates.lastElement();
			accelerationUpdates.removeAllElements();
			accelerationUpdates.addElement(temp);
		}
	}
	
	
	/**
	 * Sets the buffering mode of the Listener to record and return all 
	 * TrackerUpdates, beginning at the time this mode is first enabled.
	 */
	public synchronized void setModeAllTrackerUpdates()
	{
		if( trackerBufferMode == LAST_UPDATE )
		{
			trackerUpdates.removeAllElements( );
		}
		trackerBufferMode = ALL_UPDATES;
	}
	
	
	/**
	 * Sets the buffering mode of the Listener to record and return all 
	 * VelocityUpdates, beginning at the time this mode is first enabled.
	 */
	public synchronized void setModeAllVelocityUpdates()
	{
		if( velocityBufferMode == LAST_UPDATE )
		{
			velocityUpdates.removeAllElements( );
		}
		velocityBufferMode = ALL_UPDATES;
	}
	
	
	/**
	 * Sets the buffering mode of the Listener to record and return all 
	 * AccelerationUpdates, beginning at the time this mode is first enabled.
	 */
	public synchronized void setModeAllAccelerationUpdates()
	{
		if( accelerationBufferMode == LAST_UPDATE )
		{
			accelerationUpdates.removeAllElements( );
		}
		accelerationBufferMode = ALL_UPDATES;
	}
	
	
	/**
	 * @return TrackerRemoteListener.ALL_UPDATES if the Listener is recording and 
	 * returning all TrackerUpdates; TrackerRemoteListener.LAST_UPDATE if only the 
	 * latest TrackerUpdate.
	 */
	public synchronized int getModeTrackerUpdate()
	{
		return trackerBufferMode;
	}
	
	
	/**
	 * @return TrackerRemoteListener.ALL_UPDATES if the Listener is recording and 
	 * returning all VelocityUpdates; TrackerRemoteListener.LAST_UPDATE if only the 
	 * latest VelocityUpdate.
	 */
	public synchronized int getModeVelocityUpdate()
	{
		return velocityBufferMode;
	}
	
	
	/**
	 * @return TrackerRemoteListener.ALL_UPDATES if the Listener is recording and 
	 * returning all AccelerationUpdates; TrackerRemoteListener.LAST_UPDATE if only the 
	 * latest AccelerationUpdate.
	 */
	public synchronized int getModeAccelerationUpdate()
	{
		return accelerationBufferMode;
	}
	
	
	/**
	 * This method retreives the buffered TrackerUpdates from the Listener.
	 * If the buffering mode is LAST_UPDATE, the last update received will
	 * be returned (note that, in this mode, successive calls to getTrackerUpdate()
	 * may return the same TrackerUpdate if no new updates were received in the 
	 * interim).  If the buffering mode is ALL_UPDATES, all updates 
	 * received since the last call to getTrackerUpdate() (or since ALL_UPDATES
	 * mode was enabled) will be returned.
	 * @return A Vector containing the buffered TrackerUpdates.  The number of
	 * TrackerUpdates returned will depend on the buffering mode.  If there are
	 * no TrackerUpdates buffered, an empty Vector will be returned.
	 * @see #setModeLastTrackerUpdate
	 * @see #setModeAllTrackerUpdates
	 */
	public synchronized Vector getTrackerUpdate()
	{
		Vector v = new Vector( );
		if( trackerUpdates.isEmpty() )
		{
			return v;
		}
		
		if( trackerBufferMode == LAST_UPDATE )
		{
			v.addElement( trackerUpdates.lastElement() );
		}
		else if( trackerBufferMode == ALL_UPDATES )
		{
			for( int i = 0; i < trackerUpdates.size(); i++ )
			{
				v.addElement( trackerUpdates.elementAt(i) );
			}
			trackerUpdates.removeAllElements();
		}
		return v;
	} // end method getTrackerUpdate( )
	
	
	/**
	 * This method retreives the buffered VelocityUpdates from the Listener.
	 * If the buffering mode is LAST_UPDATE, the last update received will
	 * be returned (note that, in this mode, successive calls to getVelocityUpdate()
	 * may return the same VelocityUpdate if no new updates were received in the 
	 * interim).  If the buffering mode is ALL_UPDATES, all updates 
	 * received since the last call to getVelocityUpdate() (or since ALL_UPDATES
	 * mode was enabled) will be returned.
	 * @return A Vector containing the buffered VelocityUpdates.  The number of
	 * VelocityUpdates returned will depend on the buffering mode.  If there are
	 * no VelocityUpdates buffered, an empty Vector will be returned.
	 * @see #setModeLastVelocityUpdate
	 * @see #setModeAllVelocityUpdates
	 */
	public synchronized Vector getVelocityUpdate()
	{
		Vector v = new Vector( );
		if( velocityUpdates.isEmpty() )
		{
			return v;
		}
		
		if( velocityBufferMode == LAST_UPDATE )
		{
			v.addElement( velocityUpdates.lastElement() );
		}
		else if( velocityBufferMode == ALL_UPDATES )
		{
			for( int i = 0; i < velocityUpdates.size(); i++ )
			{
				v.addElement( velocityUpdates.elementAt(i) );
			}
			velocityUpdates.removeAllElements();
		}
		return v;
	} // end method getVelocityUpdate( )
	
	
	/**
	 * This method retreives the buffered AccelerationUpdates from the Listener.
	 * If the buffering mode is LAST_UPDATE, the last update received will
	 * be returned (note that, in this mode, successive calls to getAcclerationUpdate()
	 * may return the same AccelerationUpdate if no new updates were received in the 
	 * interim).  If the buffering mode is ALL_UPDATES, all updates 
	 * received since the last call to getAcclerationUpdate() (or since ALL_UPDATES
	 * mode was enabled) will be returned.
	 * @return A Vector containing the buffered AccelerationUpdates.  The number of
	 * AccelerationUpdates returned will depend on the buffering mode.  If there are
	 * no AccelerationUpdates buffered, an empty Vector will be returned.
	 * @see #setModeLastAccelerationUpdate
	 * @see #setModeAllAccelerationUpdates
	 */
	public synchronized Vector getAcclerationUpdate()
	{
		Vector v = new Vector( );
		if( accelerationUpdates.isEmpty() )
		{
			return v;
		}
		
		if( accelerationBufferMode == LAST_UPDATE )
		{
			v.addElement( accelerationUpdates.lastElement() );
		}
		else if( accelerationBufferMode == ALL_UPDATES )
		{
			for( int i = 0; i < accelerationUpdates.size(); i++ )
			{
				v.addElement( accelerationUpdates.elementAt(i) );
			}
			accelerationUpdates.removeAllElements();
		}
		return v;
	} // end method getAccelerationUpdate( )
	
	
	/**
	 * @return The last (most recent, latest) TrackerUpdate received.  This function 
	 * returns null if no updates have been received.  Note that
	 * successive calls to getLastTrackerUpdate() may return the same TrackerUpdate
	 * if no updates were received in the interim.
	 */
	public synchronized TrackerRemote.TrackerUpdate getLastTrackerUpdate()
	{
		if( trackerUpdates.isEmpty( ) )
			return null;
		
		return (TrackerRemote.TrackerUpdate) trackerUpdates.lastElement();
	}
	
	
	/**
	 * @return The last (most recent, latest) VelocityUpdate received.  This function 
	 * returns null if no updates have been received.  Note that
	 * successive calls to getLastVelocityUpdate() may return the same VelocityUpdate
	 * if no updates were received in the interim.
	 */
	public synchronized TrackerRemote.VelocityUpdate getLastVelocityUpdate()
	{
		if( velocityUpdates.isEmpty( ) )
			return null;
		
		return (TrackerRemote.VelocityUpdate) velocityUpdates.lastElement();
	}
	
	
	/**
	 * @return The last (most recent, latest) AccelerationUpdate received.  This function 
	 * returns null if no updates have been received.  Note that
	 * successive calls to getLastAccelerationUpdate() may return the same 
	 * AccelerationUpdate if no updates were received in the interim.
	 */
	public synchronized TrackerRemote.AccelerationUpdate getLastAccelerationUpdate()
	{
		if( accelerationUpdates.isEmpty( ) )
			return null;
		
		return (TrackerRemote.AccelerationUpdate) accelerationUpdates.lastElement();
	}
	
	
	/**
	 * This is the handler that the TrackerRemote instance will call to deliver 
	 * position updates.  This method is not intended to be called by user code.
	 */
	public synchronized void trackerPositionUpdate( TrackerRemote.TrackerUpdate u, TrackerRemote tracker )
	{
		if( trackerBufferMode == LAST_UPDATE )
		{
			trackerUpdates.removeAllElements();
		}
		trackerUpdates.addElement(u);
	}
	
	
	/**
	 * This is the handler that the TrackerRemote instance will call to deliver 
	 * velocity updates.  This method is not intended to be called by user code.
	 */
	public synchronized void trackerVelocityUpdate (TrackerRemote.VelocityUpdate v, TrackerRemote tracker)
	{
		if( velocityBufferMode == LAST_UPDATE )
		{
			velocityUpdates.removeAllElements();
		}
		velocityUpdates.addElement(v);
	}
	
	
	/**
	 * This is the handler that the TrackerRemote instance will call to deliver 
	 * acceleration updates.  This method is not intended to be called by user code.
	 */
	public synchronized void trackerAccelerationUpdate (TrackerRemote.AccelerationUpdate a, TrackerRemote tracker )
	{
		if( accelerationBufferMode == LAST_UPDATE )
		{
			accelerationUpdates.removeAllElements();
		}
		accelerationUpdates.addElement(a);
	}


	protected Vector trackerUpdates;
	protected Vector velocityUpdates;
	protected Vector accelerationUpdates;
	
	protected int trackerBufferMode;
	protected int velocityBufferMode;
	protected int accelerationBufferMode;
	
} // end class TrackerRemoteListener




© 2015 - 2025 Weber Informatics LLC | Privacy Policy