Sasha Szpakowski 8830ab01fe fixup! reapply love-specific patches to OpenAL-Soft 9 months ago
..
.github 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
al 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
alc 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
cmake 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
common 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
configs 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
core 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
docs 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
examples 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
fmt-11.1.1 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
hrtf 73a6fc9196 Update OpenAL-soft to 1.23.1-bc7cb17. 1 year ago
include 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
presets 73a6fc9196 Update OpenAL-soft to 1.23.1-bc7cb17. 1 year ago
resources 904cc75ba8 Update OpenAL-soft to 1.21.1 5 years ago
router 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
tests 73a6fc9196 Update OpenAL-soft to 1.23.1-bc7cb17. 1 year ago
utils 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
.clang-tidy 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
.gitignore 73a6fc9196 Update OpenAL-soft to 1.23.1-bc7cb17. 1 year ago
.travis.yml 2b15394df5 Update OpenAL-Soft to 1.22.0 3 years ago
BSD-3Clause 2b15394df5 Update OpenAL-Soft to 1.22.0 3 years ago
CMakeLists.txt bc423714ec reapply love-specific patches to OpenAL-Soft 9 months ago
COPYING 1f9c102832 Update OpenAL Soft to 1.19.1. 7 years ago
ChangeLog 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
LICENSE-pffft 73a6fc9196 Update OpenAL-soft to 1.23.1-bc7cb17. 1 year ago
OpenALConfig.cmake.in 73a6fc9196 Update OpenAL-soft to 1.23.1-bc7cb17. 1 year ago
README.md 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
XCompile-Android.txt 904cc75ba8 Update OpenAL-soft to 1.21.1 5 years ago
XCompile.txt e9d77ef766 Added missing changes to the OpenAL-Soft update. 10 years ago
alsoftrc.sample 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
appveyor.yml 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
config.h.in 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
config_backends.h.in 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
config_simd.h.in 5e4f3241ac update OpenAL-Soft to 1.24.3. 9 months ago
libopenal.version bc423714ec reapply love-specific patches to OpenAL-Soft 9 months ago
openal.pc.in 5be7c968b8 Update OpenAL Soft to commit 414b56edec5441211dc924fef365c54267c04f1c 8 years ago
opensl_latency.cpp 8830ab01fe fixup! reapply love-specific patches to OpenAL-Soft 9 months ago
version.cmake b160006eb1 Update OpenAL Soft to 1.18.2 8 years ago
version.h.in 904cc75ba8 Update OpenAL-soft to 1.21.1 5 years ago

README.md

OpenAL Soft

master branch CI status : GitHub Actions Status Windows Build Status

OpenAL Soft is an LGPL-licensed, cross-platform, software implementation of the OpenAL 3D audio API. It's forked from the open-sourced Windows version available originally from openal.org's SVN repository (now defunct). OpenAL provides capabilities for playing audio in a virtual 3D environment. Distance attenuation, doppler shift, and directional sound emitters are among the features handled by the API. More advanced effects, including air absorption, occlusion, and environmental reverb, are available through the EFX extension. It also facilitates streaming audio, multi-channel buffers, and audio capture.

More information is available on the official website.

Source Install

To install OpenAL Soft, use your favorite shell to go into the build/ directory, and run:

cmake ..

Alternatively, you can use any available CMake front-end, like cmake-gui, ccmake, or your preferred IDE's CMake project parser.

Assuming configuration went well, you can then build it. The command cmake --build . will instruct CMake to build the project with the toolchain chosen during configuration (often GNU Make or NMake, although others are possible).

Please Note: Double check that the appropriate backends were detected. Often, complaints of no sound, crashing, and missing devices can be solved by making sure the correct backends are being used. CMake's output will identify which backends were enabled.

For most systems, you will likely want to make sure PipeWire, PulseAudio, and ALSA were detected (if your target system uses them). For Windows, make sure WASAPI was detected.

Building openal-soft - Using vcpkg

You can download and install openal-soft using the vcpkg dependency manager:

git clone https://github.com/Microsoft/vcpkg.git
cd vcpkg
./bootstrap-vcpkg.sh
./vcpkg integrate install
./vcpkg install openal-soft

The openal-soft port in vcpkg is kept up to date by Microsoft team members and community contributors. If the version is out of date, please create an issue or pull request on the vcpkg repository.

Utilities

The source package comes with an informational utility, openal-info, and is built by default. It prints out information provided by the ALC and AL sub- systems, including discovered devices, version information, and extensions.

Configuration

OpenAL Soft can be configured on a per-user and per-system basis. This allows users and sysadmins to control information provided to applications, as well as application-agnostic behavior of the library. See alsoftrc.sample for available settings.

Language Bindings

As a C API, OpenAL Soft can be used directly by any language that can use functions with C linkage. For languages that can't directly use C-style headers, bindings may be developed to allow code written in that language to call into the library. Some bindings for some languages are listed here.

C# Bindings:

  • OpenTK includes low-level C# bindings for the OpenAL API, including some extensions. It also includes utility libraries for math and linear algebra, which can be useful for 3D calculations.

Java Bindings:

  • LWJGL, the Lightweight Java Game Library, includes Java bindings for the OpenAL API, usable with OpenAL Soft.
  • JOAL, part of the JogAmp project, includes Java bindings for the OpenAL API, usable with OpenAL Soft. It also includes a higher level Sound3D Toolkit API and utility functions to make easier use of OpenAL features and capabilities.

Kotlin Bindings:

  • Multiplatform OpenAL, developed for the Kleaver project, includes Kotlin/Native bindings for the OpenAL API, based on OpenAL Soft with support for Windows, Linux, macOS, iOS and Android.

Python Bindings:

  • PyOpenAL. Also includes methods to play wave files and, with PyOgg, also Vorbis, Opus, and FLAC.

FreePascal/Lazarus Bindings:

  • ALSound. Also includes a higher level API and libsndfile support to simplify loading and playing sounds.

Other bindings for these and other languages also exist. This list will grow as more bindings are found.

Acknowledgements

Special thanks go to:

  • Creative Labs for the original source code this is based off of.
  • Christopher Fitzgerald for the current reverb effect implementation, and helping with the low-pass and HRTF filters.
  • Christian Borss for the 3D panning code previous versions used as a base.
  • Ben Davis for the idea behind a previous version of the click-removal code.
  • Richard Furse for helping with my understanding of Ambisonics that is used by the various parts of the library.