Menu

[r3358]: / trunk / LWJGL / www / documentation_openal_04.php  Maximize  Restore  History

Download this file

147 lines (134 with data), 6.8 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
<? require('_include/header.php'); ?>
<div style="margin: 0px 0px 10px 10px; width: 240px; float: right; border: 1px solid #000000;">
<table border="0" cellpadding="3" cellspacing="0">
<tr>
<td width="100%" style="text-align: center; background-color: #cccccc; font-weight: bold; border-bottom: 1px solid #000000;" colspan="2">Other Articles in the Series</td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_01.php">Lesson 1: Single Static Source</a></td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_02.php">Lesson 2: Looping and Fade-away</a></td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_03.php">Lesson 3: Multiple Sources</a></td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_04.php">Lesson 4: A Closer Look at ALC</a></td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_05.php">Lesson 5: Sources Sharing Buffers</a></td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_06.php">Lesson 6: Advanced Loading and Error Handles</a></td>
</tr>
<tr>
<td valign="top">&middot;</td>
<td width="100%" style="text-align: left;"><a href="documentation_openal_07.php">Lesson 7: The Doppler Effect</a></td>
</tr>
</table>
</div>
<h1>A Closer Look at ALC: Lesson 4</h1>
<p>
<i>
Author: <a href="mailto:lightonthewater@hotmail.com">Jesse Maurais</a> | From: <a href="http://www.devmaster.net/articles.php?catID=6" target="_blank">devmaster.net</a><br/>
Modified for LWJGL by: <a href="mailto:brian@matzon.dk">Brian Matzon</a>
</i>
</p>
<p>
<i><b>Note:</b>This article originally deals with ALC Context management,
and especially using multiple contexts. The LWJGL binding does <b>not</b>
expose multiple contexts, nor do we have any plans to do so. It is an
advanced feature, not used in games. This article has also been edited
heavily to make sense in an LWJGL environment which doesn't expose ALC
directly.</i>
</p>
<p>
Up until now we have been letting <code>AL.create()</code> do all the real
tricky stuff for us. For example handling the audio devices. It's really
nice that the <code>AL.create()</code> method is there to provide this
functionality, but any smart coder will want to know exactly what their
doing. We may want to, at some point, use the verbose
<code>AL.create(String deviceArguments, <span class="codeKeyword">int</span>
contextFrequency, <span class="codeKeyword">int</span> contextRefresh,
<span class="codeKeyword">boolean</span> contextSynchronized)</code> method.
In this tutorial we will expose the Alc layer and take a look at how to
handle the devices on our own.</p>
</p>
<p>
When using either of the two create methods of <code>AL</code>, a default
context and device is created for you. You cannot create multiple contexts
nor can you access multiple devices. Thus a lot of the ALC methods are not
available, since they simply don't make any sense. Methods that are
available also no longer take a device or context parameter since they are
managed internally.
</p>
<pre class="code" style="clear: right;">
<span class="codeComment">// Initialize OpenAL and clear the error bit.</span>
<span class="codeKeyword">try</span>{
AL.create();
} <span class="codeKeyword">catch</span> (LWJGLException le) {
le.printStackTrace();
<span class="codeKeyword">return</span>;
}
AL10.alGetError();
</pre>
<p>
Using the default create method is the simplest way to create a context and
access a device. Default values are used, and once called OpenAL is
initialized and ready to go.
</p>
<pre class="code">
<span class="codeComment">// Initialize OpenAL and clear the error bit.</span>
<span class="codeKeyword">try</span>{
AL.create("DirectSound3D", 44100, 15, <span class="codeKeyword">false</span>);
} <span class="codeKeyword">catch</span> (LWJGLException le) {
le.printStackTrace();
<span class="codeKeyword">return</span>;
}
AL10.alGetError();
</pre>
<p>
Here we initialize OpenAL using arguments for ALC. The first argument tells
ALC which device to access. Passing null is a perfectly valid argument. It
forces the ALC to use a default device.<br/>
The second argument tells ALC the frequency for mixing output buffer, in
units of Hz. Third argument tells ALC how often it should update it's
internal state and buffers. The final argument determines whether the ALC
should run in synchronous mode.
</p>
<pre class="code">
<span class="codeKeyword">public static int</span> alcGetError();
<span class="codeKeyword">public static boolean</span> alcIsExtensionPresent(String extName);
<span class="codeKeyword">public static int</span> alcGetEnumValue(String enumName);
<span class="codeKeyword">public static </span>String alcGetString(<span class="codeKeyword">int</span> pname);
<span class="codeKeyword">public static void</span> alcGetInteger(<span class="codeKeyword">int</span> pname, IntBuffer integerdata);
</pre>
<p>
It may be pretty obvious to you what these do, but lets humour ourselves and
have a closer look. First we have 'alcGetError' which is just like
'alGetError' but will return Alc errors. The next two functions are for
querying Alc extensions. This was just the creators planning ahead, as there
are no Alc extensions either. The last function, 'alcGetInteger', will
return the Alc version when passed 'ALC_MAJOR_VERSION' or 'ALC_MINOR_VERSION'.<br/><br/>
The function 'alcGetString' is pretty cool. It can take any of the following
three parameters to 'token':<br/><br/>
&nbsp;&nbsp;&nbsp;* ALC_DEFAULT_DEVICE_SPECIFIER<br/>
&nbsp;&nbsp;&nbsp;* ALC_DEVICE_SPECIFIER<br/>
&nbsp;&nbsp;&nbsp;* ALC_EXTENSIONS<br/><br/>
The first will return the device string which your OpenAL implementation
will prefer you to use. In current OpenAL this should be "DirectSound3D",
like we used above. The second token will return a list of specifiers, but
in current OpenAL will only return "DirectSound" (without the "3D" for some
reason). The last will return a list of Alc extensions, of which none exist
yet.<br/><br/>
Well that's most of Alc for you. I hope it gave you a better understanding
of how OpenAL interacts with the operation system.
</p>
<? require('_include/footer.php'); ?>
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.