#include <config.h>
-#include "Painter.h"
-#include "font_metrics.h"
+#include "frontends/Painter.h"
+
+#include "frontends/FontMetrics.h"
#include "LColor.h"
#include "lyxfont.h"
+using lyx::docstring;
+
using std::max;
using std::string;
void Painter::rectText(int x, int y,
- string const & str,
+ docstring const & str,
LyXFont const & font,
LColor_color back,
LColor_color frame)
int ascent;
int descent;
- font_metrics::rectText(str, font, width, ascent, descent);
+ FontMetrics const & fm = theFontMetrics(font);
+ fm.rectText(str, width, ascent, descent);
if (back != LColor::none)
fillRectangle(x + 1, y - ascent + 1, width - 1,
}
-void Painter::buttonText(int x, int y, string const & str, LyXFont const & font)
+void Painter::buttonText(int x, int y, docstring const & str, LyXFont const & font)
{
int width;
int ascent;
int descent;
- font_metrics::buttonText(str, font, width, ascent, descent);
+ FontMetrics const & fm = theFontMetrics(font);
+ fm.buttonText(str, width, ascent, descent);
button(x, y - ascent, width, descent + ascent);
text(x + 4, y, str, font);
void Painter::underline(LyXFont const & f, int x, int y, int width)
{
- int const below = max(font_metrics::maxDescent(f) / 2, 2);
- int const height = max((font_metrics::maxDescent(f) / 4) - 1, 1);
+ FontMetrics const & fm = theFontMetrics(f);
+
+ int const below = max(fm.maxDescent() / 2, 2);
+ int const height = max((fm.maxDescent() / 4) - 1, 1);
if (height < 2)
line(x, y + below, x + width, y + below, f.color());