From 0d2615f084326cdd2ee778f8b212e14635a843ea Mon Sep 17 00:00:00 2001 From: Lucas Nobre <47952192+kinha08@users.noreply.github.com> Date: Fri, 1 Dec 2023 09:00:30 -0300 Subject: [PATCH] fix breaking line with newline character when wrap is true --- lib/src/draw/draw_string.dart | 108 +++++++++++++++++++--------------- 1 file changed, 59 insertions(+), 49 deletions(-) diff --git a/lib/src/draw/draw_string.dart b/lib/src/draw/draw_string.dart index 8a61f565..a171492d 100644 --- a/lib/src/draw/draw_string.dart +++ b/lib/src/draw/draw_string.dart @@ -44,60 +44,67 @@ Image drawString(Image image, String string, var sy = y ?? (image.height / 2).round() - (stringHeight / 2).round(); if (wrap) { - final words = string.split(RegExp(r"\s+")); - var subString = ""; - var x2 = sx; - - for (var w in words) { - final ws = StringBuffer() - ..write(w) - ..write(' '); - w = ws.toString(); - final chars = w.codeUnits; - var wordWidth = 0; - for (var c in chars) { - if (!font.characters.containsKey(c)) { - wordWidth += font.base ~/ 2; - continue; + final sentences = string.split(RegExp(r'\n')); + + for (var sentence in sentences) { + final words = sentence.split(RegExp(r"\s+")); + var subString = ""; + var x2 = sx; + + for (var w in words) { + final ws = StringBuffer() + ..write(w) + ..write(' '); + w = ws.toString(); + final chars = w.codeUnits; + var wordWidth = 0; + for (var c in chars) { + if (c == 10) break; + if (!font.characters.containsKey(c)) { + wordWidth += font.base ~/ 2; + continue; + } + final ch = font.characters[c]!; + wordWidth += ch.xAdvance; } - final ch = font.characters[c]!; - wordWidth += ch.xAdvance; - } - if ((x2 + wordWidth) > image.width) { - // If there is a word that won't fit the starting x, stop drawing - if ((sx == x2) || (sx + wordWidth > image.width)) { - return image; + if ((x2 + wordWidth) > image.width) { + // If there is a word that won't fit the starting x, stop drawing + if ((sx == x2) || (sx + wordWidth > image.width)) { + return image; + } + + drawString(image, subString, + font: font, + x: sx, + y: sy, + color: color, + mask: mask, + maskChannel: maskChannel, + rightJustify: rightJustify); + + subString = ""; + x2 = sx; + sy += stringHeight; + subString += w; + x2 += wordWidth; + } else { + subString += w; + x2 += wordWidth; } - drawString(image, subString, - font: font, - x: sx, - y: sy, - color: color, - mask: mask, - maskChannel: maskChannel, - rightJustify: rightJustify); - - subString = ""; - x2 = sx; - sy += stringHeight; - subString += w; - x2 += wordWidth; - } else { - subString += w; - x2 += wordWidth; + if (subString.isNotEmpty) { + drawString(image, subString, + font: font, + x: sx, + y: sy, + color: color, + mask: mask, + maskChannel: maskChannel, + rightJustify: rightJustify); + } } - if (subString.isNotEmpty) { - drawString(image, subString, - font: font, - x: sx, - y: sy, - color: color, - mask: mask, - maskChannel: maskChannel, - rightJustify: rightJustify); - } + sy += stringHeight; } return image; @@ -106,8 +113,11 @@ Image drawString(Image image, String string, final origX = sx; final substrings = string.split(RegExp(r"[\n|\r]")); + // print(substrings); + for (var ss in substrings) { final chars = ss.codeUnits; + // print("$ss = $chars"); if (rightJustify == true) { for (var c in chars) { if (!font.characters.containsKey(c)) {