Package javax.media.j3d
Interface InputDevice
public interface InputDevice
InputDevice is the interface through which Java 3D and Java 3D
application programs communicate with a device driver. All input
devices that Java 3D uses must implement the InputDevice interface and
be registered with Java 3D via a call to
PhysicalEnvironment.addInputDevice(InputDevice). An input device
transfers information to the Java 3D implementation and Java 3D
applications by writing transform information to sensors that the
device driver has created and manages. The driver can update its
sensor information each time the pollAndProcessInput method is
called.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final int
Signifies that the driver for a device is a blocking driver and that it should be scheduled for regular reads by Java 3D.static final int
Signifies that the Java 3D implementation should not schedule regular reads on the sensors of this device; the Java 3D implementation will only call pollAndProcessInput when one of the device's sensors' getRead methods is called.static final int
Signifies that the driver for a device is a non-blocking driver and that it should be scheduled for regular reads by Java 3D. -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Code to process the clean up of the device and relinquish associated resources.int
This method retrieves the device's processing mode: one of BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN.getSensor
(int sensorIndex) Gets the specified Sensor associated with the device.int
This method gets the number of sensors associated with the device.boolean
This method initializes the device.void
This method causes the device's sensor readings to be updated by the device driver.void
This method will not be called by the Java 3D implementation and should be implemented as an empty method.void
This method sets the device's current position and orientation as the devices nominal position and orientation (establish its reference frame relative to the "Tracker base" reference frame).void
setProcessingMode
(int mode) This method sets the device's processing mode to one of: BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN.
-
Field Details
-
BLOCKING
static final int BLOCKINGSignifies that the driver for a device is a blocking driver and that it should be scheduled for regular reads by Java 3D. A blocking driver is defined as a driver that can cause the thread accessing the driver (the Java 3D implementation thread calling the pollAndProcessInput method) to block while the data is being accessed from the driver.- See Also:
-
NON_BLOCKING
static final int NON_BLOCKINGSignifies that the driver for a device is a non-blocking driver and that it should be scheduled for regular reads by Java 3D. A non-blocking driver is defined as a driver that does not cause the calling thread to block while data is being retrieved from the driver. If no data is available from the device, pollAndProcessInput should return without updating the sensor read value.- See Also:
-
DEMAND_DRIVEN
static final int DEMAND_DRIVENSignifies that the Java 3D implementation should not schedule regular reads on the sensors of this device; the Java 3D implementation will only call pollAndProcessInput when one of the device's sensors' getRead methods is called. A DEMAND_DRIVEN driver must always provide the current value of the sensor on demand whenever pollAndProcessInput is called. This means that DEMAND_DRIVEN drivers are non-blocking by definition.- See Also:
-
-
Method Details
-
initialize
boolean initialize()This method initializes the device. A device should be initialized before it is registered with Java 3D via the PhysicalEnvironment.addInputDevice(InputDevice) method call.- Returns:
- return true for succesful initialization, false for failure
-
setNominalPositionAndOrientation
void setNominalPositionAndOrientation()This method sets the device's current position and orientation as the devices nominal position and orientation (establish its reference frame relative to the "Tracker base" reference frame). -
pollAndProcessInput
void pollAndProcessInput()This method causes the device's sensor readings to be updated by the device driver. For BLOCKING and NON_BLOCKING drivers, this method is called regularly and the Java 3D implementation can cache the sensor values. For DEMAND_DRIVEN drivers this method is called each time one of the Sensor.getRead methods is called, and is not otherwise called. -
processStreamInput
void processStreamInput()This method will not be called by the Java 3D implementation and should be implemented as an empty method. -
close
void close()Code to process the clean up of the device and relinquish associated resources. This method should be called after the device has been unregistered from Java 3D via the PhysicalEnvironment.removeInputDevice(InputDevice) method call. -
getProcessingMode
int getProcessingMode()This method retrieves the device's processing mode: one of BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN. The Java 3D implementation calls this method when PhysicalEnvironment.addInputDevice(InputDevice) is called to register the device with Java 3D. If this method returns any value other than BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN, addInputDevice will throw an IllegalArgumentException.- Returns:
- Returns the devices processing mode, one of BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN
-
setProcessingMode
void setProcessingMode(int mode) This method sets the device's processing mode to one of: BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN. Many drivers will be written to run in only one mode. Applications using such drivers should not attempt to set the processing mode. This method should throw an IllegalArgumentException if there is an attempt to set the processing mode to anything other than the aforementioned three values.NOTE: this method should not be called after the input device has been added to a PhysicalEnvironment. The processingMode must remain constant while a device is attached to a PhysicalEnvironment.
- Parameters:
mode
- One of BLOCKING, NON_BLOCKING, or DEMAND_DRIVEN
-
getSensorCount
int getSensorCount()This method gets the number of sensors associated with the device.- Returns:
- the device's sensor count.
-
getSensor
Gets the specified Sensor associated with the device. Each InputDevice implementation is responsible for creating and managing its own set of sensors. The sensor indices begin at zero and end at number of sensors minus one. Each sensor should have had Sensor.setDevice(InputDevice) set properly before addInputDevice is called.- Parameters:
sensorIndex
- the sensor to retrieve- Returns:
- Returns the specified sensor.
-