Initial commit
This commit is contained in:
commit
56f7cd1875
105 changed files with 22109 additions and 0 deletions
83
tests/clap/ext/remote-controls.h
Normal file
83
tests/clap/ext/remote-controls.h
Normal file
|
|
@ -0,0 +1,83 @@
|
|||
#pragma once
|
||||
|
||||
#include "../plugin.h"
|
||||
#include "../string-sizes.h"
|
||||
|
||||
// This extension let the plugin provide a structured way of mapping parameters to an hardware
|
||||
// controller.
|
||||
//
|
||||
// This is done by providing a set of remote control pages organized by section.
|
||||
// A page contains up to 8 controls, which references parameters using param_id.
|
||||
//
|
||||
// |`- [section:main]
|
||||
// | `- [name:main] performance controls
|
||||
// |`- [section:osc]
|
||||
// | |`- [name:osc1] osc1 page
|
||||
// | |`- [name:osc2] osc2 page
|
||||
// | |`- [name:osc-sync] osc sync page
|
||||
// | `- [name:osc-noise] osc noise page
|
||||
// |`- [section:filter]
|
||||
// | |`- [name:flt1] filter 1 page
|
||||
// | `- [name:flt2] filter 2 page
|
||||
// |`- [section:env]
|
||||
// | |`- [name:env1] env1 page
|
||||
// | `- [name:env2] env2 page
|
||||
// |`- [section:lfo]
|
||||
// | |`- [name:lfo1] env1 page
|
||||
// | `- [name:lfo2] env2 page
|
||||
// `- etc...
|
||||
//
|
||||
// One possible workflow is to have a set of buttons, which correspond to a section.
|
||||
// Pressing that button once gets you to the first page of the section.
|
||||
// Press it again to cycle through the section's pages.
|
||||
|
||||
static CLAP_CONSTEXPR const char CLAP_EXT_REMOTE_CONTROLS[] = "clap.remote-controls/2";
|
||||
|
||||
// The latest draft is 100% compatible
|
||||
// This compat ID may be removed in 2026.
|
||||
static CLAP_CONSTEXPR const char CLAP_EXT_REMOTE_CONTROLS_COMPAT[] = "clap.remote-controls.draft/2";
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
enum { CLAP_REMOTE_CONTROLS_COUNT = 8 };
|
||||
|
||||
typedef struct clap_remote_controls_page {
|
||||
char section_name[CLAP_NAME_SIZE];
|
||||
clap_id page_id;
|
||||
char page_name[CLAP_NAME_SIZE];
|
||||
clap_id param_ids[CLAP_REMOTE_CONTROLS_COUNT];
|
||||
|
||||
// This is used to separate device pages versus preset pages.
|
||||
// If true, then this page is specific to this preset.
|
||||
bool is_for_preset;
|
||||
} clap_remote_controls_page_t;
|
||||
|
||||
typedef struct clap_plugin_remote_controls {
|
||||
// Returns the number of pages.
|
||||
// [main-thread]
|
||||
uint32_t(CLAP_ABI *count)(const clap_plugin_t *plugin);
|
||||
|
||||
// Get a page by index.
|
||||
// Returns true on success and stores the result into page.
|
||||
// [main-thread]
|
||||
bool(CLAP_ABI *get)(const clap_plugin_t *plugin,
|
||||
uint32_t page_index,
|
||||
clap_remote_controls_page_t *page);
|
||||
} clap_plugin_remote_controls_t;
|
||||
|
||||
typedef struct clap_host_remote_controls {
|
||||
// Informs the host that the remote controls have changed.
|
||||
// [main-thread]
|
||||
void(CLAP_ABI *changed)(const clap_host_t *host);
|
||||
|
||||
// Suggest a page to the host because it corresponds to what the user is currently editing in the
|
||||
// plugin's GUI.
|
||||
// [main-thread]
|
||||
void(CLAP_ABI *suggest_page)(const clap_host_t *host, clap_id page_id);
|
||||
} clap_host_remote_controls_t;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
Loading…
Add table
Add a link
Reference in a new issue