AudioFormat is the class that specifies a particular arrangement of
 data in a sound stream. By examining the information stored in the audio
 format, you can discover how to interpret the bits in the binary sound data.
 Every data line has an audio format associated with its data stream. The audio format of a source (playback) data line indicates what kind of data the data line expects to receive for output. For a target (capture) data line, the audio format specifies the kind of the data that can be read from the line.
 Sound files also have audio formats, of course. The AudioFileFormat
 class encapsulates an AudioFormat in addition to other, file-specific
 information. Similarly, an AudioInputStream has an
 AudioFormat.
 
 The AudioFormat class accommodates a number of common sound-file
 encoding techniques, including pulse-code modulation (PCM), mu-law encoding,
 and a-law encoding. These encoding techniques are predefined, but service
 providers can create new encoding types. The encoding that a specific format
 uses is named by its encoding field.
 
In addition to the encoding, the audio format includes other properties that further specify the exact arrangement of the data. These include the number of channels, sample rate, sample size, byte order, frame rate, and frame size. Sounds may have different numbers of audio channels: one for mono, two for stereo. The sample rate measures how many "snapshots" (samples) of the sound pressure are taken per second, per channel. (If the sound is stereo rather than mono, two samples are actually measured at each instant of time: one for the left channel, and another for the right channel; however, the sample rate still measures the number per channel, so the rate is the same regardless of the number of channels. This is the standard use of the term.) The sample size indicates how many bits are used to store each snapshot; 8 and 16 are typical values. For 16-bit samples (or any other sample size larger than a byte), byte order is important; the bytes in each sample are arranged in either the "little-endian" or "big-endian" style. For encodings like PCM, a frame consists of the set of samples for all channels at a given point in time, and so the size of a frame (in bytes) is always equal to the size of a sample (in bytes) times the number of channels. However, with some other sorts of encodings a frame can contain a bundle of compressed data for a whole series of samples, as well as additional, non-sample data. For such encodings, the sample rate and sample size refer to the data after it is decoded into PCM, and so they are completely different from the frame rate and frame size.
 An AudioFormat object can include a set of properties. A property is
 a pair of key and value: the key is of type String, the associated
 property value is an arbitrary object. Properties specify additional format
 specifications, like the bit rate for compressed formats. Properties are
 mainly used as a means to transport additional information of the audio
 format to and from the service providers. Therefore, properties are ignored
 in the matches(AudioFormat) method. However, methods which rely on
 the installed service providers, like
 (AudioFormat, AudioFormat)
 isConversionSupported may consider properties, depending on the respective
 service provider implementation.
 
The following table lists some common properties which service providers should use, if applicable:
| Property key | Value type | Description | 
|---|---|---|
| "bitrate" | Integer | average bit rate in bits per second | 
| "vbr" | Boolean | true, if the file is encoded in variable bit rate (VBR) | 
| "quality" | Integer | encoding/conversion quality, 1..100 | 
Vendors of service providers (plugins) are encouraged to seek information about other already established properties in third party plugins, and follow the same conventions.
- Since:
- 1.3
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classTheEncodingclass names the specific type of data representation used for an audio stream.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected booleanIndicates whether the audio data is stored in big-endian or little-endian order.protected intThe number of audio channels in this format (1 for mono, 2 for stereo).protected AudioFormat.EncodingThe audio encoding technique used by this format.protected floatThe number of frames played or recorded per second, for sounds that have this format.protected intThe number of bytes in each frame of a sound that has this format.protected floatThe number of samples played or recorded per second, for sounds that have this format.protected intThe number of bits in each sample of a sound that has this format.
- 
Constructor SummaryConstructorsConstructorDescriptionAudioFormat(float sampleRate, int sampleSizeInBits, int channels, boolean signed, boolean bigEndian) Constructs anAudioFormatwith a linear PCM encoding and the given parameters.AudioFormat(AudioFormat.Encoding encoding, float sampleRate, int sampleSizeInBits, int channels, int frameSize, float frameRate, boolean bigEndian) Constructs anAudioFormatwith the given parameters.AudioFormat(AudioFormat.Encoding encoding, float sampleRate, int sampleSizeInBits, int channels, int frameSize, float frameRate, boolean bigEndian, Map<String, Object> properties) Constructs anAudioFormatwith the given parameters.
- 
Method SummaryModifier and TypeMethodDescriptionintObtains the number of channels.Obtains the type of encoding for sounds in this format.floatObtains the frame rate in frames per second.intObtains the frame size in bytes.getProperty(String key) Obtain the property value specified by the key.floatObtains the sample rate.intObtains the size of a sample.booleanIndicates whether the audio data is stored in big-endian or little-endian byte order.booleanmatches(AudioFormat format) Indicates whether this format matches the one specified.Obtain an unmodifiable map of properties.toString()Returns a string that describes the audio format, such as: "PCM SIGNED 22050 Hz 16 bit mono big-endian".
- 
Field Details- 
encodingThe audio encoding technique used by this format.
- 
sampleRateprotected float sampleRateThe number of samples played or recorded per second, for sounds that have this format.
- 
sampleSizeInBitsprotected int sampleSizeInBitsThe number of bits in each sample of a sound that has this format.
- 
channelsprotected int channelsThe number of audio channels in this format (1 for mono, 2 for stereo).
- 
frameSizeprotected int frameSizeThe number of bytes in each frame of a sound that has this format.
- 
frameRateprotected float frameRateThe number of frames played or recorded per second, for sounds that have this format.
- 
bigEndianprotected boolean bigEndianIndicates whether the audio data is stored in big-endian or little-endian order.
 
- 
- 
Constructor Details- 
AudioFormatpublic AudioFormat(AudioFormat.Encoding encoding, float sampleRate, int sampleSizeInBits, int channels, int frameSize, float frameRate, boolean bigEndian) Constructs anAudioFormatwith the given parameters. The encoding specifies the convention used to represent the data. The other parameters are further explained in theclass description.- Parameters:
- encoding- the audio encoding technique
- sampleRate- the number of samples per second
- sampleSizeInBits- the number of bits in each sample
- channels- the number of channels (1 for mono, 2 for stereo, and so on)
- frameSize- the number of bytes in each frame
- frameRate- the number of frames per second
- bigEndian- indicates whether the data for a single sample is stored in big-endian byte order (- falsemeans little-endian)
 
- 
AudioFormatpublic AudioFormat(AudioFormat.Encoding encoding, float sampleRate, int sampleSizeInBits, int channels, int frameSize, float frameRate, boolean bigEndian, Map<String, Object> properties) Constructs anAudioFormatwith the given parameters. The encoding specifies the convention used to represent the data. The other parameters are further explained in theclass description.- Parameters:
- encoding- the audio encoding technique
- sampleRate- the number of samples per second
- sampleSizeInBits- the number of bits in each sample
- channels- the number of channels (1 for mono, 2 for stereo, and so on)
- frameSize- the number of bytes in each frame
- frameRate- the number of frames per second
- bigEndian- indicates whether the data for a single sample is stored in big-endian byte order (- falsemeans little-endian)
- properties- a- Map<String, Object>object containing format properties
- Since:
- 1.5
 
- 
AudioFormatpublic AudioFormat(float sampleRate, int sampleSizeInBits, int channels, boolean signed, boolean bigEndian) Constructs anAudioFormatwith a linear PCM encoding and the given parameters. The frame size is set to the number of bytes required to contain one sample from each channel, and the frame rate is set to the sample rate.- Parameters:
- sampleRate- the number of samples per second
- sampleSizeInBits- the number of bits in each sample
- channels- the number of channels (1 for mono, 2 for stereo, and so on)
- signed- indicates whether the data is signed or unsigned
- bigEndian- indicates whether the data for a single sample is stored in big-endian byte order (- falsemeans little-endian)
 
 
- 
- 
Method Details- 
getEncodingObtains the type of encoding for sounds in this format.- Returns:
- the encoding type
- See Also:
 
- 
getSampleRatepublic float getSampleRate()Obtains the sample rate. For compressed formats, the return value is the sample rate of the uncompressed audio data. When thisAudioFormatis used for queries (e.g.AudioSystem.isConversionSupported) or capabilities (e.g.DataLine.Info.getFormats), a sample rate ofAudioSystem.NOT_SPECIFIEDmeans that any sample rate is acceptable.AudioSystem.NOT_SPECIFIEDis also returned when the sample rate is not defined for this audio format.- Returns:
- the number of samples per second, or
         AudioSystem.NOT_SPECIFIED
- See Also:
 
- 
getSampleSizeInBitspublic int getSampleSizeInBits()Obtains the size of a sample. For compressed formats, the return value is the sample size of the uncompressed audio data. When thisAudioFormatis used for queries (e.g.AudioSystem.isConversionSupported) or capabilities (e.g.DataLine.Info.getFormats), a sample size ofAudioSystem.NOT_SPECIFIEDmeans that any sample size is acceptable.AudioSystem.NOT_SPECIFIEDis also returned when the sample size is not defined for this audio format.- Returns:
- the number of bits in each sample, or
         AudioSystem.NOT_SPECIFIED
- See Also:
 
- 
getChannelspublic int getChannels()Obtains the number of channels. When thisAudioFormatis used for queries (e.g.AudioSystem.isConversionSupported) or capabilities (e.g.DataLine.Info.getFormats), a return value ofAudioSystem.NOT_SPECIFIEDmeans that any (positive) number of channels is acceptable.- Returns:
- The number of channels (1 for mono, 2 for stereo, etc.), or
         AudioSystem.NOT_SPECIFIED
- See Also:
 
- 
getFrameSizepublic int getFrameSize()Obtains the frame size in bytes. When thisAudioFormatis used for queries (e.g.AudioSystem.isConversionSupported) or capabilities (e.g.DataLine.Info.getFormats), a frame size ofAudioSystem.NOT_SPECIFIEDmeans that any frame size is acceptable.AudioSystem.NOT_SPECIFIEDis also returned when the frame size is not defined for this audio format.- Returns:
- the number of bytes per frame, or
         AudioSystem.NOT_SPECIFIED
- See Also:
 
- 
getFrameRatepublic float getFrameRate()Obtains the frame rate in frames per second. When thisAudioFormatis used for queries (e.g.AudioSystem.isConversionSupported) or capabilities (e.g.DataLine.Info.getFormats), a frame rate ofAudioSystem.NOT_SPECIFIEDmeans that any frame rate is acceptable.AudioSystem.NOT_SPECIFIEDis also returned when the frame rate is not defined for this audio format.- Returns:
- the number of frames per second, or
         AudioSystem.NOT_SPECIFIED
- See Also:
 
- 
isBigEndianpublic boolean isBigEndian()Indicates whether the audio data is stored in big-endian or little-endian byte order. If the sample size is not more than one byte, the return value is irrelevant.- Returns:
- trueif the data is stored in big-endian byte order,- falseif little-endian
 
- 
propertiesObtain an unmodifiable map of properties. The concept of properties is further explained in theclass description.- Returns:
- a Map<String, Object>object containing all properties. If no properties are recognized, an empty map is returned.
- Since:
- 1.5
- See Also:
 
- 
getPropertyObtain the property value specified by the key. The concept of properties is further explained in theclass description.If the specified property is not defined for a particular file format, this method returns null.- Parameters:
- key- the key of the desired property
- Returns:
- the value of the property with the specified key, or nullif the property does not exist
- Since:
- 1.5
- See Also:
 
- 
matchesIndicates whether this format matches the one specified. To match, two formats must have the same encoding, and consistent values of the number of channels, sample rate, sample size, frame rate, and frame size. The values of the property are consistent if they are equal or the specified format has the property valueAudioSystem.NOT_SPECIFIED. The byte order (big-endian or little-endian) must be the same if the sample size is greater than one byte.- Parameters:
- format- format to test for match
- Returns:
- trueif this format matches the one specified,- falseotherwise
 
- 
toStringReturns a string that describes the audio format, such as: "PCM SIGNED 22050 Hz 16 bit mono big-endian". The contents of the string may vary between implementations of Java Sound.
 
-