2003-01-11 19:17:13 +00:00
|
|
|
// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
|
|
|
|
#ifndef __font_hh
|
|
|
|
#define __font_hh
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2003-01-12 21:17:26 +00:00
|
|
|
#include "userstring.hh"
|
|
|
|
|
2002-11-01 03:27:41 +00:00
|
|
|
extern "C" {
|
|
|
|
#include <X11/Xlib.h>
|
2002-12-03 08:54:51 +00:00
|
|
|
#define _XFT_NO_COMPAT_ // no Xft 1 API
|
2002-11-01 03:27:41 +00:00
|
|
|
#include <X11/Xft/Xft.h>
|
|
|
|
}
|
|
|
|
|
|
|
|
#include <assert.h>
|
2003-01-12 21:17:26 +00:00
|
|
|
|
2002-11-01 03:27:41 +00:00
|
|
|
#include <string>
|
|
|
|
|
2002-11-03 10:07:16 +00:00
|
|
|
namespace otk {
|
|
|
|
|
2003-01-11 19:17:13 +00:00
|
|
|
class Color;
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2003-01-11 19:17:13 +00:00
|
|
|
class Font {
|
2002-11-01 03:27:41 +00:00
|
|
|
/*
|
|
|
|
* static members
|
|
|
|
*/
|
|
|
|
private:
|
|
|
|
static std::string _fallback_font;
|
2002-12-03 08:54:51 +00:00
|
|
|
static bool _xft_init;
|
2002-11-01 03:27:41 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
// 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; }
|
|
|
|
|
|
|
|
/*
|
|
|
|
* instance members
|
|
|
|
*/
|
|
|
|
private:
|
2002-11-03 10:07:16 +00:00
|
|
|
int _screen_num;
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2002-12-03 08:54:51 +00:00
|
|
|
std::string _fontstring;
|
2002-11-01 03:27:41 +00:00
|
|
|
|
|
|
|
bool _shadow;
|
|
|
|
unsigned char _offset;
|
|
|
|
unsigned char _tint;
|
|
|
|
|
|
|
|
XftFont *_xftfont;
|
|
|
|
|
|
|
|
bool createXftFont(void);
|
|
|
|
|
|
|
|
public:
|
|
|
|
// loads an Xft font
|
2003-01-11 19:17:13 +00:00
|
|
|
Font(int screen_num, const std::string &fontstring, bool shadow,
|
2002-12-03 08:54:51 +00:00
|
|
|
unsigned char offset, unsigned char tint);
|
2003-01-11 19:17:13 +00:00
|
|
|
virtual ~Font();
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2002-12-03 08:54:51 +00:00
|
|
|
inline const std::string &fontstring() const { return _fontstring; }
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2002-12-03 08:54:51 +00:00
|
|
|
unsigned int height() const;
|
|
|
|
unsigned int maxCharWidth() const;
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2003-01-12 21:17:26 +00:00
|
|
|
//! Measures the length of a string
|
|
|
|
/*!
|
|
|
|
@param string The string to measure, it should be UTF8 encoded.
|
|
|
|
*/
|
|
|
|
unsigned int measureString(const userstring &string) const;
|
2002-11-01 03:27:41 +00:00
|
|
|
|
2002-12-03 08:54:51 +00:00
|
|
|
//! 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! :)
|
2003-01-12 21:17:26 +00:00
|
|
|
@param d The drawable to render into.
|
|
|
|
@param x The X offset onto the drawable at which to start drawing.
|
|
|
|
@param x The Y offset onto the drawable at which to start drawing.
|
|
|
|
@param color The color to use for drawing the text.
|
|
|
|
@param string The string to draw, it should be UTF8 encoded.
|
2002-12-03 08:54:51 +00:00
|
|
|
*/
|
2003-01-11 19:17:13 +00:00
|
|
|
void drawString(XftDraw *d, int x, int y, const Color &color,
|
2003-01-12 21:17:26 +00:00
|
|
|
const userstring &string) const;
|
2002-11-01 03:27:41 +00:00
|
|
|
};
|
|
|
|
|
2002-11-03 10:07:16 +00:00
|
|
|
}
|
|
|
|
|
2003-01-11 19:17:13 +00:00
|
|
|
#endif // __font_hh
|