Merge branch 'nsm' of https://github.com/royvegard/ardour
[ardour.git] / libs / gtkmm2ext / gtkmm2ext / utils.h
index d6d5a9498cb90209038a8952500d0022c2c82f94..0bde3cb56287a149f9065e0a1c52e5ddcce70434 100644 (file)
 
 #include <vector>
 #include <string>
+#include <stdint.h>
 
+#include <cairomm/refptr.h>
+
+#include <gtkmm/container.h>
 #include <gtkmm/treeview.h>
 #include <gdkmm/window.h> /* for WMDecoration */
+#include <gdkmm/pixbuf.h>
+#include <pangomm/fontdescription.h>
+
+namespace Cairo {
+        class Context;
+}
 
 namespace Gtk {
        class ComboBoxText;
@@ -35,7 +45,11 @@ namespace Gtk {
 }
 
 namespace Gtkmm2ext {
-       void init ();
+       void init (const char*);
+
+       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);
@@ -50,17 +64,14 @@ namespace Gtkmm2ext {
                                                     gint hpadding,
                                                     gint vpadding);
 
-       void set_popdown_strings (Gtk::ComboBoxText&, 
-                                 const std::vector<std::string>&, 
-                                 bool set_size = false,
-                                 gint hpadding = 0, gint vpadding = 0);
+       Glib::RefPtr<Gdk::Pixbuf> pixbuf_from_string (const std::string& name, 
+                                                     const Pango::FontDescription& font, 
+                                                     int clip_width, 
+                                                     int clip_height, 
+                                                     Gdk::Color fg);
 
-        // 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
+       void set_popdown_strings (Gtk::ComboBoxText&, 
+                                 const std::vector<std::string>&);
 
        template<class T> void deferred_delete (void *ptr) {
                delete static_cast<T *> (ptr);
@@ -71,6 +82,42 @@ namespace Gtkmm2ext {
        void set_treeview_header_as_default_label(Gtk::TreeViewColumn *c);
        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);
+
+        int physical_screen_height (Glib::RefPtr<Gdk::Window>);
+        int physical_screen_width (Glib::RefPtr<Gdk::Window>);
+
+        void container_clear (Gtk::Container&);
+
+       /* C++ API for rounded rectangles */
+       
+        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_right_half_rectangle (Cairo::RefPtr<Cairo::Context>, double x, double y, double w, double h, double r=10);
+
+       /* C API for rounded rectangles */
+
+        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);
+       void rounded_right_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__ */