From 6f6e93e01be225327a233fd02e3fd614ae0ee048 Mon Sep 17 00:00:00 2001 From: MeFisto94 Date: Fri, 19 Feb 2016 00:59:15 +0100 Subject: [PATCH 1/2] Simplified the AudioNode constructors (#342) and allow looping/seeking on every AudioNode now by default. --- .../main/java/com/jme3/audio/AudioNode.java | 72 +++++++++++++++++-- 1 file changed, 68 insertions(+), 4 deletions(-) diff --git a/jme3-core/src/main/java/com/jme3/audio/AudioNode.java b/jme3-core/src/main/java/com/jme3/audio/AudioNode.java index 8664af6c7..2ff4134ab 100644 --- a/jme3-core/src/main/java/com/jme3/audio/AudioNode.java +++ b/jme3-core/src/main/java/com/jme3/audio/AudioNode.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009-2012 jMonkeyEngine + * Copyright (c) 2009-2012, 2016 jMonkeyEngine * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -86,6 +86,7 @@ public class AudioNode extends Node implements AudioSource { protected float innerAngle = 360; protected float outerAngle = 360; protected boolean positional = true; + protected Type type = null; /** * Status indicates the current status of the audio node. @@ -112,6 +113,26 @@ public class AudioNode extends Node implements AudioSource { Stopped, } + /** + * Type indicates how to retrieve the audio data. + * It replaced the old "stream" and "streamCache" parameters. + * It defines whether the whole file is read and buffered or + * if it is read gradually from disk. + */ + public enum Type { + /** + * The audio data will be loaded as whole and be buffered in memory. + * Use this for short sounds. + */ + Buffered, + + /** + * The audio data will be streamed gradually from disk. + * Use this for longer sounds. + * Note: looping and seeking is supported. + */ + Streaming, + } /** * Creates a new AudioNode without any audio data set. */ @@ -126,6 +147,22 @@ public class AudioNode extends Node implements AudioSource { */ public AudioNode(AudioData audioData, AudioKey audioKey) { setAudioData(audioData, audioKey); + if (audioKey.isStream()) { + type = Type.Streaming; + } else { + type = Type.Buffered; + } + } + + /** + * Creates a new AudioNode with the given audio file. + * @param assetManager The asset manager to use to load the audio file + * @param name The filename of the audio file + * @param type The type. If Type.Streaming, the audio will be streamed gradually from disk, + * otherwise it will be buffered (Type.Buffered) + */ + public AudioNode(AssetManager assetManager, String name, Type type) { + this(assetManager, name, type == Type.Streaming, true); } /** @@ -139,10 +176,17 @@ public class AudioNode extends Node implements AudioSource { * the stream cache is used. When enabled, the audio stream will * be read entirely but not decoded, allowing features such as * seeking, looping and determining duration. + * + * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioNode.Type)} instead */ public AudioNode(AssetManager assetManager, String name, boolean stream, boolean streamCache) { this.audioKey = new AudioKey(name, stream, streamCache); this.data = (AudioData) assetManager.loadAsset(audioKey); + if (stream) { + type = Type.Streaming; + } else { + type = Type.Buffered; + } } /** @@ -152,9 +196,11 @@ public class AudioNode extends Node implements AudioSource { * @param name The filename of the audio file * @param stream If true, the audio will be streamed gradually from disk, * otherwise, it will be buffered. + * + * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioNode.Type)} instead */ public AudioNode(AssetManager assetManager, String name, boolean stream) { - this(assetManager, name, stream, false); + this(assetManager, name, stream, true); // Always streamCached } /** @@ -167,7 +213,7 @@ public class AudioNode extends Node implements AudioSource { * @deprecated AudioRenderer parameter is ignored. */ public AudioNode(AudioRenderer audioRenderer, AssetManager assetManager, String name) { - this(assetManager, name, false); + this(assetManager, name, Type.Buffered); } /** @@ -175,9 +221,10 @@ public class AudioNode extends Node implements AudioSource { * * @param assetManager The asset manager to use to load the audio file * @param name The filename of the audio file + * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioNode.Type)} instead */ public AudioNode(AssetManager assetManager, String name) { - this(assetManager, name, false); + this(assetManager, name, Type.Buffered); } protected AudioRenderer getRenderer() { @@ -283,6 +330,12 @@ public class AudioNode extends Node implements AudioSource { data = audioData; this.audioKey = audioKey; + + if (audioKey.isStream()) { + type = Type.Streaming; + } else { + type = Type.Buffered; + } } /** @@ -310,6 +363,17 @@ public class AudioNode extends Node implements AudioSource { this.status = status; } + /** + * This is set only once in the constructor. + * It defines, whether the underlying Data is Buffered or + * Streamed continuously. + * Warning: Can return null! + * @return The {@link Type} of the audio node. + */ + public Type getType() { + return type; + } + /** * @return True if the audio will keep looping after it is done playing, * otherwise, false. From c90048595f4b310cce3f2164a299d2c13f79adb7 Mon Sep 17 00:00:00 2001 From: MeFisto94 Date: Wed, 24 Feb 2016 02:46:16 +0100 Subject: [PATCH 2/2] Removed AudioNode.Type in favor of AudioData.DataType, which is what we are using now. --- .../main/java/com/jme3/audio/AudioNode.java | 70 +++++-------------- 1 file changed, 18 insertions(+), 52 deletions(-) diff --git a/jme3-core/src/main/java/com/jme3/audio/AudioNode.java b/jme3-core/src/main/java/com/jme3/audio/AudioNode.java index 2ff4134ab..2c5cc5b98 100644 --- a/jme3-core/src/main/java/com/jme3/audio/AudioNode.java +++ b/jme3-core/src/main/java/com/jme3/audio/AudioNode.java @@ -33,6 +33,7 @@ package com.jme3.audio; import com.jme3.asset.AssetManager; import com.jme3.asset.AssetNotFoundException; +import com.jme3.audio.AudioData.DataType; import com.jme3.export.InputCapsule; import com.jme3.export.JmeExporter; import com.jme3.export.JmeImporter; @@ -86,7 +87,6 @@ public class AudioNode extends Node implements AudioSource { protected float innerAngle = 360; protected float outerAngle = 360; protected boolean positional = true; - protected Type type = null; /** * Status indicates the current status of the audio node. @@ -113,26 +113,6 @@ public class AudioNode extends Node implements AudioSource { Stopped, } - /** - * Type indicates how to retrieve the audio data. - * It replaced the old "stream" and "streamCache" parameters. - * It defines whether the whole file is read and buffered or - * if it is read gradually from disk. - */ - public enum Type { - /** - * The audio data will be loaded as whole and be buffered in memory. - * Use this for short sounds. - */ - Buffered, - - /** - * The audio data will be streamed gradually from disk. - * Use this for longer sounds. - * Note: looping and seeking is supported. - */ - Streaming, - } /** * Creates a new AudioNode without any audio data set. */ @@ -147,22 +127,17 @@ public class AudioNode extends Node implements AudioSource { */ public AudioNode(AudioData audioData, AudioKey audioKey) { setAudioData(audioData, audioKey); - if (audioKey.isStream()) { - type = Type.Streaming; - } else { - type = Type.Buffered; - } } /** * Creates a new AudioNode with the given audio file. * @param assetManager The asset manager to use to load the audio file * @param name The filename of the audio file - * @param type The type. If Type.Streaming, the audio will be streamed gradually from disk, - * otherwise it will be buffered (Type.Buffered) + * @param type The type. If {@link com.jme3.audio.AudioData.DataType}.Stream, the audio will be streamed gradually from disk, + * otherwise it will be buffered ({@link com.jme3.audio.AudioData.DataType}.Buffer) */ - public AudioNode(AssetManager assetManager, String name, Type type) { - this(assetManager, name, type == Type.Streaming, true); + public AudioNode(AssetManager assetManager, String name, DataType type) { + this(assetManager, name, type == DataType.Stream, true); } /** @@ -177,16 +152,11 @@ public class AudioNode extends Node implements AudioSource { * be read entirely but not decoded, allowing features such as * seeking, looping and determining duration. * - * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioNode.Type)} instead + * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioData.DataType)} instead */ public AudioNode(AssetManager assetManager, String name, boolean stream, boolean streamCache) { this.audioKey = new AudioKey(name, stream, streamCache); this.data = (AudioData) assetManager.loadAsset(audioKey); - if (stream) { - type = Type.Streaming; - } else { - type = Type.Buffered; - } } /** @@ -197,7 +167,7 @@ public class AudioNode extends Node implements AudioSource { * @param stream If true, the audio will be streamed gradually from disk, * otherwise, it will be buffered. * - * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioNode.Type)} instead + * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioData.DataType)} instead */ public AudioNode(AssetManager assetManager, String name, boolean stream) { this(assetManager, name, stream, true); // Always streamCached @@ -213,7 +183,7 @@ public class AudioNode extends Node implements AudioSource { * @deprecated AudioRenderer parameter is ignored. */ public AudioNode(AudioRenderer audioRenderer, AssetManager assetManager, String name) { - this(assetManager, name, Type.Buffered); + this(assetManager, name, DataType.Buffer); } /** @@ -221,10 +191,10 @@ public class AudioNode extends Node implements AudioSource { * * @param assetManager The asset manager to use to load the audio file * @param name The filename of the audio file - * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioNode.Type)} instead + * @deprecated Use {@link AudioNode#AudioNode(com.jme3.asset.AssetManager, java.lang.String, com.jme3.audio.AudioData.DataType) } instead */ public AudioNode(AssetManager assetManager, String name) { - this(assetManager, name, Type.Buffered); + this(assetManager, name, DataType.Buffer); } protected AudioRenderer getRenderer() { @@ -330,12 +300,6 @@ public class AudioNode extends Node implements AudioSource { data = audioData; this.audioKey = audioKey; - - if (audioKey.isStream()) { - type = Type.Streaming; - } else { - type = Type.Buffered; - } } /** @@ -364,14 +328,16 @@ public class AudioNode extends Node implements AudioSource { } /** - * This is set only once in the constructor. - * It defines, whether the underlying Data is Buffered or - * Streamed continuously. + * Get the Type of the underlying AudioData to see if it's streamed or buffered. + * This is a shortcut to getAudioData().getType() * Warning: Can return null! - * @return The {@link Type} of the audio node. + * @return The {@link com.jme3.audio.AudioData.DataType} of the audio node. */ - public Type getType() { - return type; + public DataType getType() { + if (data == null) + return null; + else + return data.getDataType(); } /**