X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fbig_clock_window.cc;h=58c63989d8f81eb6776dcf38d96e5a2d2c41cefc;hb=2eae3b5cd19e845a2258fb578548c2b571e46348;hp=c67ae38074f9a8ca71e5787393c6f1682bb976ff;hpb=d7a16f7de648907d5d9156da2f79bd5034f399f9;p=ardour.git diff --git a/gtk2_ardour/big_clock_window.cc b/gtk2_ardour/big_clock_window.cc index c67ae38074..58c63989d8 100644 --- a/gtk2_ardour/big_clock_window.cc +++ b/gtk2_ardour/big_clock_window.cc @@ -21,42 +21,43 @@ #include #include +#include "gtkmm2ext/utils.h" + #include "ardour_ui.h" #include "audio_clock.h" #include "big_clock_window.h" #include "public_editor.h" #include "utils.h" -#include "i18n.h" +#include "pbd/i18n.h" using std::min; using std::string; +using namespace ARDOUR_UI_UTILS; -BigClockWindow::BigClockWindow (AudioClock& c) +BigClockWindow::BigClockWindow (AudioClock& c) : ArdourWindow (_("Big Clock")) , clock (c) - , resize_in_progress (false) - , original_height (0) - , original_width (0) - , original_font_size (0) { - ARDOUR_UI::Clock.connect (sigc::mem_fun (clock, &AudioClock::set)); + ARDOUR_UI::Clock.connect (sigc::bind (sigc::mem_fun (clock, &AudioClock::set), false, 0)); clock.set_corner_radius (0.0); - clock.mode_changed.connect (sigc::mem_fun (*this, &BigClockWindow::reset_aspect_ratio)); set_keep_above (true); set_border_width (0); add (clock); clock.show_all (); + + clock.size_request (default_size); + + clock.signal_size_allocate().connect (sigc::mem_fun (*this, &BigClockWindow::clock_size_reallocated)); } void BigClockWindow::on_unmap () { ArdourWindow::on_unmap (); - - PublicEditor::instance().reset_focus (); + ARDOUR_UI::instance()->reset_focus (this); } bool @@ -68,92 +69,27 @@ BigClockWindow::on_key_press_event (GdkEventKey* ev) void BigClockWindow::on_realize () { - int x, y, w, d, h; - ArdourWindow::on_realize (); + /* (try to) ensure that resizing is possible and the window can be moved (and closed) */ + get_window()->set_decorations (Gdk::DECOR_BORDER | Gdk::DECOR_RESIZEH | Gdk::DECOR_TITLE | Gdk::DECOR_MENU); - get_window()->set_decorations (Gdk::DECOR_BORDER|Gdk::DECOR_RESIZEH); - get_window()->get_geometry (x, y, w, h, d); - - reset_aspect_ratio (); - - original_height = h; - original_width = w; - - Pango::FontDescription fd (clock.get_style()->get_font()); - original_font_size = fd.get_size (); - - if (!fd.get_size_is_absolute ()) { - original_font_size /= PANGO_SCALE; - } -} - -void -BigClockWindow::on_size_allocate (Gtk::Allocation& alloc) -{ - ArdourWindow::on_size_allocate (alloc); - - if (!resize_in_progress) { - Glib::signal_idle().connect (sigc::bind (sigc::mem_fun (*this, &BigClockWindow::text_resizer), 0, 0)); - resize_in_progress = true; - } -} - -void -BigClockWindow::reset_aspect_ratio () -{ - Gtk::Requisition req; - - clock.size_request (req); - - float aspect = req.width/(float)req.height; + /* try to force a fixed aspect ratio so that we don't distort the font */ + float aspect = default_size.width/(float)default_size.height; Gdk::Geometry geom; geom.min_aspect = aspect; geom.max_aspect = aspect; - - set_geometry_hints (clock, geom, Gdk::HINT_ASPECT); + geom.min_width = -1; /* use requisition */ + geom.min_height = -1; /* use requisition */ + + get_window()->set_geometry_hints (geom, Gdk::WindowHints (Gdk::HINT_ASPECT|Gdk::HINT_MIN_SIZE)); } -bool -BigClockWindow::text_resizer (int, int) +void +BigClockWindow::clock_size_reallocated (Gtk::Allocation& alloc) { - resize_in_progress = false; - - Glib::RefPtr win = get_window(); - Pango::FontDescription fd (clock.get_style()->get_font()); - int current_size = fd.get_size (); - int x, y, w, h, d; - - if (!fd.get_size_is_absolute ()) { - current_size /= PANGO_SCALE; - } - - win->get_geometry (x, y, w, h, d); - - double scale = min (((double) w / (double) original_width), - ((double) h / (double) original_height)); - - int size = (int) lrintf (original_font_size * scale); - - if (size != current_size) { - - string family = fd.get_family(); - std::vector buf(family.length()+16); - snprintf (&buf[0], family.length()+16, "%s %d", family.c_str(), size); - - try { - Pango::FontDescription fd (&buf[0]); - Glib::RefPtr rcstyle = clock.get_modifier_style (); - rcstyle->set_font (fd); - clock.modify_style (rcstyle); - } - - catch (...) { - /* oh well, do nothing */ - } - } - - return false; + clock.set_scale ((double) alloc.get_width() / default_size.width, + (double) alloc.get_height() / default_size.height); } +