X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2FFont.hh;h=9f083db9d306845afa68e0e04de9441dfd71234f;hb=d181f1ad05332c42eb090384666171a142f54b0c;hp=4f4624ed60ca30caf1475e4801a9670449235783;hpb=5282d92b627041047b2603b0c2d013c221f4dd56;p=chaz%2Fopenbox diff --git a/src/Font.hh b/src/Font.hh index 4f4624ed..9f083db9 100644 --- a/src/Font.hh +++ b/src/Font.hh @@ -47,13 +47,11 @@ class BFont { * static members */ private: -// static bool _antialias; static std::string _fallback_font; public: -// inline static bool antialias(void) { return _antialias; } -// inline static void setAntialias(bool a) { _antialias = a; } - + // the fallback is only used for X fonts, not for Xft fonts, since it is + // assumed that X fonts will be the fallback from Xft. inline static std::string fallbackFont(void) { return _fallback_font; } inline static void setFallbackFont(const std::string &f) { _fallback_font = f; } @@ -65,14 +63,18 @@ private: Display *_display; BScreen *_screen; - std::string _name; + std::string _family; bool _simplename; // true if not spec'd as a -*-* string int _size; bool _bold; bool _italic; #ifdef XFT + bool _antialias; + XftFont *_xftfont; + + bool createXftFont(void); #endif // standard @@ -81,24 +83,28 @@ private: XFontSet _fontset; XFontSetExtents *_fontset_extents; - std::string buildXlfdName(bool mb) const; + std::string buildXlfd(void) const; + std::string buildMultibyteXlfd(void) const; - bool init(const std::string &xlfd = ""); - bool createFont(void); - bool parseFontString(const std::string &xlfd); + bool createXFont(const std::string &xlfd); + bool parseXlfd(const std::string &xlfd); bool _valid; public: +#ifdef XFT + // loads an Xft font BFont(Display *d, BScreen *screen, const std::string &family, int size, - bool bold, bool italic); + bool bold, bool italic, bool antialias = True); +#endif + // loads a standard X font BFont(Display *d, BScreen *screen, const std::string &xlfd); - virtual ~BFont(); + virtual ~BFont(void); inline bool valid(void) const { return _valid; } - inline std::string name(void) const { assert(_valid); return _name; } - inline int size(void) const { assert(_valid); return _size / 10; } + 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; }