Buffer size widget tweaks
This commit is contained in:
parent
e2236e8c36
commit
2722a01ab0
|
@ -301,6 +301,7 @@
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkComboBoxEntry" id="buffer_size_combo">
|
<widget class="GtkComboBoxEntry" id="buffer_size_combo">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
<property name="sensitive">False</property>
|
||||||
<property name="tooltip" translatable="yes">Jack latency</property>
|
<property name="tooltip" translatable="yes">Jack latency</property>
|
||||||
<property name="border_width">1</property>
|
<property name="border_width">1</property>
|
||||||
<property name="items" translatable="yes">32 frames
|
<property name="items" translatable="yes">32 frames
|
||||||
|
@ -312,7 +313,9 @@
|
||||||
2048 frames
|
2048 frames
|
||||||
4096 frames</property>
|
4096 frames</property>
|
||||||
<child internal-child="entry">
|
<child internal-child="entry">
|
||||||
<widget class="GtkEntry" id="comboboxentry-entry1">
|
<widget class="GtkEntry" id="comboboxentry">
|
||||||
|
<property name="sensitive">True</property>
|
||||||
|
<property name="editable">False</property>
|
||||||
</widget>
|
</widget>
|
||||||
</child>
|
</child>
|
||||||
</widget>
|
</widget>
|
||||||
|
@ -364,8 +367,9 @@
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkToolButton" id="clear_load_but">
|
<widget class="GtkToolButton" id="clear_load_button">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
<property name="sensitive">False</property>
|
||||||
<property name="tooltip" translatable="yes">Clear the dropout indicator</property>
|
<property name="tooltip" translatable="yes">Clear the dropout indicator</property>
|
||||||
<property name="stock_id">gtk-clear</property>
|
<property name="stock_id">gtk-clear</property>
|
||||||
</widget>
|
</widget>
|
||||||
|
@ -381,13 +385,13 @@
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="yscale">0</property>
|
<property name="yscale">0</property>
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkProgressBar" id="main_xrun_progress">
|
<widget class="GtkProgressBar" id="xrun_progress_bar">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="tooltip" translatable="yes">Drouput (XRun) Indicator
|
<property name="tooltip" translatable="yes">Drouput (XRun) Indicator
|
||||||
|
|
||||||
The bar represents the percentage of available time used for audio processing (i.e. the DSP load). If the bar reaches 100%, a dropout will occur.</property>
|
The bar represents the percentage of available time used for audio processing (i.e. the DSP load). If the bar reaches 100%, a dropout will occur.</property>
|
||||||
<property name="pulse_step">0.10000000149</property>
|
<property name="pulse_step">0.10000000149</property>
|
||||||
<property name="text" translatable="yes">0 Dropouts</property>
|
<property name="text" translatable="yes">? Dropouts</property>
|
||||||
</widget>
|
</widget>
|
||||||
</child>
|
</child>
|
||||||
</widget>
|
</widget>
|
||||||
|
|
129
gui/main.c
129
gui/main.c
|
@ -26,6 +26,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
#include "glade.h"
|
#include "glade.h"
|
||||||
#include "canvas.h"
|
#include "canvas.h"
|
||||||
#include "graph_canvas.h"
|
#include "graph_canvas.h"
|
||||||
|
@ -37,6 +40,14 @@
|
||||||
#include "graph_view.h"
|
#include "graph_view.h"
|
||||||
#include "../catdup.h"
|
#include "../catdup.h"
|
||||||
|
|
||||||
|
GtkWidget * g_main_win;
|
||||||
|
GtkWidget * g_clear_load_button;
|
||||||
|
GtkWidget * g_xrun_progress_bar;
|
||||||
|
GtkWidget * g_buffer_size_combo;
|
||||||
|
|
||||||
|
graph_view_handle g_jack_view = NULL;
|
||||||
|
graph_view_handle g_studio_view = NULL;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
static void
|
static void
|
||||||
gtkmm_get_ink_pixel_size (Glib::RefPtr<Pango::Layout> layout,
|
gtkmm_get_ink_pixel_size (Glib::RefPtr<Pango::Layout> layout,
|
||||||
|
@ -64,21 +75,54 @@ gtkmm_set_width_for_given_text (Gtk::Widget &w, const gchar *text,
|
||||||
w.set_size_request(width + hpadding, old_height);//height + vpadding);
|
w.set_size_request(width + hpadding, old_height);//height + vpadding);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
#endif
|
||||||
update_toolbar()
|
|
||||||
|
static void set_buffer_size_combo_width(void)
|
||||||
{
|
{
|
||||||
bool started;
|
//gtkmm_set_width_for_given_text(*_buffer_size_combo, "4096 frames", 40);
|
||||||
|
}
|
||||||
|
|
||||||
started = _jack->is_started();
|
static void buffer_size_clear()
|
||||||
|
{
|
||||||
|
gtk_entry_set_text(GTK_ENTRY(get_glade_widget("comboboxentry")), "");
|
||||||
|
}
|
||||||
|
|
||||||
_buffer_size_combo->set_sensitive(started);
|
static void buffer_size_set(uint32_t size)
|
||||||
|
{
|
||||||
|
gtk_combo_box_set_active(GTK_COMBO_BOX(g_buffer_size_combo), (int)log2f(size) - 5);
|
||||||
|
}
|
||||||
|
|
||||||
if (started)
|
#if 0
|
||||||
|
|
||||||
|
void
|
||||||
|
buffer_size_changed()
|
||||||
|
{
|
||||||
|
const int selected = _buffer_size_combo->get_active_row_number();
|
||||||
|
|
||||||
|
if (selected == -1)
|
||||||
{
|
{
|
||||||
_buffer_size_combo->set_active((int)log2f(_jack->buffer_size()) - 5);
|
update_toolbar();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
uint32_t buffer_size = 1 << (selected + 5);
|
||||||
|
|
||||||
|
// this check is temporal workaround for jack bug
|
||||||
|
// we skip setting buffer size if it same as acutal one
|
||||||
|
// proper place for such check is in jack
|
||||||
|
if (_jack->buffer_size() != buffer_size)
|
||||||
|
{
|
||||||
|
if (!_jack->set_buffer_size(buffer_size))
|
||||||
|
{
|
||||||
|
update_toolbar(); // reset combo box to actual value
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 0
|
||||||
void
|
void
|
||||||
update_load()
|
update_load()
|
||||||
{
|
{
|
||||||
|
@ -111,54 +155,8 @@ clear_load()
|
||||||
_jack->reset_xruns();
|
_jack->reset_xruns();
|
||||||
_max_dsp_load = 0.0;
|
_max_dsp_load = 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
jack_status_changed(
|
|
||||||
bool started)
|
|
||||||
{
|
|
||||||
update_toolbar();
|
|
||||||
|
|
||||||
_menu_jack_start->set_sensitive(!started);
|
|
||||||
_menu_jack_stop->set_sensitive(started);
|
|
||||||
_clear_load_but->set_sensitive(started);
|
|
||||||
if (!started)
|
|
||||||
{
|
|
||||||
_main_xrun_progress->set_fraction(0.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
buffer_size_changed()
|
|
||||||
{
|
|
||||||
const int selected = _buffer_size_combo->get_active_row_number();
|
|
||||||
|
|
||||||
if (selected == -1)
|
|
||||||
{
|
|
||||||
update_toolbar();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
uint32_t buffer_size = 1 << (selected+5);
|
|
||||||
|
|
||||||
// this check is temporal workaround for jack bug
|
|
||||||
// we skip setting buffer size if it same as acutal one
|
|
||||||
// proper place for such check is in jack
|
|
||||||
if (_jack->buffer_size() != buffer_size)
|
|
||||||
{
|
|
||||||
if (!_jack->set_buffer_size(buffer_size))
|
|
||||||
{
|
|
||||||
update_toolbar(); // reset combo box to actual value
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GtkWidget * g_main_win;
|
|
||||||
graph_view_handle g_jack_view = NULL;
|
|
||||||
graph_view_handle g_studio_view = NULL;
|
|
||||||
|
|
||||||
void control_proxy_on_studio_appeared(void)
|
void control_proxy_on_studio_appeared(void)
|
||||||
{
|
{
|
||||||
if (!create_view("Studio", SERVICE_NAME, STUDIO_OBJECT_PATH, false, &g_studio_view))
|
if (!create_view("Studio", SERVICE_NAME, STUDIO_OBJECT_PATH, false, &g_studio_view))
|
||||||
|
@ -179,12 +177,32 @@ void control_proxy_on_studio_disappeared(void)
|
||||||
|
|
||||||
void jack_started(void)
|
void jack_started(void)
|
||||||
{
|
{
|
||||||
|
uint32_t size;
|
||||||
|
|
||||||
lash_info("JACK started");
|
lash_info("JACK started");
|
||||||
|
|
||||||
|
gtk_widget_set_sensitive(g_buffer_size_combo, true);
|
||||||
|
|
||||||
|
if (jack_proxy_get_buffer_size(&size))
|
||||||
|
{
|
||||||
|
buffer_size_set(size);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lash_error("jack_proxy_get_buffer_size() failed.");
|
||||||
|
}
|
||||||
|
|
||||||
|
gtk_widget_set_sensitive(g_clear_load_button, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void jack_stopped(void)
|
void jack_stopped(void)
|
||||||
{
|
{
|
||||||
lash_info("JACK stopped");
|
lash_info("JACK stopped");
|
||||||
|
|
||||||
|
gtk_widget_set_sensitive(g_buffer_size_combo, false);
|
||||||
|
buffer_size_clear();
|
||||||
|
gtk_widget_set_sensitive(g_clear_load_button, false);
|
||||||
|
gtk_progress_bar_set_fraction(GTK_PROGRESS_BAR(g_xrun_progress_bar), 0.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void jack_appeared(void)
|
void jack_appeared(void)
|
||||||
|
@ -234,6 +252,9 @@ int main(int argc, char** argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
g_main_win = get_glade_widget("main_win");
|
g_main_win = get_glade_widget("main_win");
|
||||||
|
g_clear_load_button = get_glade_widget("clear_load_button");
|
||||||
|
g_xrun_progress_bar = get_glade_widget("xrun_progress_bar");
|
||||||
|
g_buffer_size_combo = get_glade_widget("buffer_size_combo");
|
||||||
|
|
||||||
world_tree_init();
|
world_tree_init();
|
||||||
view_init();
|
view_init();
|
||||||
|
@ -250,7 +271,7 @@ int main(int argc, char** argv)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
//gtkmm_set_width_for_given_text(*_buffer_size_combo, "4096 frames", 40);
|
set_buffer_size_combo_width();
|
||||||
|
|
||||||
g_signal_connect(G_OBJECT(g_main_win), "destroy", G_CALLBACK(gtk_main_quit), NULL);
|
g_signal_connect(G_OBJECT(g_main_win), "destroy", G_CALLBACK(gtk_main_quit), NULL);
|
||||||
g_signal_connect(G_OBJECT(get_glade_widget("menu_file_quit")), "activate", G_CALLBACK(gtk_main_quit), NULL);
|
g_signal_connect(G_OBJECT(get_glade_widget("menu_file_quit")), "activate", G_CALLBACK(gtk_main_quit), NULL);
|
||||||
|
|
Loading…
Reference in New Issue