X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Futils.h;h=2dce61e9080e468f3144dcfdb2f0bfc69f64ac3a;hb=c4fc6792b5b12d58b26d556077d06448301cb801;hp=eb74864a78ec3e7964f4db0d95386e6b1f1751ea;hpb=882e3a690a38b447f00bd14bfdfea88e9ad49f93;p=ardour.git diff --git a/gtk2_ardour/utils.h b/gtk2_ardour/utils.h index eb74864a78..2dce61e908 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 @@ -26,37 +26,33 @@ #include "ardour/types.h" #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); +extern sigc::signal DPIReset; -} +std::string fit_to_pixels (const std::string&, 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); +int pixel_width (const std::string& 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 +73,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); +std::string 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); @@ -89,11 +87,10 @@ bool key_is_legal_for_numeric_entry (guint keyval); void reset_dpi (); void set_pango_fontsize (); -inline guint8 convert_color_channel (guint8 src, guint8 alpha); -void convert_bgra_to_rgba (guint8 const* src, - guint8* dst, - int width, - int height); +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__ */