diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2008-01-18 19:58:34 +0000 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2008-01-18 19:58:34 +0000 |
commit | df1da084eddfb2f9b2016595649b435be43c15d3 (patch) | |
tree | c28f5b9bf75fb803a722a72949f3b68172dc5a0f /gtk2_ardour/splash.cc | |
parent | 7356c65a2a35c8059d5132df7e9f149617952232 (diff) |
permit OSX native package without JACK; prevent excessive track name lengths from messing up JACK port names; splash screen tweaks for OS X; new region gain control operations ; work on AU plugin GUIs (totally incomplete); don't needlessly create prompters in a barcontroller (create on demand)
git-svn-id: svn://localhost/ardour2/branches/2.0-ongoing@2938 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/splash.cc')
-rw-r--r-- | gtk2_ardour/splash.cc | 44 |
1 files changed, 38 insertions, 6 deletions
diff --git a/gtk2_ardour/splash.cc b/gtk2_ardour/splash.cc index 4da01783c5..79764b4605 100644 --- a/gtk2_ardour/splash.cc +++ b/gtk2_ardour/splash.cc @@ -26,30 +26,62 @@ Splash::Splash () throw failed_constructor(); } - set_size_request (pixbuf->get_width(), pixbuf->get_height()); + darea.set_size_request (pixbuf->get_width(), pixbuf->get_height()); set_type_hint (Gdk::WINDOW_TYPE_HINT_SPLASHSCREEN); set_keep_above (true); set_position (WIN_POS_CENTER); - add_events (Gdk::BUTTON_PRESS_MASK|Gdk::BUTTON_RELEASE_MASK); + darea.add_events (Gdk::BUTTON_PRESS_MASK|Gdk::BUTTON_RELEASE_MASK); + + layout = create_pango_layout (""); + + darea.show (); + darea.signal_expose_event().connect (mem_fun (*this, &Splash::expose)); + + add (darea); +} + +void +Splash::on_realize () +{ + Window::on_realize (); + layout->set_font_description (get_style()->get_font()); } + bool Splash::on_button_release_event (GdkEventButton* ev) { hide (); + return true; } bool -Splash::on_expose_event (GdkEventExpose* ev) +Splash::expose (GdkEventExpose* ev) { - RefPtr<Gdk::Window> window = get_window(); - - Window::on_expose_event (ev); + RefPtr<Gdk::Window> window = darea.get_window(); window->draw_pixbuf (get_style()->get_bg_gc (STATE_NORMAL), pixbuf, ev->area.x, ev->area.y, ev->area.x, ev->area.y, ev->area.width, ev->area.height, Gdk::RGB_DITHER_NONE, 0, 0); + + Glib::RefPtr<Gtk::Style> style = darea.get_style(); + Glib::RefPtr<Gdk::GC> white = style->get_white_gc(); + + window->draw_layout (white, 10, pixbuf->get_height() - 30, layout); + return true; } + +void +Splash::message (const string& msg) +{ + string str ("<b>"); + str += msg; + str += "</b>"; + + layout->set_markup (str); + darea.queue_draw (); + get_window()->process_updates (true); +} |