summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Lubomir I. Ivanov <neolit123@gmail.com>2013-12-05 14:08:33 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-12-05 08:04:48 -0800
commit94f85bbef9e0b4079f17f6d995c3af381f3784de (patch)
tree2f21b20c8582712f9466ad6978748f7764530f61
parent09a8a85bab620dd119a601e9cadbd0333385acbc (diff)
downloadsubsurface-94f85bbef9e0b4079f17f6d995c3af381f3784de.tar.gz
Print: fix truncated table in "Table print" mode
The whole procedure here is quite confusing. Once we have our model populated, we need to estimate where to put page headers (each page has one) and to do that we store a list of indexes, where a page would begin (pageIndexes). But since a row can end up being chopped at the end of a page we move it to a new page and this particular part was lacking compensation for the moved row's height, when storing the *last* pageIndex. For N number of pages we are losing N - 1 dives, or such that were previously transferred on a new page. See #326 Signed-off-by: Lubomir I. Ivanov <neolit123@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/printlayout.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/qt-ui/printlayout.cpp b/qt-ui/printlayout.cpp
index 556bf139b..004188ca1 100644
--- a/qt-ui/printlayout.cpp
+++ b/qt-ui/printlayout.cpp
@@ -328,7 +328,7 @@ void PrintLayout::printTable()
// a list of vertical offsets where pages begin and some helpers
QList<unsigned int> pageIndexes;
pageIndexes.append(0);
- int tableHeight = 0, rowH = 0, accH = 0;
+ int tableHeight = 0, rowH = 0, accH = 0, headings = 0;
// process all rows
progress = 0;
@@ -339,6 +339,7 @@ void PrintLayout::printTable()
if (accH > scaledPageH) { // push a new page index and add a heading
pageIndexes.append(pageIndexes.last() + (accH - rowH));
addTablePrintHeadingRow(&model, i);
+ headings += rowH; // last row was moved to a new page; compensate!
accH = 0;
i--;
}
@@ -346,7 +347,7 @@ void PrintLayout::printTable()
progress++;
emit signalProgress(stage + (progress * stage) / total);
}
- pageIndexes.append(pageIndexes.last() + accH);
+ pageIndexes.append(pageIndexes.last() + accH + headings);
// resize the whole widget so that it can be rendered
table.resize(scaledPageW, tableHeight);