X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffrontends%2FPainter.C;h=6650722fcacb2ff2557c9a87d7ff5a4d19cb9f33;hb=36945644e70db39a8316570bb44fabc7a3bd3d49;hp=06544896d8161e2d1ee89f57fdc8e1386c556aec;hpb=6fac1dc98003a6a6e02765f078b3d3426d426508;p=lyx.git diff --git a/src/frontends/Painter.C b/src/frontends/Painter.C index 06544896d8..6650722fca 100644 --- a/src/frontends/Painter.C +++ b/src/frontends/Painter.C @@ -1,100 +1,92 @@ /** * \file Painter.C - * Read the file COPYING + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. * * \author unknown - * \author John Levon + * \author John Levon * - * Full author contact details are available in file CREDITS + * Full author contact details are available in file CREDITS. */ #include -#ifdef __GNUG__ -#pragma implementation -#endif - #include "Painter.h" -#include "lyxfont.h" +#include "font_metrics.h" #include "WorkArea.h" -#include "frontends/font_metrics.h" - + +#include "LColor.h" +#include "lyxfont.h" + using std::max; - -Painter & Painter::button(int x, int y, int w, int h) +using std::string; + + +void Painter::button(int x, int y, int w, int h) { fillRectangle(x, y, w, h, LColor::buttonbg); buttonFrame(x, y, w, h); - return * this; } -Painter & Painter::buttonFrame(int x, int y, int w, int h) +void Painter::buttonFrame(int x, int y, int w, int h) { // Width of a side of the button int const d = 2; fillRectangle(x, y, w, d, LColor::top); fillRectangle(x, (y + h - d), w, d, LColor::bottom); - + // Now a couple of trapezoids int x1[4], y1[4]; - + x1[0] = x + d; y1[0] = y + d; - x1[1] = x + d; y1[1] = (y + h - d); - x1[2] = x; y1[2] = y + h; - x1[3] = x; y1[3] = y; + x1[1] = x + d; y1[1] = y + h - d; + x1[2] = x; y1[2] = y + h; + x1[3] = x; y1[3] = y; fillPolygon(x1, y1, 4, LColor::left); - x1[0] = (x + w - d); y1[0] = y + d; - x1[1] = (x + w - d); y1[1] = (y + h - d); - x1[2] = x + w; y1[2] = (y + h - d); - x1[3] = x + w; y1[3] = y; + x1[0] = x + w - d; y1[0] = y + d; + x1[1] = x + w - d; y1[1] = y + h - d; + x1[2] = x + w; y1[2] = y + h - d; + x1[3] = x + w; y1[3] = y; fillPolygon(x1, y1, 4, LColor::right); - - return *this; } -Painter & Painter::rectText(int x, int baseline, - string const & str, +void Painter::rectText(int x, int y, + string const & str, LyXFont const & font, - LColor::color back, - LColor::color frame) + LColor_color back, + LColor_color frame) { int width; int ascent; int descent; font_metrics::rectText(str, font, width, ascent, descent); - - if (frame != LColor::none) { - rectangle(x, baseline - ascent, width, ascent + descent, frame); - } - - if (back != LColor::none) { - fillRectangle(x + 1, baseline - ascent + 1, width - 1, + + if (back != LColor::none) + fillRectangle(x + 1, y - ascent + 1, width - 1, ascent + descent - 1, back); - } - - text(x + 3, baseline, str, font); - return *this; + + if (frame != LColor::none) + rectangle(x, y - ascent, width, ascent + descent, frame); + + text(x + 3, y, str, font); } -Painter & Painter::buttonText(int x, int baseline, - string const & str, - LyXFont const & font) +void Painter::buttonText(int x, int y, string const & str, LyXFont const & font) { int width; int ascent; int descent; font_metrics::buttonText(str, font, width, ascent, descent); - - button(x, baseline - ascent, width, descent + ascent); - text(x + 4, baseline, str, font); - return *this; + + button(x, y - ascent, width, descent + ascent); + text(x + 4, y, str, font); } @@ -102,11 +94,9 @@ 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); - - if (height < 2) { + + if (height < 2) line(x, y + below, x + width, y + below, f.color()); - } else { - fillRectangle(x, y + below, width, below + height, - f.color()); - } + else + fillRectangle(x, y + below, width, below + height, f.color()); }