if (((lineY + line->GetSize().y) > rect.GetBottom()) || hasHardPageBreak)
{
- // New page starting at this line
- int newY = rect.y;
+ // Only if we're not at the start of the document, and
+ // even then, only if either it's a hard break or if the object
+ // can fit in a whole page (otherwise there's no point in making
+ // the rest of this page blank).
+ if (lastLine && (hasHardPageBreak || (line->GetSize().y <= rect.GetHeight())))
+ {
+ // New page starting at this line
+ int newY = rect.y;
- // We increase the offset by the difference between new and old positions
+ // We increase the offset by the difference between new and old positions
- int increaseOffsetBy = lineY - newY;
- yOffset += increaseOffsetBy;
+ int increaseOffsetBy = lineY - newY;
+ yOffset += increaseOffsetBy;
- if (!lastLine)
- lastLine = line;
+ m_pageBreaksStart.Add(lastStartPos);
+ m_pageBreaksEnd.Add(lastLine->GetAbsoluteRange().GetEnd());
+ m_pageYOffsets.Add(yOffset);
- m_pageBreaksStart.Add(lastStartPos);
- m_pageBreaksEnd.Add(lastLine->GetAbsoluteRange().GetEnd());
- m_pageYOffsets.Add(yOffset);
+ lastStartPos = line->GetAbsoluteRange().GetStart();
+ m_numPages ++;
+ }
- lastStartPos = line->GetAbsoluteRange().GetStart();
lastLine = line;
- m_numPages ++;
-
// Now create page breaks for the rest of the line, if it's larger than the page height
int contentLeft = line->GetSize().y - rect.GetHeight();
while (contentLeft >= 0)
m_pageBreaksStart.Add(lastStartPos);
m_pageBreaksEnd.Add(lastLine->GetAbsoluteRange().GetEnd());
m_pageYOffsets.Add(yOffset);
+
+ m_numPages ++;
}
}
}
// Closing page break
- if (m_pageBreaksStart.GetCount() == 0 || (m_pageBreaksEnd[m_pageBreaksEnd.GetCount()-1] < (GetRichTextBuffer()->GetOwnRange().GetEnd()-1)))
- {
- m_pageBreaksStart.Add(lastStartPos);
- m_pageBreaksEnd.Add(GetRichTextBuffer()->GetOwnRange().GetEnd());
- m_pageYOffsets.Add(yOffset);
- }
+ m_pageBreaksStart.Add(lastStartPos);
+ m_pageBreaksEnd.Add(GetRichTextBuffer()->GetOwnRange().GetEnd());
+ m_pageYOffsets.Add(yOffset);
}
}
// The dimensions used for indentation etc. have to be unscaled
// during printing to be correct when scaling is applied.
- // if (!IsPreview())
- m_richTextBuffer->SetScale(scale);
+ // Also, correct the conversions in wxRTC using DC instead of print DC.
+ m_richTextBuffer->SetScale(scale * float(dc->GetPPI().x)/float(ppiPrinterX));
// Calculate margins
int marginLeft = wxRichTextObject::ConvertTenthsMMToPixels(ppiPrinterX, m_marginLeft);