X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Futils.h;h=cac21b4ffabc1df6656b4a54e1a5a85b49fb1d8f;hb=d8e93be2ee68fc6a18a7ca17d36ffc67c94207b3;hp=eb74864a78ec3e7964f4db0d95386e6b1f1751ea;hpb=882e3a690a38b447f00bd14bfdfea88e9ad49f93;p=ardour.git diff --git a/gtk2_ardour/utils.h b/gtk2_ardour/utils.h index eb74864a78..cac21b4ffa 100644 --- a/gtk2_ardour/utils.h +++ b/gtk2_ardour/utils.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002 Paul Davis + Copyright (C) 2002 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -27,36 +27,31 @@ #include #include #include +#include #include "canvas.h" +namespace PBD { + class Controllable; + class ScopedConnectionList; +} + namespace Gtk { class Window; class ComboBoxText; class Paned; + class Adjustment; } -static inline double -gain_to_slider_position (ARDOUR::gain_t g) -{ - if (g == 0) return 0; - return pow((6.0*log(g)/log(2.0)+192.0)/198.0, 8.0); - -} +Glib::ustring fit_to_pixels (const Glib::ustring&, int pixel_width, Pango::FontDescription& font, int& actual_width, bool with_ellipses = false); -static inline ARDOUR::gain_t -slider_position_to_gain (double pos) -{ - /* XXX Marcus writes: this doesn't seem right to me. but i don't have a better answer ... */ - if (pos == 0.0) return 0; - return pow (2.0,(sqrt(sqrt(sqrt(pos)))*198.0-192.0)/6.0); -} +std::pair fit_to_pixels (cairo_t *, std::string, double); -Glib::ustring fit_to_pixels (const Glib::ustring&, int pixel_width, Pango::FontDescription& font, int& actual_width, bool with_ellipses = false); int pixel_width (const Glib::ustring& str, Pango::FontDescription& font); gint just_hide_it (GdkEventAny*, Gtk::Window*); void allow_keyboard_focus (bool); +void add_item_with_sensitivity (Gtk::Menu_Helpers::MenuList &, Gtk::Menu_Helpers::MenuElem, bool); unsigned char* xpm2rgb (const char** xpm, uint32_t& w, uint32_t& h); unsigned char* xpm2rgba (const char** xpm, uint32_t& w, uint32_t& h); @@ -77,10 +72,12 @@ bool canvas_item_visible (ArdourCanvas::Item* item); void set_color (Gdk::Color&, int); +bool relay_key_press (GdkEventKey* ev, Gtk::Window* win); +bool forward_key_press (GdkEventKey* ev); bool key_press_focus_accelerator_handler (Gtk::Window& window, GdkEventKey* ev); -bool possibly_translate_keyval_to_make_legal_accelerator (uint32_t& keyval); Glib::RefPtr get_xpm (std::string); +Glib::ustring get_icon_path (const char*); Glib::RefPtr get_icon (const char*); static std::map > xpm_map; const char* const *get_xpm_data (std::string path); @@ -95,5 +92,16 @@ void convert_bgra_to_rgba (guint8 const* src, int width, int height); +Glib::RefPtr pixbuf_from_ustring (const Glib::ustring& name, + Pango::FontDescription* font, + int clip_width, + int clip_height, + Gdk::Color); + +void resize_window_to_proportion_of_monitor (Gtk::Window*, int, int); + +std::string escape_underscores (std::string const &); + +void control_link (PBD::ScopedConnectionList& scl, boost::shared_ptr c, Gtk::Adjustment& a); #endif /* __ardour_gtk_utils_h__ */