X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FRowPainter.cpp;h=4f5593e18b3764bce121ea2dae5255888fedc052;hb=7f1cb306f942709601314f3e396f0e01defdc45d;hp=6e4cf31ac10eed23dd7016d30067091ec4fd27b1;hpb=57b400cdffa7f0008adf5c697604e5110ea9b304;p=lyx.git diff --git a/src/RowPainter.cpp b/src/RowPainter.cpp index 6e4cf31ac1..4f5593e18b 100644 --- a/src/RowPainter.cpp +++ b/src/RowPainter.cpp @@ -11,8 +11,6 @@ #include -#include - #include "RowPainter.h" #include "Buffer.h" @@ -20,6 +18,7 @@ #include "Cursor.h" #include "BufferParams.h" #include "BufferView.h" +#include "Bullet.h" #include "Changes.h" #include "Language.h" #include "Layout.h" @@ -39,6 +38,7 @@ #include "support/gettext.h" #include "support/lassert.h" +#include using namespace std; @@ -83,7 +83,11 @@ FontInfo RowPainter::labelFont(bool end) const void RowPainter::paintInset(Row::Element const & e) const { - // Handle selection + // Handle selection (first left/right, then middle). + pi_.selected_left = pi_.selected + || (row_.isRTL() ? row_.end_margin_sel : row_.begin_margin_sel); + pi_.selected_right = pi_.selected + || (row_.isRTL() ? row_.begin_margin_sel : row_.end_margin_sel); bool const pi_selected = pi_.selected; Cursor const & cur = pi_.base.bv->cursor(); if (cur.selection() && cur.text() == &text_ @@ -290,7 +294,10 @@ void RowPainter::paintChange(Row::Element const & e) const void RowPainter::paintChangeBar() const { - pi_.pain.fillRectangle(5, yo_ - row_.ascent(), 3, row_.height(), Color_changebar); + int const x = pi_.base.bv->leftMargin() - pi_.base.bv->zoomedPixels(7); + Dimension const & cdim = row_.contents_dim(); + pi_.pain.fillRectangle(x, yo_ - cdim.ascent(), + 3, cdim.height(), Color_changebar); } @@ -337,9 +344,9 @@ void RowPainter::paintDepthBar() const for (depth_type i = 1; i <= depth; ++i) { int const w = nestMargin() / 5; int x = int(xo_) + w * i; - // consider the bufferview left margin if we're drawing outermost text + // only consider the changebar space if we're drawing outermost text if (text_.isMainText()) - x += pi_.base.bv->leftMargin(); + x += pi_.base.bv->leftMargin() - changebarMargin(); int const starty = yo_ - row_.ascent(); int const h = row_.height() - 1 - (i - next_depth - 1) * 3; @@ -379,18 +386,17 @@ void RowPainter::paintAppendixStart(int y) const void RowPainter::paintTooLargeMarks(bool const left, bool const right) const { - if (left) - pi_.pain.line(pi_.base.dottedLineThickness(), yo_ - row_.ascent(), - pi_.base.dottedLineThickness(), yo_ + row_.descent(), - Color_scroll, Painter::line_onoffdash, - pi_.base.dottedLineThickness()); + int const lwid = pi_.base.dottedLineThickness(); + Dimension const & cdim = row_.contents_dim(); + if (left) { + int const x = pi_.base.bv->leftMargin() - lwid; + pi_.pain.line(x, yo_ - cdim.ascent(), x, yo_ + cdim.descent(), + Color_scroll, Painter::line_onoffdash, lwid); + } if (right) { - int const wwidth = - pi_.base.bv->workWidth() - pi_.base.dottedLineThickness(); - pi_.pain.line(wwidth, yo_ - row_.ascent(), - wwidth, yo_ + row_.descent(), - Color_scroll, Painter::line_onoffdash, - pi_.base.dottedLineThickness()); + int const x = pi_.base.bv->workWidth() - pi_.base.bv->rightMargin(); + pi_.pain.line(x, yo_ - cdim.ascent(), x, yo_ + cdim.descent(), + Color_scroll, Painter::line_onoffdash, lwid); } } @@ -421,13 +427,26 @@ void RowPainter::paintLabel() const if (str.empty()) return; + // different font for label separation and string Layout const & layout = par_.layout(); FontInfo const font = labelFont(false); FontMetrics const & fm = theFontMetrics(font); + FontInfo lfont = font; + + // bullet? + if (layout.labeltype == LABEL_ITEMIZE && par_.itemdepth < 4) { + // get label font size from document properties + lfont.setSize(pi_.base.bv->buffer().params().user_defined_bullet(par_.itemdepth).getFontSize()); + // realize to avoid assertion + lfont.realize(sane_font); + } + + FontMetrics const & lfm = theFontMetrics(lfont); + int const x = row_.isRTL() ? row_.width() + fm.width(layout.labelsep) - : row_.left_margin - fm.width(layout.labelsep) - fm.width(str); + : row_.left_margin - fm.width(layout.labelsep) - lfm.width(str); - pi_.pain.text(int(xo_) + x, yo_, str, font); + pi_.pain.text(int(xo_) + x, yo_, str, lfont); } @@ -458,8 +477,18 @@ void RowPainter::paintTopLevelLabel() const double x = x_; if (layout.labeltype == LABEL_CENTERED) { - x += (tm_.width() - row_.left_margin - row_.right_margin) / 2; - x -= fm.width(str) / 2; + // The 'size + 1' is weird, but it makes sure that we get the + // left margin of non-first row. + int leftm = tm_.leftMargin(row_.pit(), par_.size() + 1); + int rightm = tm_.rightMargin(row_.pit()); + if (row_.isRTL()) + swap(leftm, rightm); + /* Currently, x points at row_.left_margin (which contains the + * indent). First remove that, and then center the title with + * respect to the left and right margins. + */ + x += leftm - row_.left_margin + (tm_.width() - leftm -rightm) / 2 + - fm.width(str) / 2; } else if (row_.isRTL()) { x = xo_ + tm_.width() - row_.right_margin - fm.width(str); } @@ -502,8 +531,8 @@ void RowPainter::paintLast() const FontInfo const font = labelFont(true); FontMetrics const & fm = theFontMetrics(font); docstring const & str = par_.layout().endlabelstring(); - double const x = row_.isRTL() ? x_ - fm.width(str) : x_; - pi_.pain.text(int(x), yo_, str, font); + double const x = row_.isRTL() ? row_.left_margin - fm.width(str) : row_.width(); + pi_.pain.text(xo_ + x, yo_, str, font); break; } @@ -549,6 +578,7 @@ void RowPainter::paintText() break; case Row::SPACE: + case Row::MARGINSPACE: paintTextDecoration(e); } @@ -570,10 +600,16 @@ void RowPainter::paintSelection() const if (!row_.selection()) return; - int const y1 = yo_ - row_.ascent(); - int const y2 = y1 + row_.height(); + int const y1 = yo_ - row_.contents_dim().asc; + int const y2 = yo_ + row_.contents_dim().des; - // draw the margins + // The top selection + if (row_.begin_margin_sel) + pi_.pain.fillRectangle(int(xo_), yo_ - row_.ascent(), + tm_.width(), row_.ascent() - row_.contents_dim().asc, + Color_selection); + + // The left margin selection if (row_.isRTL() ? row_.end_margin_sel : row_.begin_margin_sel) pi_.pain.fillRectangle(int(xo_), y1, row_.left_margin, y2 - y1, Color_selection); @@ -612,11 +648,31 @@ void RowPainter::paintSelection() const x += e.full_width(); } + // the right margin selection if (row_.isRTL() ? row_.begin_margin_sel : row_.end_margin_sel) pi_.pain.fillRectangle(int(x), y1, int(xo_ + tm_.width()) - int(x), y2 - y1, Color_selection); + // The bottom selection + if (row_.end_margin_sel) + pi_.pain.fillRectangle(int(xo_), yo_ + row_.contents_dim().des, + tm_.width(), row_.descent() - row_.contents_dim().des, + Color_selection); +} + +void RowPainter::paintBookmark(int num) const +{ + BufferView const * bv = pi_.base.bv; + FontInfo fi = bv->buffer().params().getFont().fontInfo(); + FontMetrics const & fm = theFontMetrics(fi); + fi.setColor(Color_bookmark); + // ❶ U+2776 DINGBAT NEGATIVE CIRCLED DIGIT ONE + char_type const ch = 0x2775 + num; + int const x = row_.isRTL() + ? bv->workWidth() - bv->rightMargin() + (bv->defaultMargin() - fm.width(ch)) / 2 + : bv->leftMargin() - (bv->defaultMargin() + fm.width(ch)) / 2; + pi_.pain.text(x, yo_, ch, fi); }