Package net.risingworld.api.assets
Class SoundAsset
java.lang.Object
net.risingworld.api.assets.Asset
net.risingworld.api.assets.SoundAsset
Represents a custom audio file (this could either be a sound effect or a music track).
Supported file formats: ogg, mp2, mp3, midi/mid, wav, flac
Example: Create a SoundAsset and play it for every player who joins the game
Supported file formats: ogg, mp2, mp3, midi/mid, wav, flac
-
Nested Class Summary
Nested classes/interfaces inherited from class net.risingworld.api.assets.Asset
Asset.Source, Asset.Type
-
Field Summary
Fields inherited from class net.risingworld.api.assets.Asset
DEFAULT_EXTENSION
-
Method Summary
Modifier and TypeMethodDescriptionboolean
Determines if the sound is streamed or not.static SoundAsset
load
(byte[] data) static SoundAsset
loadFromAssetBundle
(AssetBundle bundle, String path) static SoundAsset
loadFromFile
(String file) Creates a new sound asset referencing a file on harddrive.static SoundAsset
loadFromFile
(String file, boolean streamed) Creates a new sound asset referencing a file on harddrive.static SoundAsset
loadFromPlugin
(Plugin plugin, String resource) Creates a new sound asset and loads the sound from the plugin jar file.static SoundAsset
loadFromURL
(String url) Loads a stream from an URL.Methods inherited from class net.risingworld.api.assets.Asset
dispose, equals, getChecksum, getDependency, getExtension, getHandle, getPath, getSource, getType, hashCode, isDisposed
-
Method Details
-
loadFromFile
Creates a new sound asset referencing a file on harddrive.- Parameters:
file
- the path to the sound file on the harddrive.- Returns:
- a new sound asset instance.
- Example: Load sound "explosion.ogg" from "assets" subfolder in plugin directory
-
loadFromFile
Creates a new sound asset referencing a file on harddrive. Optionally you can determine if the sound should be streamed or not. Usually the whole sound file is loaded into memory before playing it, but if streaming is enabled, the game reads the sound while playing. This reduces memory consumption, but increases cpu load. By default, streaming is disabled.
Important: It only makes sense to stream large sound files, e.g music etc.- Parameters:
file
- the path to the sound file on the harddrive.streamed
- true to enable streaming, false to disable it (default).- Returns:
- a new sound asset instance.
-
loadFromPlugin
Creates a new sound asset and loads the sound from the plugin jar file.- Parameters:
plugin
- a reference to the plugin. This is required to make sure the game loads the resource from the correct plugin jar.resource
- the path to the resource (inside the jar file).- Returns:
- a new sound asset instance.
- Example: Load sound "explosion.ogg" from jar file (in package rw.plugin.sounds)
-
loadFromAssetBundle
-
load
-
loadFromURL
Loads a stream from an URL. This could be a link to an online radio stream, for example.- Parameters:
url
- the URL to the stream.- Returns:
- a new sound asset instance.
-
isStreamed
public boolean isStreamed()Determines if the sound is streamed or not.- Returns:
- true if this sound will be streamed, false if not.
-