diff options
author | David Robillard <d@drobilla.net> | 2011-10-20 04:11:24 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-10-20 04:11:24 +0000 |
commit | c9321a790de52835588989ac6c032a44c5eed668 (patch) | |
tree | f938a95beca8f64fb2f0c8ce5166f547337b8bbc /src | |
parent | c059e981b4d563edfb19a73e48b79efab34eee86 (diff) | |
download | jalv-c9321a790de52835588989ac6c032a44c5eed668.tar.gz jalv-c9321a790de52835588989ac6c032a44c5eed668.tar.bz2 jalv-c9321a790de52835588989ac6c032a44c5eed668.zip |
Support UI resize extension.
git-svn-id: http://svn.drobilla.net/lad/trunk/jalv@3552 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src')
-rw-r--r-- | src/jalv.c | 27 | ||||
-rw-r--r-- | src/jalv_console.c | 6 | ||||
-rw-r--r-- | src/jalv_gtk2.c | 13 | ||||
-rw-r--r-- | src/jalv_internal.h | 7 | ||||
-rw-r--r-- | src/jalv_qt4.cpp | 13 |
5 files changed, 66 insertions, 0 deletions
@@ -34,6 +34,9 @@ #include "lv2/lv2plug.in/ns/ext/event/event-helpers.h" #include "lv2/lv2plug.in/ns/ext/uri-map/uri-map.h" +#ifdef HAVE_LV2_UI_RESIZE +# include "lv2/lv2plug.in/ns/ext/ui-resize/ui-resize.h" +#endif #include "lilv/lilv.h" @@ -67,9 +70,27 @@ static LV2_URI_Map_Feature uri_map = { NULL, &uri_to_id }; static const LV2_Feature uri_map_feature = { NS_EXT "uri-map", &uri_map }; static LV2_Feature instance_feature = { NS_EXT "instance-access", NULL }; +#ifdef HAVE_LV2_UI_RESIZE +static int +lv2_ui_resize(LV2_UI_Resize_Feature_Data data, int width, int height) +{ + Jalv* jalv = (Jalv*)data; + jalv->ui_width = width; + jalv->ui_height = height; + return jalv_ui_resize(jalv, width, height); +} + +LV2_UI_Resize_Feature ui_resize = { NULL, &lv2_ui_resize }; +static const LV2_Feature ui_resize_feature = { NS_EXT "ui-resize#UIResize", &ui_resize }; + +const LV2_Feature* features[4] = { + &uri_map_feature, &instance_feature, &ui_resize_feature +}; +#else const LV2_Feature* features[3] = { &uri_map_feature, &instance_feature, NULL }; +#endif /** Abort and exit on error */ static void @@ -431,6 +452,12 @@ main(int argc, char** argv) "http://lv2plug.in/ns/ext/event", "http://lv2plug.in/ns/ext/midi#MidiEvent"); +#ifdef HAVE_LV2_UI_RESIZE + ui_resize.data = &host; + host.ui_width = -1; + host.ui_height = -1; +#endif + sem_init(&exit_sem, 0, 0); host.done = &exit_sem; diff --git a/src/jalv_console.c b/src/jalv_console.c index 6c0addd..29ac146 100644 --- a/src/jalv_console.c +++ b/src/jalv_console.c @@ -36,6 +36,12 @@ print_usage(const char* name, bool error) } int +jalv_ui_resize(Jalv* jalv, int width, int height) +{ + return 0; +} + +int jalv_init(int* argc, char*** argv, JalvOptions* opts) { int a = 1; diff --git a/src/jalv_gtk2.c b/src/jalv_gtk2.c index d1a4a00..fae3f6a 100644 --- a/src/jalv_gtk2.c +++ b/src/jalv_gtk2.c @@ -86,6 +86,17 @@ on_quit_activate(GtkWidget* widget, gtk_widget_destroy(window); } +int +jalv_ui_resize(Jalv* jalv, int width, int height) +{ + if (jalv->ui_instance) { + GtkWidget* widget = (GtkWidget*)suil_instance_get_widget(jalv->ui_instance); + if (widget) { + gtk_widget_set_size_request(GTK_WIDGET(widget), width, height); + } + } + return 0; +} int jalv_open_ui(Jalv* jalv, @@ -130,6 +141,8 @@ jalv_open_ui(Jalv* jalv, g_timeout_add(1000 / JALV_UI_UPDATE_HZ, (GSourceFunc)jalv_emit_ui_events, jalv); + + jalv_ui_resize(jalv, jalv->ui_width, jalv->ui_height); } else { GtkWidget* button = gtk_button_new_with_label("Close"); diff --git a/src/jalv_internal.h b/src/jalv_internal.h index 9a36f9a..9b2946c 100644 --- a/src/jalv_internal.h +++ b/src/jalv_internal.h @@ -75,6 +75,10 @@ typedef struct { JalvOptions opts; /**< Command-line options */ const char* prog_name; /**< Program name (argv[0]) */ LilvWorld* world; /**< Lilv World */ +#ifdef HAVE_LV2_UI_RESIZE + int ui_width; /**< Requested UI width */ + int ui_height; /**< Requested UI height */ +#endif SerdReader* reader; /**< RDF reader (for persistence) */ SerdWriter* writer; /**< RDF writer (for persistence) */ struct Property* props; /**< Restored state properties */ @@ -127,6 +131,9 @@ jalv_open_ui(Jalv* jalv, bool jalv_emit_ui_events(Jalv* jalv); +int +jalv_ui_resize(Jalv* jalv, int width, int height); + void jalv_save(Jalv* jalv, const char* dir); diff --git a/src/jalv_qt4.cpp b/src/jalv_qt4.cpp index 7673165..a765770 100644 --- a/src/jalv_qt4.cpp +++ b/src/jalv_qt4.cpp @@ -39,6 +39,18 @@ jalv_native_ui_type(Jalv* jalv) "http://lv2plug.in/ns/extensions/ui#Qt4UI"); } +int +jalv_ui_resize(Jalv* jalv, int width, int height) +{ + if (jalv->ui_instance && width > 0 && height > 0) { + QWidget* widget = (QWidget*)suil_instance_get_widget(jalv->ui_instance); + if (widget) { + widget->resize(width, height); + } + } + return 0; +} + class Timer : public QTimer { public: Timer(Jalv* j) : jalv(j) {} @@ -58,6 +70,7 @@ jalv_open_ui(Jalv* jalv, if (instance) { QWidget* widget = (QWidget*)suil_instance_get_widget(instance); widget->show(); + jalv_ui_resize(jalv, jalv->ui_width, jalv->ui_height); } else { QPushButton* button = new QPushButton("Close"); button->show(); |