3/13/2014 A low-level audio player in C# - CodeProject
http://www.codeproject.com/Articles/3352/A-low-level-audio-player-in-C 1/4
10,458,738 members (61,465 online) 309 Sign out
Member 10652045
home quick answers discussions features community
help
Search f or articles, questions, tips
Articles » Multimedia » Audio and Video » Audio
Article
Browse Code
Bugs / Suggestions
Stats
Revisions
Alternatives
Comments &
Discussions (164)
Add your own
alternative version
About Article
This article describes a
sample application that
uses the waveout API in C#.
Type Article
Licence
First Posted 11 Dec 2002
Views 659,433
Bookmarked 229 times
.NET1.0 Win2K WinXP C#
Dev Intermediate
Top News
News on the future of C#
as a language
Get the Insider News free each
morning.
Related Videos
Related Articles
A full-duplex audio player in C#
using the waveIn/waveOut APIs
AMR Audio Encoding
Next
Rate:
3 Tweet 1
A low-level audio player in C#
By Ianier Munoz, 27 Aug 2003
Download source files - 12 Kb
Introduction
It is no news that the .NET framework does not include any classes for dealing with sound. Some
people have worked around this limitation by wrapping high-level system components, such as
Windows Media Player or DirectShow, into .NET-friendly libraries. However, most of these libraries
are designed in such a way that they cannot be used to manipulate audio samples on the fly
because they do not give you access to the actual sound data.
When developing applications that deal with such low-level issues, the most commonly used
technologies are DirectSound and the waveout API. This article describes a sample application that
uses the waveout API in C# through Interop to play a WAV file in a continuous loop.
Using the code
Most of the work in the sample application is carried out by two classes: WaveStream and
WaveOutPlayer.
The WaveStream class extends System.IO.Stream and implements the necessary code to read
audio samples from a WAV file. The constructor reads the file header and extracts all the relevant
information including the actual length of the stream and the format of the audio samples, which
is exposed through the Format property.
One important thing to note is that seeking operations in the WaveStream class are relative to
the sound data stream. This way you don't have to care about the length of the header or about
those extra bytes at the end of the stream that don't belong to the audio data chunk. Seeking to
0 will cause the next read operation to start at the beginning of the audio data.
The WaveOutPlayer class is where the most interesting things happen. For the sake of simplicity,
the interface of this class has been reduced to the strict minimum. There are no Start, Stop or
Pause methods. Creating an instance of WaveOutPlayer will cause the system to start streaming
immediately.
Let's have a look at the code that creates the WaveOutPlayer instance. As you can see, the
4.84 (80 votes)
0
articles
3/13/2014 A low-level audio player in C# - CodeProject
http://www.codeproject.com/Articles/3352/A-low-level-audio-player-in-C 2/4
Programming Audio Effects in
C#
C Sharp Ripper
Low-Level Control of *.wav Data
(Part I)
3 Breakthrough Ways to
Visualize HTML5
Play or Capture Audio Sound.
Send and Receive as Multicast
(RTP)
C# MP3 Compressor
Open Audio Engine
Audio-Gallery-Suite (A
complete audio gallery solution
made with
HTML5/CSS3/jQuery-
JS/PHP/C#)
Text to Speech (tts) for the Web
AAC Encode
Embedding and Playing WAV
Audio Files in a WinForms
Application
Workaround to Fix Audio
Autoplay on Mobile Browsers!
PVS.AVPlayer
Another Article on MP3 Players
using Windows Media Player
nVLC
Unlocking the Power of HTML5
Audio
C# Windows Media Format SDK
Translation
C# MP3 Compressor
Related Research
Fine-Tuning the Engines of SMB
Growth: 4 strategies for growing
your business
Protecting Your Business Data:
Five Do’s and Don’ts
constructor takes five parameters:
Collapse | Copy Code
private void Play()
{
Stop();
if (m_AudioStream != null)
{
m_AudioStream.Position = 0;
m_Player = new WaveLib.WaveOutPlayer(-1, m_Format, 16384, 3,
new WaveLib.BufferFillEventHandler(Filler));
}
}
The first parameter is the ID of the wave device that you want to use. The value -1 represents the
default system device, but if your system has more than one sound card, then you can pass any
number from 0 to the number of installed sound cards minus one to select a particular device.
The second parameter is the format of the audio samples. In this example, the format is taken
directly from the wave stream.
The third and forth parameters are the size of the internal wave buffers and the number of buffers
to allocate. You should set these to reasonable values. Smaller buffers will give you less latency,
but the audio may stutter if your computer is not fast enough.
The fifth and last parameter is a delegate that will be called periodically as internal audio buffers
finish playing, so that you can feed them with new sound data. In the sample application we just
read audio data from the wave stream, like this:
Collapse | Copy Code
private void Filler(IntPtr data, int size)
{
byte[] b = new byte[size];
if (m_AudioStream != null)
{
int pos = 0;
while (pos < size)
{
int toget = size - pos;
int got = m_AudioStream.Read(b, pos, toget);
if (got < toget)
m_AudioStream.Position = 0; // loop if the file ends
pos += got;
}
}
else
{
for (int i = 0; i < b.Length; i++)
b[i] = 0;
}
System.Runtime.InteropServices.Marshal.Copy(b, 0, data, size);
}
Please note that this delegate may be called from any internal thread created by the
WaveOutPlayer object, so if you want to call into your Windows Forms objects you should use
the Invoke mechanism.
To stop playing, just call Dispose on the player object, like this:
Collapse | Copy Code
private void Stop()
{
if (m_Player != null)
try
{
m_Player.Dispose();
}
finally
{
m_Player = null;
}
}
Conclusion
3/13/2014 A low-level audio player in C# - CodeProject
http://www.codeproject.com/Articles/3352/A-low-level-audio-player-in-C 3/4
Ianier Munoz
Web Developer
Luxembourg
Ianier Munoz lives in France and works as a senior consultant and analyst for an international
consulting firm. His specialty is in multimedia applications, and he has authored some popular
software, such as American DJ's Pro-Mix, Chronotron and Adapt-X.
Add a Comment or Question