2004-07-21 11:32:09 +00:00
|
|
|
$Id$
|
|
|
|
|
2004-08-31 17:14:03 +00:00
|
|
|
* existing gstreamer interfaces
|
|
|
|
./gstreamer/gst/gsttaginterface.c
|
|
|
|
./gstreamer/gst/gstinterface.c
|
|
|
|
./gstreamer/gst/gsturi.c
|
|
|
|
./gst-plugins/gst-libs/gst/propertyprobe/propertyprobe.c
|
|
|
|
./gst-plugins/gst-libs/gst/mixer/mixer.c
|
|
|
|
./gst-plugins/gst-libs/gst/tuner/tuner.c
|
|
|
|
./gst-plugins/gst-libs/gst/xoverlay/xoverlay.c
|
|
|
|
./gst-plugins/gst-libs/gst/colorbalance/colorbalance.c
|
|
|
|
./gst-plugins/gst-libs/gst/navigation/navigation.c
|
2004-07-21 11:32:09 +00:00
|
|
|
* new general interfaces
|
|
|
|
* GST_TYPE_PRESET_MANAGER
|
|
|
|
- add preset managment
|
|
|
|
- API:
|
|
|
|
GList *get_presets();
|
|
|
|
void activate_preset_by_index(glong index);
|
|
|
|
void activate_preset_by_name(const gchar *name);
|
|
|
|
void add_current(const gchar *name);
|
|
|
|
void remove_preset_by_index(glong index);
|
|
|
|
void remove_preset_by_name(const gchar *name);
|
|
|
|
- features
|
|
|
|
- there should always be a default preset
|
|
|
|
- questions
|
|
|
|
- were and how do we store the presets?
|
|
|
|
|
|
|
|
* GST_TYPE_UI_HINT
|
|
|
|
- add hints to generate 'good' looking interfaces to elements
|
|
|
|
- API:
|
2004-07-21 15:48:05 +00:00
|
|
|
GList *get_group_list();
|
2004-07-26 16:05:18 +00:00
|
|
|
struct ui_hint_group {
|
|
|
|
gchar *label;
|
|
|
|
gachr *role;
|
|
|
|
GList *entries;
|
|
|
|
}
|
|
|
|
struct ui_hint_group_entry {
|
|
|
|
enum UiHintGroupEntryType type={PARAM,DPARAM};
|
|
|
|
gchar *name;
|
|
|
|
}
|
|
|
|
roles {
|
|
|
|
/* graphics */
|
|
|
|
"color_selection/rgb",
|
|
|
|
"color_selection/hsv",
|
|
|
|
"aspect_ratio",
|
|
|
|
/* audio */
|
|
|
|
"envelope/adsr",
|
|
|
|
}
|
2004-07-21 11:32:09 +00:00
|
|
|
- features
|
2004-07-26 16:05:18 +00:00
|
|
|
- grouping of parameters, each group has:
|
|
|
|
- a label: giving a title to the group
|
|
|
|
- a role:
|
|
|
|
- this can give the UI a hint about the purpose of the controls
|
|
|
|
- this only makes sense, if we dont make this a thousand templates
|
|
|
|
- a list of dparams or properties
|
2004-07-21 15:38:55 +00:00
|
|
|
- question
|
|
|
|
- should this be aware of instruments (voice-groups)
|
2004-07-26 16:05:18 +00:00
|
|
|
- no, instruments should auto-generate those
|
2004-07-21 11:32:09 +00:00
|
|
|
|
|
|
|
* new interfaces for audio applications
|
|
|
|
* GST_TYPE_MUSIC_GENERATOR
|
2004-07-21 15:38:55 +00:00
|
|
|
- add hints so that application can use a element as an instrument
|
2004-07-21 11:32:09 +00:00
|
|
|
- API:
|
2004-07-21 15:48:05 +00:00
|
|
|
// param types
|
2004-07-21 11:32:09 +00:00
|
|
|
DParam *get_note_dparam();
|
2004-07-21 15:38:55 +00:00
|
|
|
GList *get_trigger_dparams();
|
2004-07-21 15:48:05 +00:00
|
|
|
// -- or
|
|
|
|
DParamType get_dparam_type(DParam *);
|
|
|
|
dparamtype = { NOTE, TRIGGER, OTHER }
|
|
|
|
// voices
|
2004-07-21 15:38:55 +00:00
|
|
|
char *get_number_of_voices_property();
|
|
|
|
GList *get_global_param_names();
|
|
|
|
GList *get_voice_param_names();
|
|
|
|
- features
|
|
|
|
- find out which params to use to play notes/trigger sounds
|
|
|
|
- these params will not appear in a control-ui
|
|
|
|
- notes involve a key to frequency translation
|
|
|
|
- find out if the element has a number_of_voices property
|
|
|
|
- if yes, we can find out about the max by looking at the gparamspec
|
|
|
|
- setting the property, adds/removes voices
|
|
|
|
- if the element supports it, it needs to:
|
|
|
|
- register voice-dparams as e.g. note_XXX, where XXX is the voice-number
|
|
|
|
- run the voice-loop in the chain/loop function
|
|
|
|
each voice processes the same input, if at all
|
|
|
|
the outputs of all voices are mixed together
|
|
|
|
|