fb
Properties
fb.AlwaysOnTop | boolean |
read, write | ||
fb.ComponentPath | string |
read | ||
fb.CursorFollowPlayback | boolean |
read, write | ||
3.5.4 | fb.CustomVolume | number |
read | See note below. |
fb.FoobarPath | string |
read | ||
fb.IsPaused | boolean |
read | ||
fb.IsPlaying | boolean |
read | ||
fb.PlaybackFollowCursor | boolean |
read, write | ||
fb.PlaybackLength | number |
read | ||
fb.PlaybackTime | number |
read, write | ||
fb.ProfilePath | string |
read | ||
fb.ReplaygainMode | ReplaygainMode | read, write | ||
fb.StopAfterCurrent | boolean |
read, write | ||
fb.VersionString | string |
read | ||
fb.Volume | number |
read, write | See note below. |
Example
fb.AlwaysOnTop = !fb.AlwaysOnTop; // toggles the current value
console.log(fb.FoobarPath); // Z:\foobar2000\
fb.PlaybackTime = 60; // jump to the one minute mark
Custom Volume
fb.CustomVolume
can be used for displaying the volume from UPnP
devices. It will return
a value of -1
when using a normal device and that also indicates that fb.Volume
is writable.
When a custom volume control is active, you can not use fb.Volume
and must use fb.VolumeUp()
/ fb.VolumeDown()
/ fb.VolumeMute()
.
Methods
Shortcuts to main menu commands#
fb.AddDirectory() |
fb.AddFiles() |
fb.Exit() |
fb.LoadPlaylist() |
fb.Next() |
fb.Pause() |
fb.Play() |
fb.PlayOrPause() |
fb.Prev() |
fb.Random() |
fb.SavePlaylist() |
fb.ShowConsole() |
fb.ShowPreferences() |
fb.Stop() |
fb.VolumeDown() |
fb.VolumeMute() |
fb.VolumeUp() |
The above methods have no return value.
fb.AddLocationsAsync(window_id, paths)
#
Arguments | ||
---|---|---|
window_id | window.ID | |
paths | array |
An array of strings which could be files, urls, playlists. |
Returns a unique task_id
.
Similar to plman.AddLocations except rather than specifiying a target playlist, you get a handle list generated from the supplied paths/urls which are sent to a new on_locations_added callback.
Example
var files = ["z:\\1.mp3", "z:\\2.flac"];
function on_mouse_lbtn_dblclk() {
var task_id = fb.AddLocationsAsync(window.ID, files);
console.log("got task_id", task_id);
}
function on_locations_added(task_id, handle_list) {
console.log("callback task_id", task_id);
console.log(handle_list.Count);
}
fb.CheckClipboardContents()
#
Returns a boolean
value.
Checks clipboard contents are handles or a file selection
from Windows Explorer
. Use in conjunction with
fb.GetClipboardContents.
fb.CheckComponent(name)
#
Arguments | ||
---|---|---|
name | string |
Returns a boolean
value.
Use this if your script depends on other components.
Example
if (!fb.CheckComponent("foo_playcount")) {
utils.ShowPopupMessage("This script requires foo_playcount.", "Rating");
}
fb.ClearPlaylist()
#
No return value.
Clears active playlist. If you wish to clear a specific playlist, use plman.ClearPlaylist.
fb.CreateContextMenuManager()
#
Returns an IContextMenuManager instance.
fb.CreateHandleList([handle])
#
Arguments | ||
---|---|---|
handle | IMetadbHandle, optional |
Returns an IMetadbHandleList instance.
Example
var handle = fb.GetFocusItem();
var handle_list = fb.CreateHandleList(handle);
var image_path = ...
handle_list.AttachImage(image_path, 0);
handle_list.Dispose();
fb.CreateMainMenuManager(root_name)
#
Arguments | ||
---|---|---|
root_name | string |
Must be one of File , Edit , View , Playback , Library , Help . |
Returns an IMainMenuManager instance.
fb.EnableAdvancedLogging()
#
3.6.1
No return value.
Only enable this if you're having problems diagnosing your own script errors. The setting persists
until foobar2000
is closed. To disable this advanced logging, remove this method and restart
foobar2000
.
Console messages will point directly at the C++
source code and this is something that you can
ask about in the main support thread.
fb.GetAlbumArtStub([art_id])
#
3.3.10
Arguments | ||
---|---|---|
art_id | AlbumArtId | Default 0 . |
Returns an IJSImage instance or null
on failure.
fb.GetAudioChunk(requested_length[, offset])
#
3.6.6
Arguments | ||
---|---|---|
requested_length | number |
seconds |
offset | number |
Default 0 |
Returns an IAudioChunk instance or null
on failure.
The source code is basically this:
STDMETHODIMP Fb::GetAudioChunk(double requested_length, double offset, IAudioChunk** out)
{
RETURN_HR_IF_NULL(E_POINTER, out);
// return value will be null in JavaScript if the code below fails
*out = nullptr;
if (m_vis.is_valid())
{
double time{};
if (m_vis->get_absolute_time(time))
{
audio_chunk_impl chunk;
if (m_vis->get_chunk_absolute(chunk, time + offset, requested_length))
{
// success, return value will be a valid audio chunk
*out = new ComObject<AudioChunk>(chunk);
}
}
}
return S_OK;
}
get_absolute_time
and get_chunk_absolute
and their arguments are described here:
https://github.com/marc2k3/foobar2000-sdk/blob/main/foobar2000/SDK/vis.h
fb.GetClipboardContents()
#
Returns an IMetadbHandleList instance.
Clipboard contents can be handles copied to the clipboard in other components, a file selection from Explorer, etc.
Example
// ==PREPROCESSOR==
// @import "%fb2k_component_path%helpers.txt"
// ==/PREPROCESSOR==
function on_mouse_rbtn_up(x, y) {
var ap = plman.ActivePlaylist;
// playlist_can_add_items is defined in helpers.txt, it uses
// plman.GetPlaylistLockFilterMask to determine if the active playlist
// permits adding items
// MF_STRING and MF_GRAYED are also defined there.
var can_paste_flag = playlist_can_add_items(ap) && fb.CheckClipboardContents() ? MF_STRING : MF_GRAYED;
var menu = window.CreatePopupMenu();
menu.AppendMenuItem(can_paste_flag, 1, "Paste");
var idx = menu.TrackPopupMenu(x, y);
menu.Dispose();
if (idx == 1) {
var handle_list = fb.GetClipboardContents();
plman.InsertPlaylistItems(ap, plman.GetPlaylistItemCount(ap), handle_list);
handle_list.Dispose();
}
return true;
}
fb.GetDSPPresets()
#
Returns a JSON
array in string form so you need to use JSON.parse
on the result.
Example
var str = fb.GetDSPPresets();
console.log(str);
[
{
"active": true,
"name": "two"
},
{
"active": false,
"name": "three"
}
]
var arr = JSON.parse(str);
console.log(arr.length); // number of presets
for (var i = 0; i < arr.length; i++) {
if (arr[i].active) {
// this is the active preset, do something with the name??
}
}
fb.GetFocusItem()
#
Returns an IMetadbHandle instance.
Handle of the currently selected active playlist item or null
on failure.
fb.GetLibraryItems([query])
#
Arguments | ||
---|---|---|
query | string |
Optional. If omitted or invalid, all items will be returned. |
Returns an IMetadbHandleList instance.
fb.GetNowPlaying()
#
Returns an IMetadbHandle instance.
Now playing item or null
if foobar2000 isn't playing.
fb.GetOutputDevices()
#
Returns a JSON
array in string form so you need to use JSON.parse
on the result.
Example
var str = fb.GetOutputDevices();
console.log(str);
[
{
"active": false,
"device_id": "{5243F9AD-C84F-4723-8194-0788FC021BCC}",
"name": "Null Output",
"output_id": "{EEEB07DE-C2C8-44C2-985C-C85856D96DA1}"
},
{
"active": true,
"device_id": "{00000000-0000-0000-0000-000000000000}",
"name": "Primary Sound Driver",
"output_id": "{D41D2423-FBB0-4635-B233-7054F79814AB}"
},
{
"active": false,
"device_id": "{1C4EC038-97DB-48E7-9C9A-05FDED46847B}",
"name": "Speakers (Sound Blaster Z)",
"output_id": "{D41D2423-FBB0-4635-B233-7054F79814AB}"
},
{
"active": false,
"device_id": "{41B86272-3D6C-4A5A-8907-4FE7EBE39E7E}",
"name": "SPDIF-Out (Sound Blaster Z)",
"output_id": "{D41D2423-FBB0-4635-B233-7054F79814AB}"
},
{
"active": false,
"device_id": "{9CDC0FAE-2870-4AFA-8287-E86099D69076}",
"name": "3 - BenQ BL3200 (AMD High Definition Audio Device)",
"output_id": "{D41D2423-FBB0-4635-B233-7054F79814AB}"
}
]
var arr = JSON.parse(str);
console.log(arr.length); // number of devices
As you can see, only one of the items in the array has active
set to true
so that is the device you'd want to display the name of
or mark as selected in a menu.
To change device you can use fb.RunMainMenuCommand with the
device name or use fb.SetOutputDevice with the
device_id
/output_id
.
Example
var str = fb.GetOutputDevices();
var arr = JSON.parse(str);
// Assuming same list from above, switch output to the last device.
fb.RunMainMenuCommand("Playback/Device/" + arr[4].name);
var str = fb.GetOutputDevices();
var arr = JSON.parse(str);
// Assuming same list from above, switch output to the last device.
fb.SetOutputDevice(arr[4].output_id, arr[4].device_id);
fb.GetSelection([flags])
#
Arguments | ||
---|---|---|
flags | number |
Default 0 , 1 no now playing |
Returns an IMetadbHandleList instance.
fb.GetSelectionType()
#
Returns a SelectionType
fb.IsLibraryEnabled()
#
Returns a boolean
value.
fb.IsLibraryInitialised()
#
3.5.1
Returns a boolean
value.
fb.RunContextCommand(command)
#
Arguments | ||
---|---|---|
command | string |
The full path to the command must be supplied. Case is not important. |
Returns true
if a matching command was found, false
otherwise.
Note
This method is for the currently playing file only. See also: IMetadbHandleList RunContextCommand.
fb.RunMainMenuCommand(command)
#
Arguments | ||
---|---|---|
command | string |
The full path to the command must be supplied. Case is not important. |
Returns true
if a matching command was found, false
otherwise.
fb.SetDSPPreset(idx)
#
Arguments | ||
---|---|---|
idx | number |
No return value. See fb.GetDSPPresets.
fb.SetOutputDevice(output_id, device_id)
#
Arguments | ||
---|---|---|
output_id | string |
|
device_id | string |
No return value. See fb.GetOutputDevices.
fb.ShowLibrarySearchUI(query)
#
Arguments | ||
---|---|---|
query | string |
No return value.
Opens the Library>Search
window populated with the query you set.
fb.ShowPictureViewer(path)
#
Arguments | ||
---|---|---|
path | string |
No return value.
fb.TitleFormat(pattern)
#
Arguments | ||
---|---|---|
pattern | string |
Returns an ITitleFormat instance.