From 7a04d25fea9720bba9812d6912e8258c06ae2f80 Mon Sep 17 00:00:00 2001 From: bptato Date: Tue, 26 Mar 2024 01:49:13 +0100 Subject: layout: also round line height for painting backgrounds it's pointless to do otherwise, and results in inconsistencies between line positioning and background coloring. --- src/layout/engine.nim | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/layout/engine.nim b/src/layout/engine.nim index 8a56f110..48284408 100644 --- a/src/layout/engine.nim +++ b/src/layout/engine.nim @@ -436,9 +436,6 @@ proc verticalAlignLine(ictx: var InlineContext) = ictx.currentLine.minHeight = max(ictx.currentLine.minHeight, atom.offset.y - offsety + atom.size.h) - # Set the line height that will be used for painting to new top edge + old - # bottom edge, and set the baseline. - ictx.currentLine.line.height = max(bottomEdge + marginTop, lineheight) ictx.currentLine.baseline = baseline #TODO this does not really work with rounding :/ ictx.currentLine.baseline += ictx.currentLine.paddingTop @@ -453,6 +450,8 @@ proc verticalAlignLine(ictx: var InlineContext) = # we would swallow hard line breaks with
.) if lineheight >= ch and ictx.currentLine.size.h < ch: ictx.currentLine.size.h = ch + # Set the line height to size.h. + ictx.currentLine.line.height = ictx.currentLine.size.h proc putAtom(state: var LineBoxState; atom: InlineAtom; iastate: InlineAtomState; fragment: InlineFragment) = -- cgit 1.4.1-2-gfad0