Factor out painting of text decorations

(cherry picked from commit 53b75399e75f4895880861908d05eed119dca3a8)
This commit is contained in:
Vincent van Ravesteijn 2012-05-02 18:02:17 +02:00
parent cf27d693d8
commit 17c6bb42e5
3 changed files with 22 additions and 17 deletions

View File

@ -127,6 +127,9 @@ public:
*/ */
virtual int text(int x, int y, char_type c, FontInfo const & f) = 0; virtual int text(int x, int y, char_type c, FontInfo const & f) = 0;
/// draw the underbar, strikeout, uuline and uwave font attributes
virtual void textDecoration(FontInfo const & f, int x, int y, int width) = 0;
/** /**
* Draw a string and enclose it inside a rectangle. If * Draw a string and enclose it inside a rectangle. If
* back color is specified, the background is cleared with * back color is specified, the background is cleared with

View File

@ -335,14 +335,7 @@ int GuiPainter::text(int x, int y, docstring const & s,
if (f.realShape() == SMALLCAPS_SHAPE) { if (f.realShape() == SMALLCAPS_SHAPE) {
textwidth = smallCapsText(x, y, str, f); textwidth = smallCapsText(x, y, str, f);
if (f.underbar() == FONT_ON) textDecoration(f, x, y, textwidth);
underline(f, x, y, textwidth);
if (f.strikeout() == FONT_ON)
strikeoutLine(f, x, y, textwidth);
if (f.uuline() == FONT_ON)
doubleUnderline(f, x, y, textwidth);
if (f.uwave() == FONT_ON)
wavyHorizontalLine(x, y, textwidth, f.realColor().baseColor);
return textwidth; return textwidth;
} }
@ -350,15 +343,7 @@ int GuiPainter::text(int x, int y, docstring const & s,
// textwidth = fontMetrics().width(str); // textwidth = fontMetrics().width(str);
// because the above is awfully expensive on MacOSX // because the above is awfully expensive on MacOSX
textwidth = fm.width(s); textwidth = fm.width(s);
if (f.underbar() == FONT_ON) textDecoration(f, x, y, textwidth);
underline(f, x, y, textwidth);
if (f.strikeout() == FONT_ON)
strikeoutLine(f, x, y, textwidth);
if (f.uuline() == FONT_ON)
doubleUnderline(f, x, y, textwidth);
if (f.uwave() == FONT_ON)
// f.color() doesn't work on some circumstances
wavyHorizontalLine(x, y, textwidth, f.realColor().baseColor);
if (!isDrawingEnabled()) if (!isDrawingEnabled())
return textwidth; return textwidth;
@ -441,6 +426,20 @@ int GuiPainter::text(int x, int y, docstring const & s,
} }
void GuiPainter::textDecoration(FontInfo const & f, int x, int y, int width)
{
if (f.underbar() == FONT_ON)
underline(f, x, y, width);
if (f.strikeout() == FONT_ON)
strikeoutLine(f, x, y, width);
if (f.uuline() == FONT_ON)
doubleUnderline(f, x, y, width);
if (f.uwave() == FONT_ON)
// f.color() doesn't work on some circumstances
wavyHorizontalLine(x, y, width, f.realColor().baseColor);
}
static int max(int a, int b) { return a > b ? a : b; } static int max(int a, int b) { return a > b ? a : b; }

View File

@ -93,6 +93,9 @@ public:
/// draw a char at position x, y (y is the baseline) /// draw a char at position x, y (y is the baseline)
virtual int text(int x, int y, char_type c, FontInfo const & f); virtual int text(int x, int y, char_type c, FontInfo const & f);
///
virtual void textDecoration(FontInfo const & f, int x, int y, int width);
/// draw a string and enclose it inside a button frame /// draw a string and enclose it inside a button frame
virtual void buttonText(int x, int baseline, docstring const & s, virtual void buttonText(int x, int baseline, docstring const & s,
FontInfo const & font, bool mouseHover); FontInfo const & font, bool mouseHover);