Class AbstractPushBufferStream<T extends javax.media.protocol.PushBufferDataSource>
- java.lang.Object
-
- org.jitsi.impl.neomedia.control.AbstractControls
-
- org.jitsi.impl.neomedia.jmfext.media.protocol.AbstractPushBufferStream<T>
-
- All Implemented Interfaces:
javax.media.Controls,javax.media.protocol.Controls,javax.media.protocol.PushBufferStream,javax.media.protocol.SourceStream
- Direct Known Subclasses:
DirectShowStream,QuickTimeStream,WASAPIStream
public abstract class AbstractPushBufferStream<T extends javax.media.protocol.PushBufferDataSource> extends AbstractControls implements javax.media.protocol.PushBufferStream
Provides a base implementation of PushBufferStream in order to facilitate implementers by taking care of boilerplate in the most common cases.- Author:
- Lyubomir Marinov
-
-
Field Summary
Fields Modifier and Type Field Description protected TdataSourceThe DataSource which has created this instance and which contains it as one of its streams.protected javax.media.control.FormatControlformatControlThe FormatControl which gives access to the Format of the media data provided by this SourceStream and which, optionally, allows setting it.static StringPUSH_BUFFER_STREAM_CLASS_NAMEThe name of the PushBufferStream class.protected javax.media.protocol.BufferTransferHandlertransferHandlerThe BufferTransferHandler which is notified by this PushBufferStream when data is available for reading.
-
Constructor Summary
Constructors Modifier Constructor Description protectedAbstractPushBufferStream(T dataSource, javax.media.control.FormatControl formatControl)Initializes a new AbstractPushBufferStream instance which is to have its Format-related information abstracted by a specific FormatControl.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Releases the resources used by this instance throughout its existence and makes it available for garbage collection.protected javax.media.FormatdoGetFormat()Gets the Format of this AbstractBufferStream as directly known by it.protected javax.media.FormatdoSetFormat(javax.media.Format format)Attempts to set the Format of this AbstractBufferStream.booleanendOfStream()Determines whether the end of this SourceStream has been reached.javax.media.protocol.ContentDescriptorgetContentDescriptor()Gets a ContentDescriptor which describes the type of the content made available by this SourceStream.longgetContentLength()Gets the length in bytes of the content made available by this SourceStream.Object[]getControls()ImplementsControls.getControls().javax.media.FormatgetFormat()Gets the Format of the media data made available by this AbstractBufferStream.voidsetTransferHandler(javax.media.protocol.BufferTransferHandler transferHandler)Sets the BufferTransferHandler which is to be notified by this PushBufferStream when data is available for reading.voidstart()Starts the transfer of media data from this AbstractBufferStream.voidstop()Stops the transfer of media data from this AbstractBufferStream.-
Methods inherited from class org.jitsi.impl.neomedia.control.AbstractControls
getControl, getControl, queryInterface, queryInterface
-
-
-
-
Field Detail
-
PUSH_BUFFER_STREAM_CLASS_NAME
public static final String PUSH_BUFFER_STREAM_CLASS_NAME
The name of the PushBufferStream class.
-
transferHandler
protected javax.media.protocol.BufferTransferHandler transferHandler
The BufferTransferHandler which is notified by this PushBufferStream when data is available for reading.
-
dataSource
protected final T extends javax.media.protocol.DataSource dataSource
The DataSource which has created this instance and which contains it as one of its streams.
-
formatControl
protected final javax.media.control.FormatControl formatControl
The FormatControl which gives access to the Format of the media data provided by this SourceStream and which, optionally, allows setting it.
-
-
Constructor Detail
-
AbstractPushBufferStream
protected AbstractPushBufferStream(T dataSource, javax.media.control.FormatControl formatControl)
Initializes a new AbstractPushBufferStream instance which is to have its Format-related information abstracted by a specific FormatControl.- Parameters:
dataSource- the PushBufferDataSource which is creating the new instance so that it becomes one of its streamsformatControl- the FormatControl which is to abstract the Format-related information of the new instance
-
-
Method Detail
-
setTransferHandler
public void setTransferHandler(javax.media.protocol.BufferTransferHandler transferHandler)
Sets the BufferTransferHandler which is to be notified by this PushBufferStream when data is available for reading.- Specified by:
setTransferHandlerin interfacejavax.media.protocol.PushBufferStream- Parameters:
transferHandler- the BufferTransferHandler which is to be notified by this PushBufferStream when data is available for reading
-
close
public void close()
Releases the resources used by this instance throughout its existence and makes it available for garbage collection. This instance is considered unusable after closing.Warning: The method is not invoked by the framework, extenders may choose to invoke it.
-
doGetFormat
protected javax.media.Format doGetFormat()
Gets the Format of this AbstractBufferStream as directly known by it. Allows extenders to override the Format known to the DataSource which created this instance and possibly provide more details on the currently set Format.- Returns:
- the Format of this AbstractBufferStream as directly known by it or null if this AbstractBufferStream does not directly know its Format and it relies on the DataSource which created it to report its Format
-
doSetFormat
protected javax.media.Format doSetFormat(javax.media.Format format)
Attempts to set the Format of this AbstractBufferStream. Allows extenders to enable setting the Format of an existing AbstractBufferStream (in contract to setting it before the AbstractBufferStream is created by the DataSource which will provide it).- Parameters:
format- the Format to be set as the format of this AbstractBufferStream- Returns:
- the Format of this AbstractBufferStream or null if the attempt to set the Format did not succeed and any last-known Format is to be left in effect
-
endOfStream
public boolean endOfStream()
Determines whether the end of this SourceStream has been reached. The AbstractBufferStream implementation always returns false.- Specified by:
endOfStreamin interfacejavax.media.protocol.SourceStream- Returns:
- true if the end of this SourceStream has been reached; otherwise, false
-
getContentDescriptor
public javax.media.protocol.ContentDescriptor getContentDescriptor()
Gets a ContentDescriptor which describes the type of the content made available by this SourceStream. The AbstractBufferStream implementation always returns a ContentDescriptor with content type equal to ContentDescriptor#RAW.- Specified by:
getContentDescriptorin interfacejavax.media.protocol.SourceStream- Returns:
- a ContentDescriptor which describes the type of the content made available by this SourceStream
-
getContentLength
public long getContentLength()
Gets the length in bytes of the content made available by this SourceStream. The AbstractBufferStream implementation always returns LENGTH_UNKNOWN.- Specified by:
getContentLengthin interfacejavax.media.protocol.SourceStream- Returns:
- the length in bytes of the content made available by this SourceStream if it is known; otherwise, LENGTH_UKNOWN
-
getControls
public Object[] getControls()
ImplementsControls.getControls(). Gets the controls available for this instance.- Specified by:
getControlsin interfacejavax.media.Controls- Returns:
- an array of Objects which represent the controls available for this instance
-
getFormat
public javax.media.Format getFormat()
Gets the Format of the media data made available by this AbstractBufferStream.- Returns:
- the Format of the media data made available by this AbstractBufferStream
-
start
public void start() throws IOExceptionStarts the transfer of media data from this AbstractBufferStream.- Throws:
IOException- if anything goes wrong while starting the transfer of media data from this AbstractBufferStream
-
stop
public void stop() throws IOExceptionStops the transfer of media data from this AbstractBufferStream.- Throws:
IOException- if anything goes wrong while stopping the transfer of media data from this AbstractBufferStream
-
-