Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rednblackgames/gdx-miniaudio
Advanced Cross Platform Audio Engine for libGDX based on MiniAudio
https://github.com/rednblackgames/gdx-miniaudio
audio-engine cross-platform libgdx miniaudio
Last synced: 3 months ago
JSON representation
Advanced Cross Platform Audio Engine for libGDX based on MiniAudio
- Host: GitHub
- URL: https://github.com/rednblackgames/gdx-miniaudio
- Owner: rednblackgames
- License: apache-2.0
- Created: 2022-05-12T06:54:22.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-10-27T18:55:52.000Z (3 months ago)
- Last Synced: 2024-10-27T23:12:08.970Z (3 months ago)
- Topics: audio-engine, cross-platform, libgdx, miniaudio
- Language: C
- Homepage:
- Size: 5.66 MB
- Stars: 49
- Watchers: 4
- Forks: 7
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGES
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
- awesome-libgdx - gdx-miniaudio - Advanced Cross Platform Audio Engine for libGDX based on MiniAudio. (Resources / Audio)
README
# gdx-miniaudio
![maven-central](https://img.shields.io/maven-central/v/games.rednblack.miniaudio/miniaudio?color=blue&label=release)
![sonatype-nexus](https://img.shields.io/nexus/s/games.rednblack.miniaudio/miniaudio?label=snapshot&server=https%3A%2F%2Foss.sonatype.org)`gdx-miniaudio` is a cross-platform Audio Engine for libGDX based on [MiniAudio](https://miniaud.io/) library.
## Features
- Reading files from internal Assets
- Supported formats: WAV, FLAC, MP3, OGG Vorbis
- Global start and stop/pause
- Master volume control
- Virtual 3D Listener (Position/Direction/WorldUp/Cone)
- Multiple 3D Listeners
- "Fire and forget" Sounds
- Sound creation (with custom flags)
- Sound play/pause/stop/loop/isLooping/isEnd/seekTo
- Sound Volume/Pan/Pitch
- Sound Spatialization (position, direction, cone, attenuation model, rolloff, etc.)
- Sound Fading (In/Out/Custom)
- Sound length and current cursor position
- Sound end callback
- Chain multiple sounds gapless
- Graph Nodes Filters/Effects
- Play raw PCM data
- Waves and Noise generation
- Sound Groups with atomic management
- Sound Groups Spatialization (position, direction, cone, attenuation model, rolloff, etc.)
- libGDX AssetManager Loader
- MASoundPool with libGDX Pool API
- Audio Input Node (microphone)
- Audio Encoder Node (only wav)**Filters**
- Band Pass
- Biquad
- High Pass
- High Shelf
- Low Pass
- Low Shelf
- Notching
- Peaking**Effects**
- Delay/Echo
- Reverb**Mixers**
- Channel Splitter
- Channel Combiner
- Stream Splitter (duplicate source)
- Leading silence trimmer## How to use
### Include gradle dependencies
Native dependencies needs to be included in `core`, `android`, `ios` and `desktop` submodules.
#### Core
```groovy
dependencies {
api "games.rednblack.miniaudio:miniaudio:$miniaudioVersion"
}
```#### Android
```groovy
dependencies {
natives "games.rednblack.miniaudio:miniaudio:$miniaudioVersion:natives-armeabi-v7a"
natives "games.rednblack.miniaudio:miniaudio:$miniaudioVersion:natives-arm64-v8a"
natives "games.rednblack.miniaudio:miniaudio:$miniaudioVersion:natives-x86"
natives "games.rednblack.miniaudio:miniaudio:$miniaudioVersion:natives-x86_64"
}
```#### iOS
```groovy
dependencies {
implementation "games.rednblack.miniaudio:miniaudio:$miniaudioVersion:natives-ios"
}
```#### Desktop
```groovy
dependencies {
implementation "games.rednblack.miniaudio:miniaudio:$miniaudioVersion:natives-desktop"
}
```### Usage
Usage of MiniAudio Engine is straightforward.
```java
public class Main implements ApplicationListener {
MiniAudio miniAudio;
MASound maSound;
AssetManager assetManager;
@Override
public void create() {
//Create only one MiniAudio object!
miniAudio = new MiniAudio();
//Play simple audio
int res = miniAudio.playSound("piano2.wav");
//res contains result code, check it for errors with
//games.rednblack.miniaudio.MAResult class//Create and load a sound without starting it
maSound = miniAudio.createSound("piano2.wav");
// .. sound customization ...
maSound.play();
//AssetManager Loader
assetManager = new AssetManager();
assetManager.setLoader(MASound.class, new MASoundLoader(miniAudio, assetManager.getFileHandleResolver()));
assetManager.load("game.ogg", MASound.class);
// ... load as usual ...
}@Override
public void dispose() {
//Always dispose everything! First all sounds and then the engine
maSound.dispose();
//If MASounds are loaded with the AssetManager be sure to dispose it first
assetManager.dispose();
miniAudio.dispose();
}@Override
public void pause() {
miniAudio.stopEngine();
}@Override
public void resume() {
miniAudio.startEngine();
}
}
```#### Android additions
If current platform is Android, native AssetManager object needs to be injected to `MiniAudio` engine.
Refers to [Interfacing with platform specific code](https://libgdx.com/wiki/app/interfacing-with-platform-specific-code).```java
miniAudio.setupAndroid(Context#getAssets());
```You can safely pass `null` on other platforms.
### Proguard Rules
If your Java code is obfuscated, be sure to keep required JNI methods.```
-keepclassmembers class games.rednblack.miniaudio.MiniAudio {
public void on_native_sound_end(long);
public void on_native_log(int, java.lang.String);
public void on_native_notification(int);
}
```### Effects Graph
MiniAudio comes with a powerful effects system based on graph design.
```
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Data flows left to right >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
+-----------------+
+----------+ +----= Low Pass Filter =----+
+---------------+ | =----+ +-----------------+ | +----------+
| MASound =----= Splitter | +----= ENDPOINT |
+---------------+ | =----+ +-----------------+ | +----------+
+----------+ +----= Echo / Delay =----+
+-----------------+
``````java
MASplitter splitter = new MASplitter(miniAudio);
MALowPassFilter lowPassFilter = new MALowPassFilter(miniAudio, 550, 8);
MADelayNode delayNode = new MADelayNode(miniAudio, 0.25f, 0.45f);miniAudio.attachToEngineOutput(lowPassFilter, 0);
miniAudio.attachToEngineOutput(delayNode, 0);lowPassFilter.attachToThisNode(splitter, 0);
delayNode.attachToThisNode(splitter, 1);splitter.attachToThisNode(maSound, 0);
maSound.loop();
```## TODO
- Blocking Stream PCM data (like libGDX specs - maybe)
- MiniAudio has tons of additional features, open a issue to request more bindings
### License
[MiniAudio](https://github.com/mackron/miniaudio) is licensed under public domain or MIT No Attribution.
`gdx-miniaudio` is available under the Apache 2.0 Open Source License.
```
Copyright (c) 2022 Francesco Marongiu.Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
```