provide the ability to enable + disable tooltips
[ardour.git] / libs / gtkmm2ext / gtkmm2ext / utils.h
index c92d91ae5849126b22004cc1a01e61e5818ae9b9..1b0a9f57254efafd056bdefddf9d89700892e740 100644 (file)
@@ -47,6 +47,10 @@ namespace Gtk {
 namespace Gtkmm2ext {
        void init ();
 
+       std::string fit_to_pixels (const std::string&, int pixel_width, Pango::FontDescription& font, int& actual_width, bool with_ellipses = false);
+       std::pair<std::string, double> fit_to_pixels (cairo_t *, std::string, double);
+       int pixel_width (const std::string& str, Pango::FontDescription& font);
+
        void get_ink_pixel_size (Glib::RefPtr<Pango::Layout>, 
                                 int& width, int& height);
 
@@ -60,23 +64,14 @@ namespace Gtkmm2ext {
                                                     gint hpadding,
                                                     gint vpadding);
 
-        Glib::RefPtr<Gdk::Pixbuf> pixbuf_from_string (const std::string& name, 
-                                                      const Pango::FontDescription& font, 
-                                                      int clip_width, 
-                                                      int clip_height, 
-                                                      Gdk::Color fg);
+       Glib::RefPtr<Gdk::Pixbuf> pixbuf_from_string (const std::string& name, 
+                                                     const Pango::FontDescription& font, 
+                                                     int clip_width, 
+                                                     int clip_height, 
+                                                     Gdk::Color fg);
 
        void set_popdown_strings (Gtk::ComboBoxText&, 
-                                 const std::vector<std::string>&, 
-                                 bool set_size = false,
-                                 gint hpadding = 0, gint vpadding = 0);
-
-        // Combo's are stupid - they steal space from the entry for the button
-#ifdef GTKOSX
-        static const guint32 COMBO_FUDGE = 38; 
-#else
-        static const guint32 COMBO_FUDGE = 24; 
-#endif
+                                 const std::vector<std::string>&);
 
        template<class T> void deferred_delete (void *ptr) {
                delete static_cast<T *> (ptr);
@@ -88,6 +83,8 @@ namespace Gtkmm2ext {
        Glib::RefPtr<Gdk::Drawable> get_bogus_drawable();
        void detach_menu (Gtk::Menu&);
 
+       Glib::RefPtr<Gdk::Window> window_to_draw_on (Gtk::Widget& w, Gtk::Widget** parent);
+
         bool possibly_translate_keyval_to_make_legal_accelerator (uint32_t& keyval);
         uint32_t possibly_translate_legal_accelerator_to_real_key (uint32_t keyval);
 
@@ -96,6 +93,25 @@ namespace Gtkmm2ext {
 
         void container_clear (Gtk::Container&);
         void rounded_rectangle (Cairo::RefPtr<Cairo::Context> context, double x, double y, double w, double h, double r=10);
+        void rounded_top_rectangle (Cairo::RefPtr<Cairo::Context> context, double x, double y, double w, double h, double r=10);
+        void rounded_top_left_rectangle (Cairo::RefPtr<Cairo::Context> context, double x, double y, double w, double h, double r=10);
+        void rounded_top_right_rectangle (Cairo::RefPtr<Cairo::Context> context, double x, double y, double w, double h, double r=10);
+       void rounded_top_half_rectangle (Cairo::RefPtr<Cairo::Context>, double x, double y, double w, double h, double r=10);
+       void rounded_bottom_half_rectangle (Cairo::RefPtr<Cairo::Context>, double x, double y, double w, double h, double r=10);
+
+        void rounded_rectangle (cairo_t*, double x, double y, double w, double h, double r=10);
+        void rounded_top_rectangle (cairo_t*, double x, double y, double w, double h, double r=10);
+        void rounded_top_left_rectangle (cairo_t*, double x, double y, double w, double h, double r=10);
+        void rounded_top_right_rectangle (cairo_t*, double x, double y, double w, double h, double r=10);
+
+       void rounded_top_half_rectangle (cairo_t*, double x, double y, double w, double h, double r=10);
+       void rounded_bottom_half_rectangle (cairo_t*, double x, double y, double w, double h, double r=10);
+
+       Gtk::Label* left_aligned_label (std::string const &);
+
+       void set_no_tooltip_whatsoever (Gtk::Widget &);
+       void enable_tooltips ();
+       void disable_tooltips ();
 };
 
 #endif /*  __gtkmm2ext_utils_h__ */