Le 14/04/2015 17:08, Kornel Benko a écrit :
You are right, I prefer a little thicker lines.
The dashed line does not respect the used font size, only the preferences zoom.
The one I propose respects the font size, I find it better.
JMarc
Maybe my eyes are not the best, but look at this snapshot.
Hi Kornel,
Back to this problem. What about the following patch?
JMarc
>From 289ee94350b0b79978584473f8400bf4e60bdc23 Mon Sep 17 00:00:00 2001
From: Jean-Marc Lasgouttes <lasgout...@lyx.org>
Date: Wed, 25 Nov 2015 22:09:45 +0100
Subject: [PATCH] Make spellchecker dotted underlines thicker.
---
src/RowPainter.cpp | 10 +++++-----
src/RowPainter.h | 1 -
2 files changed, 5 insertions(+), 6 deletions(-)
diff --git a/src/RowPainter.cpp b/src/RowPainter.cpp
index ce5780b..ec083e9 100644
--- a/src/RowPainter.cpp
+++ b/src/RowPainter.cpp
@@ -62,7 +62,7 @@ RowPainter::RowPainter(PainterInfo & pi,
pm_(text_metrics_.parMetrics(pit)), change_(pi_.change_),
xo_(x), yo_(y), width_(text_metrics_.width()),
solid_line_thickness_(1), solid_line_offset_(1),
- dotted_line_thickness_(1), dotted_line_offset_(2)
+ dotted_line_thickness_(1)
{
if (lyxrc.zoom >= 200) {
// derive the line thickness from zoom factor
@@ -77,8 +77,6 @@ RowPainter::RowPainter(PainterInfo & pi,
// the zoom is given in percent
// (increase thickness at 150%, 250% etc.)
dotted_line_thickness_ = (lyxrc.zoom + 50) / 100;
- // adjust line_offset_ too
- dotted_line_offset_ = 1 + dotted_line_thickness_ / 2;
}
x_ = row_.left_margin + xo_;
@@ -183,9 +181,11 @@ void RowPainter::paintMisspelledMark(double const orig_x,
{
// if changed the misspelled marker gets placed slightly lower than normal
// to avoid drawing at the same vertical offset
+ FontMetrics const & fm = theFontMetrics(e.font);
+ int const thickness = max(fm.lineWidth(), 2);
int const y = yo_ + solid_line_offset_ + solid_line_thickness_
+ (e.change.changed() ? solid_line_thickness_ + 1 : 0)
- + dotted_line_offset_;
+ + 1 + thickness / 2;
//FIXME: this could be computed only once, it is probably not costly.
// check for cursor position
@@ -228,7 +228,7 @@ void RowPainter::paintMisspelledMark(double const orig_x,
pi_.pain.line(int(orig_x) + x1, y, int(orig_x) + x2, y,
Color_error,
- Painter::line_onoffdash, dotted_line_thickness_);
+ Painter::line_onoffdash, thickness);
pos = range.last + 1;
}
}
diff --git a/src/RowPainter.h b/src/RowPainter.h
index 6d5a8c6..a4120e6 100644
--- a/src/RowPainter.h
+++ b/src/RowPainter.h
@@ -103,7 +103,6 @@ private:
int solid_line_thickness_;
int solid_line_offset_;
int dotted_line_thickness_;
- int dotted_line_offset_;
};
} // namespace lyx
--
2.5.0