Documentation ¶
Overview ¶
Package wav provides WAV (RIFF) decoder.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Stream ¶
type Stream struct {
// contains filtered or unexported fields
}
Stream is a decoded audio stream.
The format is signed 16bit integer little endian PCM (DecodeWithoutResampling, etc.), or 32bit float little endian PCM (DeocdeF32). The channel count is 2.
func Decode
deprecated
Decode decodes WAV (RIFF) data to playable stream in signed 16bit integer, little endian, 2 channels (stereo) format.
The format must be 1 or 2 channels, 8bit or 16bit little endian PCM. The format is converted into 2 channels and 16bit.
Decode returns error when decoding fails or IO error happens.
Decode automatically resamples the stream to fit with the audio context if necessary.
The returned Stream's Seek is available only when src is an io.Seeker.
A Stream doesn't close src even if src implements io.Closer. Closing the source is src owner's responsibility.
Deprecated: as of v2.1. Use DecodeWithSampleRate instead.
func DecodeF32 ¶ added in v2.8.0
DecodeF32 decodes WAV (RIFF) data to playable stream in 32bit float, little endian, 2 channels (stereo) format.
The src format must be 1 or 2 channels, 8bit or 16bit little endian PCM. The src format is converted into 2 channels and 16bit.
DecodeF32 returns error when decoding fails or IO error happens.
The returned Stream's Seek is available only when src is an io.Seeker.
A Stream doesn't close src even if src implements io.Closer. Closing the source is src owner's responsibility.
func DecodeWithSampleRate ¶ added in v2.1.0
DecodeWithSampleRate decodes WAV (RIFF) data to playable stream in signed 16bit integer, little endian, 2 channels (stereo) format.
The format must be 1 or 2 channels, 8bit or 16bit little endian PCM. The format is converted into 2 channels and 16bit.
DecodeWithSampleRate returns error when decoding fails or IO error happens.
DecodeWithSampleRate automatically resamples the stream to fit with sampleRate if necessary.
The returned Stream's Seek is available only when src is an io.Seeker.
A Stream doesn't close src even if src implements io.Closer. Closing the source is src owner's responsibility.
Resampling can be a very heavy task. Stream has a cache for resampling, but the size is limited. Do not expect that Stream has a resampling cache even after whole data is played.
func DecodeWithoutResampling ¶ added in v2.4.0
DecodeWithoutResampling decodes WAV (RIFF) data to playable stream in signed 16bit integer, little endian, 2 channels (stereo) format.
The src format must be 1 or 2 channels, 8bit or 16bit little endian PCM. The src format is converted into 2 channels and 16bit.
DecodeWithoutSampleRate returns error when decoding fails or IO error happens.
The returned Stream's Seek is available only when src is an io.Seeker.
A Stream doesn't close src even if src implements io.Closer. Closing the source is src owner's responsibility.
func (*Stream) SampleRate ¶ added in v2.8.0
SampleRate returns the sample rate of the decoded stream.