summaryrefslogtreecommitdiff
path: root/gtk2_ardour/big_clock_window.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2015-01-02 08:23:56 -0500
committerPaul Davis <paul@linuxaudiosystems.com>2015-01-02 08:23:56 -0500
commit9ef350cb909e82f855df83b4084b2490810ee49e (patch)
treebaff6d1945e724f4c7d3f7cd1ecf6ac456918b33 /gtk2_ardour/big_clock_window.cc
parent884cc6f90c54c6e2e528973502554ee9405c94a2 (diff)
remember big clock window scaling, or rather, recompute it accurately
Diffstat (limited to 'gtk2_ardour/big_clock_window.cc')
-rw-r--r--gtk2_ardour/big_clock_window.cc20
1 files changed, 8 insertions, 12 deletions
diff --git a/gtk2_ardour/big_clock_window.cc b/gtk2_ardour/big_clock_window.cc
index 173cc77fc0..70bad5c046 100644
--- a/gtk2_ardour/big_clock_window.cc
+++ b/gtk2_ardour/big_clock_window.cc
@@ -36,8 +36,6 @@ using namespace ARDOUR_UI_UTILS;
BigClockWindow::BigClockWindow (AudioClock& c)
: ArdourWindow (_("Big Clock"))
, clock (c)
- , original_height (0)
- , original_width (0)
{
ARDOUR_UI::Clock.connect (sigc::mem_fun (clock, &AudioClock::set));
@@ -47,6 +45,9 @@ BigClockWindow::BigClockWindow (AudioClock& c)
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
@@ -67,21 +68,16 @@ void
BigClockWindow::on_realize ()
{
ArdourWindow::on_realize ();
+ /* (try to) ensure that resizing is possible.
+ */
get_window()->set_decorations (Gdk::DECOR_BORDER|Gdk::DECOR_RESIZEH);
-
- int x, y, d;
- get_window()->get_geometry (x, y, original_width, original_height, d);
}
void
-BigClockWindow::on_size_allocate (Gtk::Allocation& alloc)
+BigClockWindow::clock_size_reallocated (Gtk::Allocation& alloc)
{
- ArdourWindow::on_size_allocate (alloc);
-
- if (original_width) {
- clock.set_scale ((double) alloc.get_width() / original_width,
- (double) alloc.get_height() / original_height);
- }
+ clock.set_scale ((double) alloc.get_width() / default_size.width,
+ (double) alloc.get_height() / default_size.height);
}