mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-14 06:57:01 +00:00
463bd17d75
There is no need for real-valued line width in painters. Actually, this even leads to uneven dashes for continuous spell checker. The new code is supposed to be equivalent to the old one, just more readable. From this, we can try to see whether some lines need to be made thicker on HiDPI screens.
189 lines
4.9 KiB
C++
189 lines
4.9 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file GuiPainter.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* \author John Levon
|
|
* \author Abdelrazak Younes
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef GUIPAINTER_H
|
|
#define GUIPAINTER_H
|
|
|
|
#include "Color.h"
|
|
|
|
#include "frontends/Painter.h"
|
|
|
|
#include <QPainter>
|
|
#include <stack>
|
|
|
|
class QString;
|
|
|
|
namespace lyx {
|
|
|
|
class FontInfo;
|
|
|
|
namespace frontend {
|
|
|
|
/**
|
|
* GuiPainter - a painter implementation for Qt
|
|
*/
|
|
class GuiPainter : public QPainter, public Painter {
|
|
public:
|
|
GuiPainter(QPaintDevice *, double pixel_ratio);
|
|
virtual ~GuiPainter();
|
|
|
|
/// draw a line from point to point
|
|
virtual void line(
|
|
int x1, int y1,
|
|
int x2, int y2,
|
|
Color,
|
|
line_style ls = line_solid,
|
|
int lw = thin_line);
|
|
|
|
/**
|
|
* lines - draw a set of lines
|
|
* @param xp array of points' x co-ords
|
|
* @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,
|
|
Color,
|
|
fill_style fs = fill_none,
|
|
line_style ls = line_solid,
|
|
int lw = thin_line);
|
|
|
|
/// draw a rectangle
|
|
virtual void rectangle(
|
|
int x, int y,
|
|
int w, int h,
|
|
Color,
|
|
line_style = line_solid,
|
|
int lw = thin_line);
|
|
|
|
/// draw a filled rectangle
|
|
virtual void fillRectangle(
|
|
int x, int y,
|
|
int w, int h,
|
|
Color);
|
|
|
|
/// draw an arc
|
|
virtual void arc(
|
|
int x, int y,
|
|
unsigned int w, unsigned int h,
|
|
int a1, int a2,
|
|
Color);
|
|
|
|
/// draw a pixel
|
|
virtual void point(int x, int y, Color);
|
|
|
|
/// draw an image from the image cache
|
|
virtual void image(int x, int y, int w, int h,
|
|
lyx::graphics::Image const & image);
|
|
|
|
/** 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);
|
|
|
|
/** 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);
|
|
|
|
/** 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);
|
|
|
|
/// 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 void textDecoration(FontInfo const & f, int x, int y, int width);
|
|
|
|
/// draw a string and enclose it inside a button frame
|
|
virtual void buttonText(int x, int baseline, docstring const & s,
|
|
FontInfo const & font, bool mouseHover);
|
|
|
|
/// start monochrome painting mode, i.e. map every color into [min,max]
|
|
virtual void enterMonochromeMode(Color const & min,
|
|
Color const & max);
|
|
/// leave monochrome painting mode
|
|
virtual void leaveMonochromeMode();
|
|
|
|
/**
|
|
* Draw a string and enclose it inside a rectangle. If
|
|
* back color is specified, the background is cleared with
|
|
* the given color. If frame is specified, a thin frame is drawn
|
|
* around the text with the given color.
|
|
*/
|
|
virtual void rectText(int x, int baseline, docstring const & str,
|
|
FontInfo const & font, Color back, Color frame);
|
|
|
|
/// draw a filled rectangle with the shape of a 3D button
|
|
virtual void button(int x, int y, int w, int h, bool mouseHover);
|
|
|
|
/// draw a character of a preedit string for cjk support.
|
|
virtual int preeditText(int x, int y,
|
|
char_type c, FontInfo const & f, preedit_style style);
|
|
|
|
void wavyHorizontalLine(int x, int y, int width, ColorCode col);
|
|
|
|
private:
|
|
/// check the font, and if set, draw an underline
|
|
void underline(FontInfo const & f,
|
|
int x, int y, int width);
|
|
|
|
/// check the font, and if set, draw an dashed underline
|
|
void dashedUnderline(FontInfo const & f,
|
|
int x, int y, int width);
|
|
|
|
/// check the font, and if set, draw an strike-through line
|
|
void strikeoutLine(FontInfo const & f,
|
|
int x, int y, int width);
|
|
|
|
/// check the font, and if set, draw double underline
|
|
void doubleUnderline(FontInfo const & f,
|
|
int x, int y, int width);
|
|
|
|
/// draw a bevelled button border
|
|
void buttonFrame(int x, int y, int w, int h);
|
|
|
|
/// set pen parameters
|
|
void setQPainterPen(QColor const & col,
|
|
line_style ls = line_solid, int lw = thin_line);
|
|
|
|
QColor current_color_;
|
|
Painter::line_style current_ls_;
|
|
int current_lw_;
|
|
///
|
|
bool const use_pixmap_cache_;
|
|
///
|
|
std::stack<QColor> monochrome_min_;
|
|
///
|
|
std::stack<QColor> monochrome_max_;
|
|
/// convert into Qt color, possibly applying the monochrome mode
|
|
QColor computeColor(Color col);
|
|
/// possibly apply monochrome mode
|
|
QColor filterColor(QColor const & col);
|
|
///
|
|
QString generateStringSignature(QString const & str, FontInfo const & f);
|
|
};
|
|
|
|
} // namespace frontend
|
|
} // namespace lyx
|
|
|
|
#endif // GUIPAINTER_H
|