From 59629bffc10b21da4787457a4b3b23e5598c03b7 Mon Sep 17 00:00:00 2001 From: Arin Alexander Date: Thu, 7 Dec 2017 02:39:00 +0300 Subject: [PATCH] Splitting has been fixed --- limereport/items/lrtextitem.cpp | 44 ++++++++++++++++++++++----------- 1 file changed, 30 insertions(+), 14 deletions(-) diff --git a/limereport/items/lrtextitem.cpp b/limereport/items/lrtextitem.cpp index c76185a..09c8988 100644 --- a/limereport/items/lrtextitem.cpp +++ b/limereport/items/lrtextitem.cpp @@ -780,43 +780,59 @@ bool TextItem::canBeSplitted(int height) const QString TextItem::getTextPart(int height, int skipHeight){ int linesHeight = 0; int curLine = 0; - int textPos = 0; +// int textPos = 0; TextPtr text = textDocument(); - text->documentLayout(); + text->size().height(); + QTextCursor cursor(text.data()); + cursor.movePosition(QTextCursor::Start); QTextBlock curBlock = text->begin(); QString resultText = ""; if (skipHeight > 0){ - for (;curBlock != text->end(); curBlock=curBlock.next()){ - for (curLine = 0; curLine < curBlock.layout()->lineCount(); curLine++){ - linesHeight += curBlock.layout()->lineAt(curLine).height() + lineSpacing(); + for (;curBlock != text->end() || curLine<=curBlock.lineCount(); curBlock = curBlock.next(), curLine = 0){ + linesHeight+=curBlock.blockFormat().topMargin(); + for (;curLine < curBlock.layout()->lineCount(); curLine++){ + linesHeight += curBlock.layout()->lineAt(curLine).rect().height() + lineSpacing(); if (linesHeight > (skipHeight-(/*fakeMarginSize()*2+*/borderLineSize() * 2))) {goto loop_exit;} + cursor.movePosition(QTextCursor::Right, QTextCursor::MoveAnchor, curBlock.layout()->lineAt(curLine).textLength()); } } - loop_exit:; + loop_exit: cursor.movePosition(QTextCursor::EndOfLine, QTextCursor::MoveAnchor); } linesHeight = 0; - for (;curBlock != text->end() || curLinelineCount(); curLine++){ - if (resultText == "") textPos= curBlock.layout()->lineAt(curLine).textStart(); + for (;curBlock != text->end() || curLinelineCount(); curLine++){ +// if (resultText == "") textPos = curBlock.layout()->lineAt(curLine).textStart(); linesHeight += curBlock.layout()->lineAt(curLine).height() + lineSpacing(); if ( (height>0) && (linesHeight>(height-(/*fakeMarginSize()*2+*/borderLineSize()*2))) ) { linesHeight-=curBlock.layout()->lineAt(curLine).height(); goto loop_exit1; } - resultText+=curBlock.text().mid(curBlock.layout()->lineAt(curLine).textStart(), - curBlock.layout()->lineAt(curLine).textLength()); +// QString fragment = curBlock.text().mid(curBlock.layout()->lineAt(curLine).textStart(), +// curBlock.layout()->lineAt(curLine).textLength()); +// resultText+=fragment; + cursor.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor, curBlock.layout()->lineAt(curLine).textLength()); } } loop_exit1:; + cursor.movePosition(QTextCursor::EndOfLine, QTextCursor::KeepAnchor); + if (allowHTML()){ + resultText = cursor.selection().toHtml(); + resultText.remove(""); + resultText.remove(""); + } else { + resultText = cursor.selection().toPlainText(); + } - resultText.chop(1); +// resultText.chop(1); - QScopedPointer context(new HtmlContext(m_strText)); - return context->extendTextByTags(resultText,textPos); +// QScopedPointer context(new HtmlContext(m_strText)); + return resultText;//context->extendTextByTags(resultText,textPos); } void TextItem::restoreLinksEvent()