X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fgtkmm2ext%2Fclick_box.cc;h=63ab3db7ba5c88e1f803245a46f23800354bc1b1;hb=93a64cb4fc1817bc0640e76de6b826d4fbfbd8c0;hp=dc9eb3943302c91e44560c020d73d6ec7acd4204;hpb=b65f8073ba306ac2d85133875746767e7c6b0eb6;p=ardour.git diff --git a/libs/gtkmm2ext/click_box.cc b/libs/gtkmm2ext/click_box.cc index dc9eb39433..63ab3db7ba 100644 --- a/libs/gtkmm2ext/click_box.cc +++ b/libs/gtkmm2ext/click_box.cc @@ -32,8 +32,6 @@ using namespace sigc; ClickBox::ClickBox (Gtk::Adjustment *adjp, const string &name, bool round_to_steps) : AutoSpin (*adjp,0,round_to_steps) { - print_func = default_printer; - print_arg = 0; layout = create_pango_layout (""); twidth = 0; theight = 0; @@ -79,23 +77,16 @@ ClickBox::button_release_handler (GdkEventButton* ev) return true; } -void -ClickBox::default_printer (char buf[32], Gtk::Adjustment &adj, - void *) -{ - sprintf (buf, "%.2f", adj.get_value()); -} - void ClickBox::set_label () { - if (!print_func) { - return; - } - char buf[32]; - print_func (buf, get_adjustment(), print_arg); + bool const h = _printer (buf, get_adjustment()); + if (!h) { + /* the printer didn't handle it, so use a default */ + sprintf (buf, "%.2f", get_adjustment().get_value ()); + } layout->set_text (buf); layout->get_pixel_size (twidth, theight); @@ -122,31 +113,36 @@ ClickBox::on_expose_event (GdkEventExpose *ev) Gtk::DrawingArea::on_expose_event (ev); - if (print_func) { - - Glib::RefPtr style (get_style()); - Glib::RefPtr fg_gc (style->get_fg_gc (Gtk::STATE_NORMAL)); - Glib::RefPtr bg_gc (style->get_bg_gc (Gtk::STATE_NORMAL)); - Glib::RefPtr win (get_window()); - - GdkRectangle base_rect; - GdkRectangle draw_rect; - gint x, y, width, height, depth; - - win->get_geometry (x, y, width, height, depth); - - base_rect.width = width; - base_rect.height = height; - base_rect.x = 0; - base_rect.y = 0; - - gdk_rectangle_intersect (&ev->area, &base_rect, &draw_rect); - win->draw_rectangle (bg_gc, true, draw_rect.x, draw_rect.y, draw_rect.width, draw_rect.height); - - if (twidth && theight) { - win->draw_layout (fg_gc, (width - twidth) / 2, (height - theight) / 2, layout); - } + Glib::RefPtr style (get_style()); + Glib::RefPtr fg_gc (style->get_fg_gc (Gtk::STATE_NORMAL)); + Glib::RefPtr bg_gc (style->get_bg_gc (Gtk::STATE_NORMAL)); + Glib::RefPtr win (get_window()); + + GdkRectangle base_rect; + GdkRectangle draw_rect; + gint x, y, width, height, depth; + + win->get_geometry (x, y, width, height, depth); + + base_rect.width = width; + base_rect.height = height; + base_rect.x = 0; + base_rect.y = 0; + + gdk_rectangle_intersect (&ev->area, &base_rect, &draw_rect); + win->draw_rectangle (bg_gc, true, draw_rect.x, draw_rect.y, draw_rect.width, draw_rect.height); + + if (twidth && theight) { + win->draw_layout (fg_gc, (width - twidth) / 2, (height - theight) / 2, layout); } return true; } + +void +ClickBox::set_printer (sigc::slot p) +{ + _printer = p; + set_label (); +} +