X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2FFont.hh;h=e29f41b114550ae6aa039cfb0b03b99624617bfb;hb=c2afc72a41a4093f1fdfdf3245d5d70ef8bf9ad2;hp=4f4624ed60ca30caf1475e4801a9670449235783;hpb=5282d92b627041047b2603b0c2d013c221f4dd56;p=chaz%2Fopenbox diff --git a/src/Font.hh b/src/Font.hh index 4f4624ed..e29f41b1 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,19 @@ 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; + bool _shadow; + XftFont *_xftfont; + + bool createXftFont(void); #endif // standard @@ -81,24 +84,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 shadow, 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; }