Methods Summary |
---|
public void | connect()Open a connection to the source described by
the MediaLocator .
The connect method initiates communication with the source.
System.out.println("connecting DataSource");
// currently we don't use the mediaLocator... we use default device
stream = new DevicePushSourceStream();
streams = new DevicePushSourceStream[1];
streams[0] = stream;
connectDevice();
|
native void | connectDevice()Connect to the actual device
|
public void | disconnect()Close the connection to the source described by the locator.
The disconnect method frees resources used to maintain a
connection to the source.
If no resources are in use, disconnect is ignored.
If stop hasn't already been called,
calling disconnect implies a stop.
disconnectDevice();
|
native void | disconnectDevice()Disconnect from the actual device
|
public java.lang.String | getContentType()Get a string that describes the content-type of the media
that the source is providing.
It is an error to call getContentType if the source is
not connected.
// tempotary implementation
return "raw";
|
public java.lang.Object | getControl(java.lang.String controlType)Obtain the object that implements the specified
Class or Interface
The full class or interface name must be used.
If the control is not supported then null
is returned.
return null;
|
public java.lang.Object[] | getControls()Obtain the collection of objects that
control the object that implements this interface.
If no controls are supported, a zero length
array is returned.
return new Object[0];
|
public javax.media.Time | getDuration()Get the duration of the media represented
by this object.
The value returned is the media's duration
when played at the default rate.
If the duration can't be determined (for example, the media object is presenting live
video) getDuration returns DURATION_UNKNOWN .
return DURATION_UNKNOWN;
|
public javax.media.protocol.PushSourceStream[] | getStreams()Get the collection of streams that this source
manages. The collection of streams is entirely
content dependent. The ContentDescriptor
of this DataSource provides the only indication of
what streams can be available on this connection.
// return the steams the actual device provides
return streams;
|
public void | start()Initiate data-transfer. The start method must be
called before data is available.
(You must call connect before calling start .)
/* instantiate a buffer and start the actual device, the read() method
calls start() on the device */
stream.start();
|
public void | stop()Stop the data-transfer.
If the source has not been connected and started,
stop does nothing.
// stop the stream's thread and the device itself
stream.stop();
stopDevice();
|
native void | stopDevice()Stops the actual device
|