From 7285c32d58aadf5037597471c28cacf1733cdae0 Mon Sep 17 00:00:00 2001 From: Jonathan Coates Date: Thu, 25 Jul 2024 20:32:08 +0100 Subject: [PATCH] Document that the speaker re-encoded audio samples --- .../peripheral/speaker/SpeakerPeripheral.java | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/projects/common/src/main/java/dan200/computercraft/shared/peripheral/speaker/SpeakerPeripheral.java b/projects/common/src/main/java/dan200/computercraft/shared/peripheral/speaker/SpeakerPeripheral.java index 8a081deb6..96405f1d9 100644 --- a/projects/common/src/main/java/dan200/computercraft/shared/peripheral/speaker/SpeakerPeripheral.java +++ b/projects/common/src/main/java/dan200/computercraft/shared/peripheral/speaker/SpeakerPeripheral.java @@ -273,16 +273,18 @@ public abstract class SpeakerPeripheral implements IPeripheral { * Attempt to stream some audio data to the speaker. *

* This accepts a list of audio samples as amplitudes between -128 and 127. These are stored in an internal buffer - * and played back at 48kHz. If this buffer is full, this function will return {@literal false}. You should wait for - * a [`speaker_audio_empty`] event before trying again. + * and played back at 48kHz. If this buffer is full, this function will return {@literal false}. Programs should + * wait for a [`speaker_audio_empty`] event before trying to play audio again. *

- * > [!NOTE] - * > The speaker only buffers a single call to {@link #playAudio} at once. This means if you try to play a small - * > number of samples, you'll have a lot of stutter. You should try to play as many samples in one call as possible - * > (up to 128×1024), as this reduces the chances of audio stuttering or halting, especially when the server or - * > computer is lagging. + * The speaker only buffers a single call to {@link #playAudio} at once. This means if you try to play a small + * number of samples, you'll have a lot of stutter. You should try to play as many samples in one call as possible + * (up to 128×1024), as this reduces the chances of audio stuttering or halting, especially when the server or + * computer is lagging. *

- * [`speaker_audio`] provides a more complete guide to using speakers + * While the speaker accepts 8-bit PCM audio, the audio stream is re-encoded before being played. This means that + * the supplied samples may not be played out exactly. + *

+ * [`speaker_audio`] provides a more complete guide to using speakers. * * @param context The Lua context. * @param audio The audio data to play.