本文整理汇总了C++中KWPage类的典型用法代码示例。如果您正苦于以下问题:C++ KWPage类的具体用法?C++ KWPage怎么用?C++ KWPage使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了KWPage类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: switch
QVariant TextContentsModelImpl::data(int index, Calligra::Components::ContentsModel::Role role) const
{
if(d->entries.count() > 0) {
auto entry = d->entries.at(index);
switch(role) {
case ContentsModel::TitleRole:
return entry.title;
case ContentsModel::LevelRole:
return entry.level;
case ContentsModel::ThumbnailRole: {
if(d->thumbnails.contains(entry.pageNumber)) {
return d->thumbnails.value(entry.pageNumber);
}
if(d->thumbnailSize.isNull()) {
return QImage{};
}
QImage thumb = entry.page->thumbnail(d->thumbnailSize, d->canvas->shapeManager());
d->thumbnails.insert(entry.pageNumber, thumb);
return thumb;
}
case ContentsModel::ContentIndexRole: {
return entry.pageNumber - 1;
}
default:
return QVariant();
}
}
//Fallback behaviour when we don't have a ToC
KWPage page = d->document->pageManager()->page(index + 1);
if(!page.isValid())
return QVariant();
switch(role) {
case ContentsModel::TitleRole:
return QString(i18n("Page %1")).arg(page.pageNumber());
case ContentsModel::LevelRole:
return 0;
case ContentsModel::ThumbnailRole: {
if(d->thumbnails.contains(index)) {
return d->thumbnails.value(index);
}
if(d->thumbnailSize.isNull()) {
return QImage{};
}
QImage thumb = page.thumbnail(d->thumbnailSize, d->canvas->shapeManager());
d->thumbnails.insert(index, thumb);
return thumb;
}
case ContentsModel::ContentIndexRole: {
return index;
}
default:
return QVariant();
}
}
示例2: KoPageLayoutDialog
KWPageSettingsDialog::KWPageSettingsDialog(QWidget *parent, KWDocument *document, const KWPage &page)
: KoPageLayoutDialog(parent, page.pageStyle().pageLayout()),
m_document(document),
m_page(page)
{
Q_ASSERT(document);
showUnitchooser(true);
Q_ASSERT(page.isValid());
m_columns = new KWDocumentColumns(this, m_page.pageStyle().columns());
addPage(m_columns, i18n("Columns"));
m_headerFooter = new KWHeaderFooter(this, m_page.pageStyle());
addPage(m_headerFooter, i18n("Header/Footer"));
showPageSpread(true);
showTextDirection(true); // TODO can we hide this in selected usecases? Use the resource manager bidi-check maybe?
//showApplyToDocument(true); // TODO uncommand when we can handle it.
bool simpleSetup = document->pageCount() == 1
|| (document->pageCount() == 2 && page.pageSide() == KWPage::PageSpread);
if (!simpleSetup) { // if there is one style, its still a simple doc
bool onlyOneStyle = true;
foreach (const KWPage &p, document->pageManager()->pages()) {
if (p.pageStyle() != m_page.pageStyle()) {
onlyOneStyle = false;
break;
}
}
if (onlyOneStyle)
simpleSetup = true;
}
示例3: Q_ASSERT
void KWCopyShape::paint(QPainter &painter, const KoViewConverter &converter, KoShapePaintingContext &paintcontext)
{
Q_ASSERT(m_original);
//paint all child shapes
KoShapeContainer* container = dynamic_cast<KoShapeContainer*>(m_original);
if (container) {
QList<KoShape*> sortedObjects = container->shapes();
sortedObjects.append(m_original);
qSort(sortedObjects.begin(), sortedObjects.end(), KoShape::compareShapeZIndex);
// Do the following to revert the absolute transformation of the
// container that is re-applied in shape->absoluteTransformation()
// later on. The transformation matrix of the container has already
// been applied once before this function is called.
QTransform baseMatrix = container->absoluteTransformation(&converter).inverted() * painter.transform();
KWPage copypage = m_pageManager->page(this);
Q_ASSERT(copypage.isValid());
foreach(KoShape *shape, sortedObjects) {
painter.save();
if (shape != m_original) {
painter.setTransform(shape->absoluteTransformation(&converter) * baseMatrix);
}
KoTextShapeData *data = qobject_cast<KoTextShapeData*>(shape->userData());
if (data == 0) {
shape->paint(painter, converter, paintcontext);
}
else {
// Since the rootArea is shared between the copyShape and the originalShape we need to
// temporary switch the used KoTextPage to be sure the proper page-numbers are displayed.
KWPage originalpage = m_pageManager->page(shape);
Q_ASSERT(originalpage.isValid());
KoTextLayoutRootArea *area = data->rootArea();
bool wasBlockChanges = false;
if (area) {
// We need to block documentChanged() signals emitted cause for example page-variables
// may change there content to result in us marking root-areas dirty for relayout else
// we could end in an infinite relayout ping-pong.
wasBlockChanges = area->documentLayout()->changesBlocked();
area->documentLayout()->setBlockChanges(true);
area->setPage(new KWPage(copypage));
}
shape->paint(painter, converter, paintcontext);
if (area) {
area->setPage(new KWPage(originalpage));
area->documentLayout()->setBlockChanges(wasBlockChanges);
}
}
painter.restore();
if (shape->stroke()) {
painter.save();
painter.setTransform(shape->absoluteTransformation(&converter) * baseMatrix);
shape->stroke()->paint(shape, painter, converter);
painter.restore();
}
}
} else {
示例4: Helper
Helper() {
pageManager = new KWPageManager();
KWPage page = pageManager->appendPage();
KoPageLayout pageLayout = page.pageStyle().pageLayout();
pageLayout.width = 200;
pageLayout.height = 200;
page.pageStyle().setPageLayout(pageLayout);
pageStyle = page.pageStyle();
}
示例5: KoPageLayoutDialog
KWPageSettingsDialog::KWPageSettingsDialog(QWidget *parent, KWDocument *document, const KWPage &page)
: KoPageLayoutDialog(parent, page.pageStyle().pageLayout()),
m_document(document),
m_page(page),
m_pageStyle(page.pageStyle())
{
Q_ASSERT(document);
setStandardButtons(QDialogButtonBox::Ok | QDialogButtonBox::Apply | QDialogButtonBox::Cancel);
connect(buttonBox(), SIGNAL(clicked(QAbstractButton*)),
this, SLOT(slotButtonClicked(QAbstractButton*)));
showUnitchooser(true);
Q_ASSERT(page.isValid());
m_columns = new KWDocumentColumns(this, m_page.pageStyle().columns());
KPageWidgetItem *columnsPage = addPage(m_columns, i18n("Columns"));
QWidget *pageStyleWidget = new QWidget(this);
QHBoxLayout *pageStyleLayout = new QHBoxLayout(pageStyleWidget);
pageStyleLayout->setMargin(0);
KPageWidgetItem *stylePage = addPage(pageStyleWidget, i18n("Style"));
m_pageStylesView = new QListWidget(this);
pageStyleLayout->addWidget(m_pageStylesView, 1);
connect(m_pageStylesView, SIGNAL(currentRowChanged(int)), this, SLOT(pageStyleCurrentRowChanged(int)));
QVBoxLayout *pageStyleLayout2 = new QVBoxLayout();
pageStyleLayout->addLayout(pageStyleLayout2);
m_clonePageStyleButton = new QPushButton(i18n("Clone"), pageStyleWidget);
connect(m_clonePageStyleButton, SIGNAL(clicked()), this, SLOT(pageStyleCloneClicked()));
pageStyleLayout2->addWidget(m_clonePageStyleButton);
m_deletePageStyleButton = new QPushButton(i18n("Delete"), pageStyleWidget);
connect(m_deletePageStyleButton, SIGNAL(clicked()), this, SLOT(pageStyleDeleteClicked()));
pageStyleLayout2->addWidget(m_deletePageStyleButton);
pageStyleLayout2->addStretch();
foreach(KPageWidgetItem *item, QList<KPageWidgetItem*>() << columnsPage << stylePage)
m_pages[item->name()] = item;
reloadPageStyles();
showPageSpread(false); //TODO better would be allow n pages to face rather then only 2
showTextDirection(true); // TODO can we hide this in selected usecases? Use the resource manager bidi-check maybe?
//showApplyToDocument(true); // TODO uncommand when we can handle it.
#if 0
bool simpleSetup = m_document->pageCount() == 1
|| (m_document->pageCount() == 2 && page.pageSide() == KWPage::PageSpread);
if (!simpleSetup) { // if there is one style, its still a simple doc
bool onlyOneStyle = true;
foreach (const KWPage &p, m_document->pageManager()->pages()) {
if (p.pageStyle() != m_page.pageStyle()) {
onlyOneStyle = false;
break;
}
}
if (onlyOneStyle)
simpleSetup = true;
}
示例6:
KWChangePageStyleCommand::KWChangePageStyleCommand(KWDocument *document, KWPage &page, const KWPageStyle &newStyle, KUndo2Command *parent)
: KUndo2Command(kundo2_i18n("Set Page Style"), parent),
m_document(document),
m_newStyle(newStyle),
m_oldStyle(page.pageStyle()),
m_page(page)
{
Q_ASSERT(m_page.isValid());
}
示例7: command1
void TestPageCommands::testInsertPageCommand3() // restore all properties
{
KWDocument document;
KWPageInsertCommand command1(&document, 0);
command1.redo();
KWPage page = command1.page();
KWPageStyle style = page.pageStyle();
style.setHasMainTextFrame(false);
style.setFootnoteDistance(10);
KoPageLayout layout;
layout.width = 400;
layout.height = 300;
layout.leftMargin = 4;
layout.rightMargin = 6;
layout.topMargin = 7;
layout.bottomMargin = 5;
style.setPageLayout(layout);
page.setPageStyle(style);
KWPageInsertCommand command2(&document, 1); // append one page.
command2.redo();
QCOMPARE(command2.page().pageStyle(), style);
QCOMPARE(command2.page().width(), 400.);
// undo and redo, remember order is important
command2.undo();
command1.undo();
command1.redo();
command2.redo();
QVERIFY(command1.page() != page);
QCOMPARE(command1.page().pageNumber(), 1);
KWPageStyle style2 = command1.page().pageStyle();
QCOMPARE(style2, style);
QCOMPARE(style2.hasMainTextFrame(), false);
QCOMPARE(style2.footnoteDistance(), 10.);
KoPageLayout layout2 = style2.pageLayout();
QCOMPARE(layout2, layout);
QCOMPARE(command2.page().pageStyle(), style);
QCOMPARE(command2.page().width(), 400.);
}
示例8: tfs
void TestTextFrameSorting::testRtlSorting()
{
KWTextFrameSet tfs(0);
KWFrame * frame1 = createFrame(QPointF(10, 10), tfs);
KWFrame * frame2 = createFrame(QPointF(120, 10), tfs);
KWPageManager pm;
KWPage page = pm.appendPage();
page.setDirectionHint(KOdfText::RightLeftTopBottom);
QCOMPARE(page.directionHint(), KOdfText::RightLeftTopBottom);
KOdfPageLayoutData layout = page.pageStyle().pageLayout();
layout.width = 200;
page.pageStyle().setPageLayout(layout);
tfs.setPageManager(&pm);
qSort(tfs.m_frames.begin(), tfs.m_frames.end(), KWTextFrameSet::sortTextFrames);
// in RTL columns also sort right-to-left
QCOMPARE(tfs.m_frames[0], frame2);
QCOMPARE(tfs.m_frames[1], frame1);
}
示例9: Q_ASSERT
void KWCanvasBase::clipToDocument(const KoShape *shape, QPointF &move) const
{
Q_ASSERT(shape);
const QPointF absPos = shape->absolutePosition();
const QPointF destination = absPos + move;
qreal bottomOfPage = 0.0;
KWPage page;
foreach (const KWPage &p, m_document->pageManager()->pages()) {
bottomOfPage += p.height();
if (bottomOfPage >= absPos.y())
page = p;
if (bottomOfPage >= destination.y()) {
page = p;
break;
}
}
if (!page.isValid()) { // shape was not in any page to begin with, can't propose anything sane...
move.setX(0);
move.setY(0);
return;
}
QRectF pageRect(page.rect().adjusted(5, 5, -5, -5));
QPainterPath path(shape->absoluteTransformation(0).map(shape->outline()));
QRectF shapeBounds = path.boundingRect();
shapeBounds.moveTopLeft(shapeBounds.topLeft() + move);
if (!shapeBounds.intersects(pageRect)) {
if (shapeBounds.left() > pageRect.right()) // need to move to the left some
move.setX(move.x() + (pageRect.right() - shapeBounds.left()));
else if (shapeBounds.right() < pageRect.left()) // need to move to the right some
move.setX(move.x() + pageRect.left() - shapeBounds.right());
if (shapeBounds.top() > pageRect.bottom()) // need to move up some
move.setY(move.y() + (pageRect.bottom() - shapeBounds.top()));
else if (shapeBounds.bottom() < pageRect.top()) // need to move down some
move.setY(move.y() + pageRect.top() - shapeBounds.bottom());
}
// Also make sure any anchoring restrictions are adhered to
KWFrameLayout::proposeShapeMove(shape, move, page);
}
示例10: open
void KWFrameGeometry::open(KShape *shape)
{
KWPage page = m_state->document()->pageManager()->page(shape);
m_topOfPage = page.offsetInDocument();
m_originalPosition = shape->position();
m_originalSize = shape->size();
QPointF position = shape->absolutePosition(widget.positionSelector->position());
widget.xPos->changeValue(position.x());
widget.yPos->changeValue(position.y() - m_topOfPage);
widget.width->changeValue(m_originalSize.width());
widget.height->changeValue(m_originalSize.height());
if (m_frame == 0) {
// default values for new frames
widget.leftMargin->changeValue(MM_TO_POINT(3));
widget.rightMargin->changeValue(MM_TO_POINT(3));
widget.topMargin->changeValue(MM_TO_POINT(3));
widget.bottomMargin->changeValue(MM_TO_POINT(3));
}
connect(widget.protectSize, SIGNAL(stateChanged(int)),
this, SLOT(protectSizeChanged(int)));
m_originalGeometryLock = shape->isGeometryProtected();
if (m_originalGeometryLock) {
widget.protectSize->setCheckState(Qt::Checked);
KWTextFrame *tf = dynamic_cast<KWTextFrame*>(shape->applicationData());
if (tf && static_cast<KWTextFrameSet*>(tf->frameSet())->textFrameSetType() != KWord::OtherTextFrameSet)
widget.protectSize->setEnabled(false); // auto-generated frame, can't edit
}
connect(widget.xPos, SIGNAL(valueChanged(double)), this, SLOT(updateShape()));
connect(widget.yPos, SIGNAL(valueChanged(double)), this, SLOT(updateShape()));
connect(widget.width, SIGNAL(valueChanged(double)), this, SLOT(updateShape()));
connect(widget.height, SIGNAL(valueChanged(double)), this, SLOT(updateShape()));
}
示例11: insertCommand
void TestPageCommands::testRemovePageCommand3() // test restore all properties
{
KWDocument document;
KWPageInsertCommand insertCommand(&document, 0);
insertCommand.redo();
KWPage page = insertCommand.page();
KWPageStyle style = page.pageStyle();
style.setHasMainTextFrame(false);
style.setFootnoteDistance(10);
KoPageLayout layout;
layout.width = 400;
layout.height = 300;
layout.leftMargin = 4;
layout.rightMargin = 6;
layout.topMargin = 7;
layout.bottomMargin = 5;
style.setPageLayout(layout);
page.setPageStyle(style);
KWPageRemoveCommand command(&document, page);
command.redo();
QVERIFY(!page.isValid());
command.undo();
page = document.pageManager()->begin();
QVERIFY(page.isValid());
QVERIFY(insertCommand.page() != page);
QCOMPARE(page.pageNumber(), 1);
KWPageStyle style2 = page.pageStyle();
QCOMPARE(style2, style);
QCOMPARE(style2.hasMainTextFrame(), false);
QCOMPARE(style2.footnoteDistance(), 10.);
KoPageLayout layout2 = style2.pageLayout();
QCOMPARE(layout2, layout);
QCOMPARE(page.pageStyle(), style);
QCOMPARE(page.width(), 400.);
}
示例12: bfl
void TestFrameLayout::headerPerPage()
{
Helper helper;
m_frames.clear();
KWPage page = helper.pageManager->begin();
KWFrameLayout bfl(helper.pageManager, m_frames);
connect(&bfl, SIGNAL(newFrameSet(KWFrameSet*)), this, SLOT(addFS(KWFrameSet*)));
KWPageStyle myStyle("myStyle");
myStyle.setHeaderPolicy(Words::HFTypeUniform);
helper.pageManager->addPageStyle(myStyle);
KWPage page2 = helper.pageManager->appendPage(myStyle);
QVERIFY(page.pageStyle() != page2.pageStyle());
QCOMPARE(bfl.m_pageStyles.count(), 0);
KWTextFrameSet *fs = bfl.getOrCreate(Words::OddPagesHeaderTextFrameSet, page);
QVERIFY(fs);
QCOMPARE(fs->textFrameSetType(), Words::OddPagesHeaderTextFrameSet);
QCOMPARE(bfl.m_pageStyles.count(), 1);
QVERIFY(bfl.m_pageStyles.contains(page.pageStyle()));
KWFrameLayout::FrameSets fsets = bfl.m_pageStyles[page.pageStyle()];
QCOMPARE(fsets.oddHeaders, fs);
QCOMPARE(fsets.evenHeaders, (void*) 0);
QCOMPARE(fsets.oddFooters, (void*) 0);
QCOMPARE(fsets.evenFooters, (void*) 0);
KWTextFrameSet *fs2 = bfl.getOrCreate(Words::OddPagesHeaderTextFrameSet, page2);
QVERIFY(fs2);
QCOMPARE(fs2->textFrameSetType(), Words::OddPagesHeaderTextFrameSet);
QVERIFY(fs != fs2);
QCOMPARE(bfl.getOrCreate(Words::OddPagesHeaderTextFrameSet, page2), fs2);
QCOMPARE(bfl.getOrCreate(Words::OddPagesHeaderTextFrameSet, page), fs);
QCOMPARE(bfl.m_pageStyles.count(), 2);
QVERIFY(bfl.m_pageStyles.contains(page.pageStyle()));
QVERIFY(bfl.m_pageStyles.contains(page2.pageStyle()));
fsets = bfl.m_pageStyles[page.pageStyle()];
QCOMPARE(fsets.oddHeaders, fs);
QCOMPARE(fsets.evenHeaders, (void*) 0);
QCOMPARE(fsets.oddFooters, (void*) 0);
QCOMPARE(fsets.evenFooters, (void*) 0);
KWFrameLayout::FrameSets fsets2 = bfl.m_pageStyles[page2.pageStyle()];
QCOMPARE(fsets2.oddHeaders, fs2);
QCOMPARE(fsets2.evenHeaders, (void*) 0);
QCOMPARE(fsets2.oddFooters, (void*) 0);
QCOMPARE(fsets2.evenFooters, (void*) 0);
}
示例13: foreach
style5.setColumns(columns);
styles.insert(style5.name(), style5);
KWPageManager manager;
foreach (const QString &styleName, pages) {
QVERIFY(styles.contains(styleName));
manager.appendPage(styles[styleName]);
}
m_frames.clear();
KWTextFrameSet tfs(0, (Words::TextFrameSetType) frameSetType);
m_frames << &tfs;
KWFrameLayout frameLayout(&manager, m_frames);
connect(&frameLayout, SIGNAL(newFrameSet(KWFrameSet*)), this, SLOT(addFS(KWFrameSet*)));
KWPage page = manager.page(pageNumber);
QVERIFY(page.isValid());
tfs.setPageStyle(page.pageStyle());
frameLayout.createNewFramesForPage(pageNumber);
QCOMPARE(tfs.frameCount(), expectedFrameCount);
foreach(KoShape *shape, tfs.shapes()) {
QVERIFY (page.rect().contains(shape->position()));
}
}
void TestFrameLayout::testCopyFramesForPage()
{
Helper helper;
m_frames.clear();
KWPage page = helper.pageManager->begin();
示例14: while
QList<KWViewMode::ViewMap> KWViewModeNormal::mapExposedRects(const QRectF &viewRect, KoViewConverter *viewConverter) const
{
QList<ViewMap> answer;
if (!viewConverter) return answer;
#if 1
if (m_pageTops.isEmpty())
return answer;
KWPage page = m_pageManager->begin();
const int pageOffset = page.pageNumber();
// Perform a binary search for page-index using our m_pageTops cache.
int begin = 0;
int end = m_pageTops.count() - 1;
int index = 0;
const qreal value = viewConverter->viewToDocument(viewRect.topLeft()).y();
if (m_pageTops.value(end) <= value) { // check extremes. Only end is needed since begin is zero.
begin = end;
index = end;
}
while (end - begin > 1) {
index = begin + (end - begin) / 2;
qreal diff = m_pageTops.value(index) - value;
if (diff < 0)
begin = index;
else if (diff > 0)
end = index;
else
break;
}
// index is now the number of the first possible page that can
// contain the viewRect. The next step is to find the
// corresponding Page. Since we have no way to get to the Nth
// page directly we have to enumerate them from the beginning.
//
// We use 1 since we might hit a pagespread in the binary search,
// so start one page early.
while (index > 1) {
page = page.next();
--index;
}
// From here we loop through some more pages after the found one
// and see if they intersect with the page in question. When we
// have two pages in row that don't intersect we break the loop.
qreal offsetX = 0.0;
int emptyPages = 0;
for(; page.isValid(); page = page.next()) {
Q_ASSERT_X(page.pageNumber()-pageOffset < m_pageTops.count(), __FUNCTION__,
QString("Pagemanager has more pages than viewmode (%1>%2 with pageOffset=%3 and pageNumber=%4 and pageCount=%5). Make sure you add pages via the document!")
.arg(page.pageNumber()-pageOffset).arg(m_pageTops.count())
.arg(pageOffset).arg(page.pageNumber()).arg(m_pageManager->pageCount()).toLocal8Bit());
// Some invariants
const QRectF pageRect = page.rect();
const qreal offsetY = m_pageTops[page.pageNumber() - pageOffset] - pageRect.top();
bool pageIntersects = false;
// 1. First handle the page itself.
const QRectF zoomedPage = viewConverter->documentToView(pageRect);
ViewMap vm;
vm.page = page;
//kDebug(32003) <<"page" << page.pageNumber();
vm.distance = viewConverter->documentToView(QPointF(offsetX, offsetY));
const QRectF targetPage(zoomedPage.x() + vm.distance.x(), zoomedPage.y() + vm.distance.y(),
zoomedPage.width(), zoomedPage.height());
QRectF intersection = targetPage.intersect(viewRect);
if (! intersection.isEmpty()) {
intersection.moveTopLeft(intersection.topLeft() - vm.distance);
vm.clipRect = intersection.toRect();
answer.append(vm);
pageIntersects = true;
}
// 2. Then handle the annotation area if annotations are active.
//
// The reason we don't do them together with the page
// itself is because the pages have a gap between them, but
// the annotation area should be unbroken.
//
// NOTE: 'annotation' below means the annotation area.
//
// FIXME: We should only do this if the annotation area is
// actually shown. How can we inside the KWViewMode
// know if annotations are active?
if (1 /* annotations are shown */) {
const QRectF annotationRect = pageRect.adjusted(page.width(), 0,
KWCanvasBase::AnnotationAreaWidth, GAP);
const QRectF zoomedAnnotation = viewConverter->documentToView(annotationRect);
ViewMap vm2;
vm2.page = page;
vm2.distance = viewConverter->documentToView(QPointF(offsetX, offsetY));
const QRectF targetAnnotation(zoomedAnnotation.x() + vm2.distance.x(),
zoomedAnnotation.y() + vm2.distance.y(),
zoomedAnnotation.width(), zoomedAnnotation.height());
intersection = targetAnnotation.intersect(viewRect);
//.........这里部分代码省略.........
示例15: while
QList<KWViewMode::ViewMap> KWViewModeNormal::clipRectToDocument(const QRect &viewRect) const
{
QList<ViewMap> answer;
if (m_pageTops.isEmpty())
return answer;
KWPage page = m_pageManager->begin();
qreal offsetX = 0.0;
const int pageOffset = page.pageNumber();
int begin = 0;
int end = m_pageTops.count() - 1;
int index = 0;
const qreal value = m_viewConverter->viewToDocument(viewRect.topLeft()).y();
if (m_pageTops.value(end) <= value) { // check extremes. Only end is needed since begin is zero.
begin = end;
index = end;
}
while (end - begin > 1) { // binary search for page-index using our m_pageTops cache.
index = begin + (end - begin) / 2;
qreal diff = m_pageTops.value(index) - value;
if (diff < 0)
begin = index;
else if (diff > 0)
end = index;
else
break;
}
while (index > 1) { // 1 since we might hit a pagespread in the binary search, so start one page early
page = page.next();
--index;
if (page.pageSide() == KWPage::PageSpread)
--index;
}
int emptyPages = 0;
while (page.isValid()) {
#ifndef NDEBUG
if (page.pageNumber() - pageOffset >= m_pageTops.count()) {
kWarning(32003) << "ERROR; pagemanager has more pages than viewmode ("
<< m_pageManager->pageCount() << ">" << m_pageTops.count()
<< "). Make sure you add pages via the document!";
break;
}
#endif
const QRectF pageRect = page.rect();
const QRectF zoomedPage = m_viewConverter->documentToView(pageRect);
ViewMap vm;
vm.page = page;
//kDebug(32003) <<"page" << page.pageNumber();
const qreal offsetY = m_pageTops[page.pageNumber() - pageOffset] - pageRect.top();
vm.distance = m_viewConverter->documentToView(QPointF(offsetX, offsetY));
const QRectF targetPage(zoomedPage.x() + vm.distance.x(), zoomedPage.y() + vm.distance.y(),
zoomedPage.width() , zoomedPage.height());
QRectF intersection = targetPage.intersect(viewRect);
if (! intersection.isEmpty()) {
intersection.moveTopLeft(intersection.topLeft() - vm.distance);
vm.clipRect = intersection.toRect();
answer.append(vm);
emptyPages = 0;
} else {
emptyPages++;
}
if (emptyPages > 2) // Since we show at max 2 pages side by side this is an easy rule
break;
if (m_pageSpreadMode) {
if (page.pageSide() == KWPage::Left)
offsetX = page.width() + GAP;
else
offsetX = 0.0;
}
page = page.next();
}
return answer;
}