]> Dogcows Code - chaz/openbox/blobdiff - otk/font.hh
start of new render code
[chaz/openbox] / otk / font.hh
index 8afd2bd10bd6aa22efe753061ec3dc66ebfa344b..dcff65260ea8028944693039caf23139c14bb7f6 100644 (file)
@@ -1,28 +1,28 @@
-// -*- mode: C++; indent-tabs-mode: nil; -*-
-#ifndef   __Font_hh
-#define   __Font_hh
+// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
+#ifndef   __font_hh
+#define   __font_hh
+
+#include "ustring.hh"
 
 extern "C" {
 #include <X11/Xlib.h>
+#define _XFT_NO_COMPAT_ // no Xft 1 API
 #include <X11/Xft/Xft.h>
 }
 
 #include <assert.h>
-#include <string>
 
 namespace otk {
 
-class BGCCache;
-class BGCCacheItem;
-class BColor;
-class ScreenInfo;
+class Color;
 
-class BFont {
+class Font {
   /*
    * static members
    */
 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 +37,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,31 +47,28 @@ 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; }
+  Font(int screen_num, const std::string &fontstring, bool shadow,
+        unsigned char offset, unsigned char tint);
+  virtual ~Font();
 
-  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 ustring &string) 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 Color &color,
+                  const ustring &string) const;
 };
 
 }
 
-#endif // __Font_hh
+#endif // __font_hh
This page took 0.023601 seconds and 4 git commands to generate.