Class MacCoreaudioStream
- java.lang.Object
-
- org.jitsi.impl.neomedia.control.AbstractControls
-
- org.jitsi.impl.neomedia.jmfext.media.protocol.AbstractPullBufferStream<DataSource>
-
- org.jitsi.impl.neomedia.jmfext.media.protocol.maccoreaudio.MacCoreaudioStream
-
- All Implemented Interfaces:
javax.media.Controls,javax.media.protocol.Controls,javax.media.protocol.PullBufferStream,javax.media.protocol.SourceStream
public class MacCoreaudioStream extends AbstractPullBufferStream<DataSource>
Implements PullBufferStream for MacCoreaudio.- Author:
- Vincent Lucas
-
-
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.
-
Constructor Summary
Constructors Constructor Description MacCoreaudioStream(DataSource dataSource, javax.media.control.FormatControl formatControl, boolean audioQualityImprovement)Initializes a new MacCoreaudioStream 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 PullBufferStream 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.voidread(javax.media.Buffer buffer)Reads media data from this PullBufferStream into a specific Buffer with blocking.voidreadInput(byte[] buffer, int bufferLength)Callback which receives the data from the coreaudio library.voidstart()Starts the transfer of media data from this PullBufferStream.voidstop()Stops the transfer of media data from this PullBufferStream.-
Methods inherited from class org.jitsi.impl.neomedia.jmfext.media.protocol.AbstractPullBufferStream
willReadBlock
-
Methods inherited from class org.jitsi.impl.neomedia.control.AbstractControls
getControl, getControl, queryInterface, queryInterface
-
-
-
-
Field Detail
-
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
-
MacCoreaudioStream
public MacCoreaudioStream(DataSource dataSource, javax.media.control.FormatControl formatControl, boolean audioQualityImprovement)
Initializes a new MacCoreaudioStream instance which is to have its Format-related information abstracted by a specific FormatControl.- Parameters:
dataSource- the DataSource 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 instanceaudioQualityImprovement- true to enable audio quality improvement for the new instance in accord with the preferences of the user or false to completely disable audio quality improvement
-
-
Method Detail
-
doGetFormat
protected javax.media.Format doGetFormat()
Gets the Format of this PullBufferStream as directly known by it.- Returns:
- the Format of this PullBufferStream as directly known by it or null if this PullBufferStream does not directly know its Format and it relies on the PullBufferDataSource which created it to report its Format
- See Also:
AbstractBufferStream.doGetFormat()
-
read
public void read(javax.media.Buffer buffer) throws IOExceptionReads media data from this PullBufferStream into a specific Buffer with blocking.- Parameters:
buffer- the Buffer in which media data is to be read from this PullBufferStream- Throws:
IOException- if anything goes wrong while reading media data from this PullBufferStream into the specified buffer
-
readInput
public void readInput(byte[] buffer, int bufferLength)Callback which receives the data from the coreaudio library.- Parameters:
buffer- The data captured from the input.bufferLength- The length of the data captured.
-
start
public void start() throws IOExceptionStarts the transfer of media data from this PullBufferStream.- 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 PullBufferStream.- Throws:
IOException- if anything goes wrong while stopping the transfer of media data from this AbstractBufferStream
-
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.
-
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
-
-