aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2012-07-29 23:00:12 +0000
committerDavid Robillard <d@drobilla.net>2012-07-29 23:00:12 +0000
commit35e38f95feed56dab2e5b1b10a7939ab640e3163 (patch)
treefb811361aa8dc2a586ad9e56ee02571a4608b441 /src
parent8bc6d3f84b425120d43ca32eb576f77ddea5bb55 (diff)
downloadjalv-35e38f95feed56dab2e5b1b10a7939ab640e3163.tar.gz
jalv-35e38f95feed56dab2e5b1b10a7939ab640e3163.tar.bz2
jalv-35e38f95feed56dab2e5b1b10a7939ab640e3163.zip
Add Gtk3 UI.
git-svn-id: http://svn.drobilla.net/lad/trunk/jalv@4572 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src')
-rw-r--r--src/jalv_gtk.c (renamed from src/jalv_gtk2.c)53
1 files changed, 47 insertions, 6 deletions
diff --git a/src/jalv_gtk2.c b/src/jalv_gtk.c
index 9ff2013..f385efa 100644
--- a/src/jalv_gtk2.c
+++ b/src/jalv_gtk.c
@@ -22,6 +22,40 @@
#include "jalv_internal.h"
+static GtkWidget*
+new_box(gboolean horizontal, gint spacing)
+{
+ #if GTK_MAJOR_VERSION == 3
+ return gtk_box_new(
+ horizontal ? GTK_ORIENTATION_HORIZONTAL : GTK_ORIENTATION_VERTICAL,
+ spacing);
+ #else
+ return (horizontal
+ ? gtk_hbox_new(FALSE, spacing)
+ : gtk_vbox_new(FALSE, spacing));
+ #endif
+}
+
+static GtkWidget*
+new_hscale(gdouble min, gdouble max, gdouble step)
+{
+ #if GTK_MAJOR_VERSION == 3
+ return gtk_scale_new_with_range(GTK_ORIENTATION_HORIZONTAL, min, max, step);
+ #else
+ return gtk_hscale_new_with_range(min, max, step);
+ #endif
+}
+
+static void
+size_request(GtkWidget* widget, GtkRequisition* req)
+{
+ #if GTK_MAJOR_VERSION == 3
+ gtk_widget_get_preferred_size(widget, NULL, req);
+ #else
+ gtk_widget_size_request(widget, req);
+ #endif
+}
+
static void
on_window_destroy(GtkWidget* widget,
gpointer data)
@@ -63,8 +97,15 @@ jalv_init(int* argc, char*** argv, JalvOptions* opts)
LilvNode*
jalv_native_ui_type(Jalv* jalv)
{
+#if GTK_MAJOR_VERSION == 2
return lilv_new_uri(jalv->world,
"http://lv2plug.in/ns/extensions/ui#GtkUI");
+#elif GTK_MAJOR_VERSION == 3
+ return lilv_new_uri(jalv->world,
+ "http://lv2plug.in/ns/extensions/ui#Gtk3UI");
+#else
+ return NULL;
+#endif
}
static void
@@ -135,7 +176,7 @@ on_save_preset_activate(GtkWidget* widget, void* ptr)
free(dot_lv2);
GtkWidget* content = gtk_dialog_get_content_area(GTK_DIALOG(dialog));
- GtkBox* box = GTK_BOX(gtk_hbox_new(FALSE, 8));
+ GtkBox* box = GTK_BOX(new_box(true, 8));
GtkWidget* uri_label = gtk_label_new("URI (Optional):");
GtkWidget* uri_entry = gtk_entry_new();
@@ -342,7 +383,7 @@ make_log_slider(struct Port* port, GHashTable* points,
float lmin = logf(min);
float lmax = logf(max);
float ldft = logf(deft);
- GtkWidget* slider = gtk_hscale_new_with_range(lmin, lmax, 0.001);
+ GtkWidget* slider = new_hscale(lmin, lmax, 0.001);
gtk_scale_set_digits(GTK_SCALE(slider), 6);
gtk_range_set_value(GTK_RANGE(slider), ldft);
g_signal_connect(G_OBJECT(slider),
@@ -358,7 +399,7 @@ make_slider(struct Port* port, GHashTable* points,
bool is_int, float min, float max, float deft)
{
const double step = is_int ? 1.0 : ((max - min) / 100.0);
- GtkWidget* slider = gtk_hscale_new_with_range(min, max, step);
+ GtkWidget* slider = new_hscale(min, max, step);
gtk_range_set_value(GTK_RANGE(slider), deft);
if (points) {
g_signal_connect(G_OBJECT(slider),
@@ -516,7 +557,7 @@ jalv_open_ui(Jalv* jalv,
gtk_window_set_title(GTK_WINDOW(window), lilv_node_as_string(name));
lilv_node_free(name);
- GtkWidget* vbox = gtk_vbox_new(FALSE, 0);
+ GtkWidget* vbox = new_box(false, 0);
GtkWidget* menu_bar = gtk_menu_bar_new();
GtkWidget* file = gtk_menu_item_new_with_mnemonic("_File");
GtkWidget* file_menu = gtk_menu_new();
@@ -576,8 +617,8 @@ jalv_open_ui(Jalv* jalv,
gtk_widget_show_all(vbox);
GtkRequisition controls_size, box_size;
- gtk_widget_size_request(GTK_WIDGET(controls), &controls_size);
- gtk_widget_size_request(GTK_WIDGET(vbox), &box_size);
+ size_request(GTK_WIDGET(controls), &controls_size);
+ size_request(GTK_WIDGET(vbox), &box_size);
gtk_window_set_default_size(
GTK_WINDOW(window),