change the way the audio clock cursor is drawn (somewhat of an experiment but it...
[ardour.git] / gtk2_ardour / audio_clock.cc
index b64e54e95e6413d1f7120adac40de3c98ac31f59..8de39d58f1d5100ffe4c52ebd21c25e6a51f1470 100644 (file)
 #include "ardour/tempo.h"
 #include "ardour/types.h"
 
-#include "ardour_ui.h"
 #include "audio_clock.h"
-#include "global_signals.h"
 #include "utils.h"
 #include "keyboard.h"
 #include "gui_thread.h"
+#include "ui_config.h"
 #include "i18n.h"
 
 using namespace ARDOUR;
@@ -121,8 +120,8 @@ AudioClock::AudioClock (const string& clock_name, bool transient, const string&
                clocks.push_back (this);
        }
 
-       ColorsChanged.connect (sigc::mem_fun (*this, &AudioClock::set_colors));
-       DPIReset.connect (sigc::mem_fun (*this, &AudioClock::dpi_reset));
+       UIConfiguration::instance().ColorsChanged.connect (sigc::mem_fun (*this, &AudioClock::set_colors));
+       UIConfiguration::instance().DPIReset.connect (sigc::mem_fun (*this, &AudioClock::dpi_reset));
 }
 
 AudioClock::~AudioClock ()
@@ -198,6 +197,7 @@ AudioClock::set_font (Pango::FontDescription font)
 
        tmp->set_text ("8");
        tmp->get_pixel_size (em_width, ignore_height);
+       
 
        /* force redraw of markup with new font-size */
        set (last_when, true);
@@ -221,15 +221,15 @@ AudioClock::set_colors ()
        uint32_t cursor_color;
 
        if (active_state()) {
-               bg_color = ARDOUR_UI::config()->color (string_compose ("%1 active: background", get_name()));
-               text_color = ARDOUR_UI::config()->color (string_compose ("%1 active: text", get_name()));
-               editing_color = ARDOUR_UI::config()->color (string_compose ("%1 active: edited text", get_name()));
-               cursor_color = ARDOUR_UI::config()->color (string_compose ("%1 active: cursor", get_name()));
+               bg_color = UIConfiguration::instance().color (string_compose ("%1 active: background", get_name()));
+               text_color = UIConfiguration::instance().color (string_compose ("%1 active: text", get_name()));
+               editing_color = UIConfiguration::instance().color (string_compose ("%1 active: edited text", get_name()));
+               cursor_color = UIConfiguration::instance().color (string_compose ("%1 active: cursor", get_name()));
        } else {
-               bg_color = ARDOUR_UI::config()->color (string_compose ("%1: background", get_name()));
-               text_color = ARDOUR_UI::config()->color (string_compose ("%1: text", get_name()));
-               editing_color = ARDOUR_UI::config()->color (string_compose ("%1: edited text", get_name()));
-               cursor_color = ARDOUR_UI::config()->color (string_compose ("%1: cursor", get_name()));
+               bg_color = UIConfiguration::instance().color (string_compose ("%1: background", get_name()));
+               text_color = UIConfiguration::instance().color (string_compose ("%1: text", get_name()));
+               editing_color = UIConfiguration::instance().color (string_compose ("%1: edited text", get_name()));
+               cursor_color = UIConfiguration::instance().color (string_compose ("%1: cursor", get_name()));
        }
 
        /* store for bg and cursor in render() */
@@ -313,13 +313,17 @@ AudioClock::render (cairo_t* cr, cairo_rectangle_t*)
        double lw = layout_width * xscale;
        double lh = layout_height * yscale;
 
-       cairo_move_to (cr, (get_width() - lw) / 2.0, (upper_height - lh) / 2.0);
+       if (lw >= get_width()) {
+               cairo_move_to (cr, 0.0, (upper_height - lh) / 2.0);
+       } else {
+               cairo_move_to (cr, (get_width() - lw) / 2.0, (upper_height - lh) / 2.0);
+       }
 
        if (xscale != 1.0 || yscale != 1.0) {
                cairo_save (cr);
                cairo_scale (cr, xscale, yscale);
        }
-       
+
        pango_cairo_show_layout (cr, _layout->gobj());
 
        if (xscale != 1.0 || yscale != 1.0) {
@@ -402,42 +406,44 @@ AudioClock::render (cairo_t* cr, cairo_rectangle_t*)
        }
 
        if (editing) {
-               if (!insert_map.empty()) {
+               Pango::Rectangle cursor;
 
-                       int xcenter = (get_width() - layout_width) /2;
+               if (!insert_map.empty()) {
 
                        if (input_string.length() < insert_map.size()) {
-                               Pango::Rectangle cursor;
 
-                               if (input_string.empty()) {
-                                       /* nothing entered yet, put cursor at the end
-                                          of string
-                                       */
-                                       cursor = _layout->get_cursor_strong_pos (edit_string.length() - 1);
-                               } else {
-                                       cursor = _layout->get_cursor_strong_pos (insert_map[input_string.length()]);
-                               }
+                               cursor = _layout->get_cursor_strong_pos (edit_string.length() - 1);
 
                                cairo_set_source_rgba (cr, cursor_r, cursor_g, cursor_b, cursor_a);
+
                                cairo_rectangle (cr,
-                                                min (get_width() - 2.0,
-                                                     (double) xcenter + cursor.get_x()/PANGO_SCALE + em_width),
-                                                (upper_height - layout_height)/2.0,
-                                                2.0, cursor.get_height()/PANGO_SCALE);
-                               cairo_fill (cr);
+                                                cursor.get_x()/PANGO_SCALE,
+                                                (upper_height - layout_height)/2.0,
+                                                em_width,
+                                                cursor.get_height()/PANGO_SCALE);
+                               cairo_stroke (cr);
+
                        } else {
                                /* we've entered all possible digits, no cursor */
                        }
 
                } else {
-                       if (input_string.empty()) {
-                               cairo_set_source_rgba (cr, cursor_r, cursor_g, cursor_b, cursor_a);
+                       cairo_set_source_rgba (cr, cursor_r, cursor_g, cursor_b, cursor_a);
+
+                       if (edit_string.empty()) {
                                cairo_rectangle (cr,
-                                                (get_width()/2.0),
-                                                (upper_height - layout_height)/2.0,
-                                                2.0, upper_height);
-                               cairo_fill (cr);
+                                                get_width() - em_width,
+                                                (upper_height - layout_height)/2.0,
+                                                em_width, upper_height);
+                       } else {
+                               cursor = _layout->get_cursor_strong_pos (edit_string.length() - 1);
+                               cairo_rectangle (cr,
+                                                cursor.get_x()/PANGO_SCALE,
+                                                (upper_height - layout_height)/2.0,
+                                                em_width, upper_height);
                        }
+                               
+                       cairo_stroke (cr);
                }
        }
 }
@@ -478,8 +484,19 @@ AudioClock::set_clock_dimensions (Gtk::Requisition& req)
                tmp->set_text (" 88:88:88,88 ");
        tmp->get_pixel_size (req.width, req.height);
 
+
        layout_height = req.height;
        layout_width = req.width;
+
+       /* get the figure width for the font. This doesn't have to super
+        * accurate since we only use it to measure the (roughly 1 character)
+        * offset from the position Pango tells us for the "cursor"
+        */
+
+       int ignore_height;
+
+       tmp->set_text ("8");
+       tmp->get_pixel_size (em_width, ignore_height);
 }
 
 void
@@ -1420,7 +1437,10 @@ AudioClock::on_key_press_event (GdkEventKey* ev)
                goto use_input_string;
 
        default:
-               return false;
+               /* do not allow other keys to passthru to the rest of the GUI
+                  when editing.
+               */
+               return true;
        }
 
        if (!insert_map.empty() && (input_string.length() >= insert_map.size())) {