X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffrontends%2FPainter.h;h=7906aa986be865e8e60a0051a2df403b4e8b4ecf;hb=af42a9d683728a0af34a56f7fd56ec8be4155227;hp=ab65b55adb2194be3df0ab14cb05a72e7fd95573;hpb=814a8411ebeac155f9ee9df915bce4ff731dd21b;p=lyx.git diff --git a/src/frontends/Painter.h b/src/frontends/Painter.h index ab65b55adb..7906aa986b 100644 --- a/src/frontends/Painter.h +++ b/src/frontends/Painter.h @@ -13,12 +13,12 @@ #ifndef PAINTER_H #define PAINTER_H -#include "ColorCode.h" - #include "support/strfwd.h" +#include "support/types.h" namespace lyx { +class Font; class FontInfo; namespace graphics { class Image; } @@ -54,12 +54,9 @@ namespace frontend { */ class Painter { public: - Painter() : drawing_enabled_(true) {} - /// possible line widths - enum line_width { - line_thin, //< thin line - line_thick //< thick line - }; + Painter(double pixel_ratio) : drawing_enabled_(true), pixel_ratio_(pixel_ratio) {} + + static const float thin_line; /// possible line styles enum line_style { @@ -67,6 +64,13 @@ public: line_onoffdash //< dashes with spaces }; + /// possible fill styles + enum fill_style { + fill_none, + fill_oddeven, + fill_winding + }; + /// possible character styles of preedit string. /// This is used for CJK input method support. enum preedit_style { @@ -78,8 +82,8 @@ public: virtual ~Painter() {} /// draw a line from point to point - virtual void line(int x1, int y1, int x2, int y2, ColorCode, - line_style = line_solid, line_width = line_thin) = 0; + virtual void line(int x1, int y1, int x2, int y2, Color, + line_style = line_solid, float line_width = thin_line) = 0; /** * lines - draw a set of lines @@ -87,22 +91,23 @@ public: * @param yp array of points' y co-ords * @param np size of the points array */ - virtual void lines(int const * xp, int const * yp, int np, ColorCode, - line_style = line_solid, line_width = line_thin) = 0; + virtual void lines(int const * xp, int const * yp, int np, Color, + fill_style = fill_none, line_style = line_solid, + float line_width = thin_line) = 0; /// draw a rectangle - virtual void rectangle(int x, int y, int w, int h, ColorCode, - line_style = line_solid, line_width = line_thin) = 0; + virtual void rectangle(int x, int y, int w, int h, Color, + line_style = line_solid, float line_width = thin_line) = 0; /// draw a filled rectangle - virtual void fillRectangle(int x, int y, int w, int h, ColorCode) = 0; + virtual void fillRectangle(int x, int y, int w, int h, Color) = 0; /// draw an arc virtual void arc(int x, int y, unsigned int w, unsigned int h, - int a1, int a2, ColorCode) = 0; + int a1, int a2, Color) = 0; /// draw a pixel - virtual void point(int x, int y, ColorCode) = 0; + virtual void point(int x, int y, Color) = 0; /// draw a filled rectangle with the shape of a 3D button virtual void button(int x, int y, int w, int h, bool mouseHover) = 0; @@ -111,11 +116,25 @@ public: virtual void image(int x, int y, int w, int h, graphics::Image const & image) = 0; - /// draw a string at position x, y (y is the baseline) - /** - * \return the width of the drawn text. - */ - virtual int text(int x, int y, docstring const & str, FontInfo const & f) = 0; + /** draw a string at position x, y (y is the baseline). The + * text direction is given by \c rtl. + * \return the width of the drawn text. + */ + virtual int text(int x, int y, docstring const & str, FontInfo const & f, bool rtl = false) = 0; + + /** draw a string at position x, y (y is the baseline). The + * text direction is enforced by the \c Font. + * \return the width of the drawn text. + */ + virtual int text(int x, int y, docstring const & str, Font const & f) = 0; + + /** draw a string at position x, y (y is the baseline), but + * make sure that the part between \c from and \c to is in + * \c other color. The text direction is enforced by the \c Font. + * \return the width of the drawn text. + */ + virtual int text(int x, int y, docstring const & str, Font const & f, + Color other, size_type from, size_type to) = 0; void setDrawingEnabled(bool drawing_enabled) { drawing_enabled_ = drawing_enabled; } @@ -123,12 +142,17 @@ public: /// Indicate wether real screen drawing shall be done or not. bool isDrawingEnabled() const { return drawing_enabled_; } + double pixelRatio() const { return pixel_ratio_; } + /// draw a char at position x, y (y is the baseline) /** * \return the width of the drawn text. */ 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 * back color is specified, the background is cleared with @@ -136,7 +160,7 @@ public: * around the text with the given color. */ virtual void rectText(int x, int baseline, docstring const & str, - FontInfo const & font, ColorCode back, ColorCode frame) = 0; + FontInfo const & font, Color back, Color frame) = 0; /// draw a string and enclose it inside a button frame virtual void buttonText(int x, int baseline, docstring const & s, @@ -147,14 +171,17 @@ public: char_type c, FontInfo const & f, preedit_style style) = 0; /// start monochrome painting mode, i.e. map every color into [min,max] - virtual void enterMonochromeMode(ColorCode const & min, - ColorCode const & max) = 0; + virtual void enterMonochromeMode(Color const & min, + Color const & max) = 0; /// leave monochrome painting mode virtual void leaveMonochromeMode() = 0; - + /// draws a wavy line that can be used for underlining. + virtual void wavyHorizontalLine(int x, int y, int width, ColorCode col) = 0; private: /// bool drawing_enabled_; + /// Ratio between physical pixels and device-independent pixels + double pixel_ratio_; }; } // namespace frontend