SFPlayer:
Filter:
SFPlayer/Classes (extension) | UGens > InOut | UGens > Buffer

SFPlayer
ExtensionExtension

A soundfile player

Description

SFPlayer plays sound files directly from disk. It also has a convenient -gui.

The most common use is: SFPlayer.new.gui or SFPlayer.new("/path/to/soundfile").gui. See examples below.

Class Methods

.new

Arguments:

path

The path to a soundfile. Can be nil for choosing the file later.

outbus

The bus to output to. Defaults to 0 (the first physical output).

server

The server to use. If nil, Server.default will be used.

skin

Optionally an instance of SFPlayerSkin, controlling the color scheme of the GUI when shown.

autoShowOpenDialog

If true and no path is specified, an Open Dialog will be shown upon creating new instance to choose the file.

autoBootServer

If true and the server is not running, it will be booted automatically.

autoSetSampleRate

If true and the server is booted automatically, its sampleRate will be set to the file's sampleRate.

autoSetOutputChannels

If true and the number of channels in the file exceeds server's number of output channels, as well as the server is booted automatically, its number of output channels will be increased to match the number of channels in the soundfile.

Instance Methods

.gui

Show a GUI of the SFPlayer. This creates an instance of SFPlayerView, stored under -view.

Arguments:

argBounds

Bounds of the gui. If nil, a default size will be used.

doneAction

Action to be performed after opening the gui and loading the soundfile into the SoundFileView.

onCloseAction

Action to be performed after closing the gui.

parent

Optionally a parent view to embed this SFPlayerView in.

Returns:

this SFPlayer (not the SFPlayerView)

.play

Play the file from the current position;

.stop

Stop playing. startTime is left at the original value;

Arguments:

updateStart

If true, the cursor in the GUI and other dependants will be reset to the previous start postion.

.pause

Stop playing. startTime is updated to the current playback position.

NOTE: If pause is called when the player is stopped, it will preload the playback buffer and wait for the start of playback. This allows starting playback without additional delay on slower storage or when multiple players are synchronized together

.reset

Updates the player to the initial state (resets playback position, amp, etc.)

.view

Returns:

If the gui was created, this returns an instance of the SFPlayerView.

.attRelTime

Get/Set the time of fade in / fade out when starting/stopping. Increase this value for seamless looping (see below).

Looping

NOTE: For seamless looping, increase attRelTime and set the loopEnd parameter to at least attRelTime less than the soundfile's duration.

.loop

Turn looping on/off by setting loop to true or false.

.loopBeginning

Get/Set loop beginning (in seconds).

.loopEnd

Get/Set loop end (in seconds).

.loopBeginningEnd

Set both beginning and end of the loop (used by the SFPlayerView).

Synchronizing multiple players

It is possible to link multiple players together and have them start playback at the same time.

Examples