X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Ffont.hh;h=8ff1f67dfd528e11d06d57bfab9fcb250da13938;hb=5a139f7263e33b499836f5df9ac37400e02c32f9;hp=8afd2bd10bd6aa22efe753061ec3dc66ebfa344b;hpb=fa8cefef63feb1d559c40db3cf9407e5bd1ac4df;p=chaz%2Fopenbox diff --git a/otk/font.hh b/otk/font.hh index 8afd2bd1..8ff1f67d 100644 --- a/otk/font.hh +++ b/otk/font.hh @@ -4,6 +4,7 @@ extern "C" { #include +#define _XFT_NO_COMPAT_ // no Xft 1 API #include } @@ -23,6 +24,7 @@ class BFont { */ private: static std::string _fallback_font; + static bool _xft_init; public: // the fallback is only used for X fonts, not for Xft fonts, since it is @@ -37,13 +39,8 @@ public: private: int _screen_num; - std::string _family; - bool _simplename; // true if not spec'd as a -*-* string - int _size; - bool _bold; - bool _italic; + std::string _fontstring; - bool _antialias; bool _shadow; unsigned char _offset; unsigned char _tint; @@ -52,29 +49,27 @@ private: bool createXftFont(void); - bool _valid; - public: // loads an Xft font - BFont(int screen_num, const std::string &family, int size, - bool bold, bool italic, bool shadow, unsigned char offset, - unsigned char tint, bool antialias = True); - virtual ~BFont(void); - - inline bool valid(void) const { return _valid; } + BFont(int screen_num, const std::string &fontstring, bool shadow, + unsigned char offset, unsigned char tint); + virtual ~BFont(); - inline std::string family(void) const { assert(_valid); return _family; } - inline int size(void) const { assert(_valid); return _size; } - inline bool bold(void) const { assert(_valid); return _bold; } - inline bool italic(void) const { assert(_valid); return _italic; } + inline const std::string &fontstring() const { return _fontstring; } - unsigned int height(void) const; - unsigned int maxCharWidth(void) const; + unsigned int height() const; + unsigned int maxCharWidth() const; - unsigned int measureString(const std::string &string) const; + unsigned int measureString(const std::string &string, + bool utf8 = false) const; - void drawString(Drawable d, int x, int y, const BColor &color, - const std::string &string) const; + //! Draws a string into an XftDraw object + /*! + Be Warned: If you use an XftDraw object and a color, or a font from + different screens, you WILL have unpredictable results! :) + */ + void drawString(XftDraw *d, int x, int y, const BColor &color, + const std::string &string, bool utf8 = false) const; }; }