QGIS API Documentation 3.39.0-Master (d0dedde5474)
|
A manager for a collection of pages in a layout. More...
#include <qgslayoutpagecollection.h>
Public Slots | |
void | redraw () |
Triggers a redraw for all pages. | |
Signals | |
void | changed () |
Emitted when pages are added or removed from the collection. | |
void | pageAboutToBeRemoved (int pageNumber) |
Emitted just before a page is removed from the collection. | |
Public Member Functions | |
QgsLayoutPageCollection (QgsLayout *layout) | |
Constructor for QgsLayoutItemPage, with the specified parent layout. | |
~QgsLayoutPageCollection () override | |
void | addPage (QgsLayoutItemPage *page) |
Adds a page to the collection. | |
void | beginPageSizeChange () |
Should be called before changing any page item sizes, and followed by a call to endPageSizeChange(). | |
void | clear () |
Removes all pages from the collection. | |
void | deletePage (int pageNumber) |
Deletes a page from the collection. | |
void | deletePage (QgsLayoutItemPage *page) |
Deletes a page from the collection. | |
void | endPageSizeChange () |
Should be called after changing any page item sizes, and preceded by a call to beginPageSizeChange(). | |
QgsLayoutItemPage * | extendByNewPage () |
Adds a new page to the end of the collection. | |
QgsLayoutGuideCollection & | guides () |
Returns a reference to the collection's guide collection, which manages page snap guides. | |
const QgsLayoutGuideCollection & | guides () const |
Returns a reference to the collection's guide collection, which manages page snap guides. | |
bool | hasUniformPageSizes () const |
Returns true if the layout has uniform page sizes, e.g. | |
void | insertPage (QgsLayoutItemPage *page, int beforePage) |
Inserts a page into a specific position in the collection. | |
QList< QgsLayoutItem * > | itemsOnPage (int page) const |
Returns a list of layout items on the specified page index. | |
template<class T > | |
void | itemsOnPage (QList< T * > &itemList, int page) const |
Returns layout items of a specific type on a specified page. | |
QgsLayout * | layout () override |
Returns the layout the object belongs to. | |
QSizeF | maximumPageSize () const |
Returns the maximum size of any page in the collection, by area. | |
double | maximumPageWidth () const |
Returns the maximum width of pages in the collection. | |
QgsLayoutItemPage * | page (int pageNumber) |
Returns a specific page (by pageNumber) from the collection. | |
const QgsLayoutItemPage * | page (int pageNumber) const |
Returns a specific page (by pageNumber) from the collection. | |
QgsLayoutItemPage * | pageAtPoint (QPointF point) const |
Returns the page at a specified point (in layout coordinates). | |
int | pageCount () const |
Returns the number of pages in the collection. | |
bool | pageIsEmpty (int page) const |
Returns whether a given page index is empty, ie, it contains no items except for the background paper item. | |
int | pageNumber (QgsLayoutItemPage *page) const |
Returns the page number for the specified page, or -1 if the page is not contained in the collection. | |
int | pageNumberForPoint (QPointF point) const |
Returns the page number corresponding to a point in the layout (in layout units). | |
QgsLayoutPoint | pagePositionToAbsolute (int page, const QgsLayoutPoint &position) const |
Converts a position on a page to an absolute position in (maintaining the units from the input position). | |
QPointF | pagePositionToLayoutPosition (int page, const QgsLayoutPoint &position) const |
Converts a position on a page to an absolute position in layout coordinates. | |
QList< QgsLayoutItemPage * > | pages () |
Returns a list of pages in the collection. | |
double | pageShadowWidth () const |
Returns the size of the page shadow, in layout units. | |
Q_DECL_DEPRECATED const QgsFillSymbol * | pageStyleSymbol () const |
Returns the symbol to use for drawing pages in the collection. | |
QPointF | positionOnPage (QPointF point) const |
Returns the position within a page of a point in the layout (in layout units). | |
int | predictPageNumberForPoint (QPointF point) const |
Returns the theoretical page number corresponding to a point in the layout (in layout units), assuming that enough pages exist in the layout to cover that point. | |
bool | readXml (const QDomElement &collectionElement, const QDomDocument &document, const QgsReadWriteContext &context) override |
Sets the collection's state from a DOM element. | |
void | reflow () |
Forces the page collection to reflow the arrangement of pages, e.g. | |
void | resizeToContents (const QgsMargins &margins, Qgis::LayoutUnit marginUnits) |
Resizes the layout to a single page which fits the current contents of the layout. | |
void | setPageStyleSymbol (QgsFillSymbol *symbol) |
Sets the symbol to use for drawing pages in the collection. | |
bool | shouldExportPage (int page) const |
Returns whether the specified page number should be included in exports of the layouts. | |
double | spaceBetweenPages () const |
Returns the space between pages, in layout units. | |
QString | stringType () const override |
Returns the object type as a string. | |
QgsLayoutItemPage * | takePage (QgsLayoutItemPage *page) |
Takes a page from the collection, returning ownership of the page to the caller. | |
QList< int > | visiblePageNumbers (const QRectF ®ion) const |
Returns a list of the page numbers which are visible within the specified region (in layout coordinates). | |
QList< QgsLayoutItemPage * > | visiblePages (const QRectF ®ion) const |
Returns a list of the pages which are visible within the specified region (in layout coordinates). | |
bool | writeXml (QDomElement &parentElement, QDomDocument &document, const QgsReadWriteContext &context) const override |
Stores the collection's state in a DOM element. | |
Public Member Functions inherited from QgsLayoutSerializableObject | |
QgsAbstractLayoutUndoCommand * | createCommand (const QString &text, int id, QUndoCommand *parent=nullptr) override |
Creates a new layout undo command with the specified text and parent. | |
Public Member Functions inherited from QgsLayoutUndoObjectInterface | |
virtual | ~QgsLayoutUndoObjectInterface ()=default |
Friends | |
class | QgsLayoutPageCollectionUndoCommand |
A manager for a collection of pages in a layout.
Definition at line 39 of file qgslayoutpagecollection.h.
|
explicit |
Constructor for QgsLayoutItemPage, with the specified parent layout.
Definition at line 26 of file qgslayoutpagecollection.cpp.
|
override |
Definition at line 34 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::addPage | ( | QgsLayoutItemPage * | page | ) |
Adds a page to the collection.
Ownership of the page is transferred to the collection, and the page will automatically be added to the collection's layout() (there is no need to manually add the page item to the layout). The page will be added after all pages currently contained in the collection.
Calling addPage() automatically triggers a reflow() of pages.
Definition at line 573 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::beginPageSizeChange | ( | ) |
Should be called before changing any page item sizes, and followed by a call to endPageSizeChange().
If page size changes are wrapped in these calls, then items will maintain their same relative position on pages after the page sizes are updated.
Definition at line 63 of file qgslayoutpagecollection.cpp.
|
signal |
Emitted when pages are added or removed from the collection.
void QgsLayoutPageCollection::clear | ( | ) |
Removes all pages from the collection.
Definition at line 707 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::deletePage | ( | int | pageNumber | ) |
Deletes a page from the collection.
The page will automatically be removed from the collection's layout().
Page numbers in collections begin at 0 - so a pageNumber of 0 will delete the first page in the collection.
Calling deletePage() automatically triggers a reflow() of pages.
Definition at line 636 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::deletePage | ( | QgsLayoutItemPage * | page | ) |
Deletes a page from the collection.
The page will automatically be removed from the collection's layout().
Calling deletePage() automatically triggers a reflow() of pages.
Definition at line 670 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::endPageSizeChange | ( | ) |
Should be called after changing any page item sizes, and preceded by a call to beginPageSizeChange().
If page size changes are wrapped in these calls, then items will maintain their same relative position on pages after the page sizes are updated.
Definition at line 78 of file qgslayoutpagecollection.cpp.
QgsLayoutItemPage * QgsLayoutPageCollection::extendByNewPage | ( | ) |
Adds a new page to the end of the collection.
This page will inherit the same size as the current final page in the collection.
The newly created page will be returned.
Definition at line 584 of file qgslayoutpagecollection.cpp.
QgsLayoutGuideCollection & QgsLayoutPageCollection::guides | ( | ) |
Returns a reference to the collection's guide collection, which manages page snap guides.
Definition at line 437 of file qgslayoutpagecollection.cpp.
const QgsLayoutGuideCollection & QgsLayoutPageCollection::guides | ( | ) | const |
Returns a reference to the collection's guide collection, which manages page snap guides.
Definition at line 442 of file qgslayoutpagecollection.cpp.
bool QgsLayoutPageCollection::hasUniformPageSizes | ( | ) | const |
Returns true
if the layout has uniform page sizes, e.g.
all pages are the same size.
This method does not consider differing units as non-uniform sizes, only the actual physical size of the pages.
Definition at line 148 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::insertPage | ( | QgsLayoutItemPage * | page, |
int | beforePage | ||
) |
Inserts a page into a specific position in the collection.
Ownership of the page is transferred to the collection, and the page will automatically be added to the collection's layout() (there is no need to manually add the page item to the layout).
The page will be added after before the page number specified by beforePage. (Page numbers in collections begin at 0 - so a beforePage of 0 will insert the page before all existing pages).
Calling insertPage() automatically triggers a reflow() of pages.
Definition at line 596 of file qgslayoutpagecollection.cpp.
QList< QgsLayoutItem * > QgsLayoutPageCollection::itemsOnPage | ( | int | page | ) | const |
Returns a list of layout items on the specified page index.
Definition at line 531 of file qgslayoutpagecollection.cpp.
|
inline |
Returns layout items of a specific type on a specified page.
Definition at line 124 of file qgslayoutpagecollection.h.
|
overridevirtual |
Returns the layout the object belongs to.
Implements QgsLayoutSerializableObject.
Definition at line 456 of file qgslayoutpagecollection.cpp.
QSizeF QgsLayoutPageCollection::maximumPageSize | ( | ) | const |
Returns the maximum size of any page in the collection, by area.
The returned value is in layout units.
Definition at line 131 of file qgslayoutpagecollection.cpp.
double QgsLayoutPageCollection::maximumPageWidth | ( | ) | const |
Returns the maximum width of pages in the collection.
The returned value is in layout units.
Definition at line 121 of file qgslayoutpagecollection.cpp.
QgsLayoutItemPage * QgsLayoutPageCollection::page | ( | int | pageNumber | ) |
Returns a specific page (by pageNumber) from the collection.
Internal page numbering starts at 0 - so a pageNumber of 0 corresponds to the first page in the collection. A nullptr
is returned if an invalid page number is specified.
Definition at line 471 of file qgslayoutpagecollection.cpp.
const QgsLayoutItemPage * QgsLayoutPageCollection::page | ( | int | pageNumber | ) | const |
Returns a specific page (by pageNumber) from the collection.
Internal page numbering starts at 0 - so a pageNumber of 0 corresponds to the first page in the collection. A nullptr
is returned if an invalid page number is specified.
Definition at line 476 of file qgslayoutpagecollection.cpp.
|
signal |
Emitted just before a page is removed from the collection.
Page numbers in collections begin at 0 - so a page number of 0 indicates the first page.
QgsLayoutItemPage * QgsLayoutPageCollection::pageAtPoint | ( | QPointF | point | ) | const |
Returns the page at a specified point (in layout coordinates).
If no page exists at point, nullptr
will be returned.
Definition at line 218 of file qgslayoutpagecollection.cpp.
int QgsLayoutPageCollection::pageCount | ( | ) | const |
Returns the number of pages in the collection.
Definition at line 466 of file qgslayoutpagecollection.cpp.
bool QgsLayoutPageCollection::pageIsEmpty | ( | int | page | ) | const |
Returns whether a given page index is empty, ie, it contains no items except for the background paper item.
Definition at line 512 of file qgslayoutpagecollection.cpp.
int QgsLayoutPageCollection::pageNumber | ( | QgsLayoutItemPage * | page | ) | const |
Returns the page number for the specified page, or -1 if the page is not contained in the collection.
Definition at line 481 of file qgslayoutpagecollection.cpp.
int QgsLayoutPageCollection::pageNumberForPoint | ( | QPointF | point | ) | const |
Returns the page number corresponding to a point in the layout (in layout units).
Page numbers in collections begin at 0 - so a page number of 0 indicates the first page.
Definition at line 166 of file qgslayoutpagecollection.cpp.
QgsLayoutPoint QgsLayoutPageCollection::pagePositionToAbsolute | ( | int | page, |
const QgsLayoutPoint & | position | ||
) | const |
Converts a position on a page to an absolute position in (maintaining the units from the input position).
Definition at line 243 of file qgslayoutpagecollection.cpp.
QPointF QgsLayoutPageCollection::pagePositionToLayoutPosition | ( | int | page, |
const QgsLayoutPoint & | position | ||
) | const |
Converts a position on a page to an absolute position in layout coordinates.
\
Definition at line 233 of file qgslayoutpagecollection.cpp.
QList< QgsLayoutItemPage * > QgsLayoutPageCollection::pages | ( | ) |
Returns a list of pages in the collection.
Definition at line 461 of file qgslayoutpagecollection.cpp.
double QgsLayoutPageCollection::pageShadowWidth | ( | ) | const |
Returns the size of the page shadow, in layout units.
Definition at line 289 of file qgslayoutpagecollection.cpp.
const QgsFillSymbol * QgsLayoutPageCollection::pageStyleSymbol | ( | ) | const |
Returns the symbol to use for drawing pages in the collection.
Definition at line 58 of file qgslayoutpagecollection.cpp.
QPointF QgsLayoutPageCollection::positionOnPage | ( | QPointF | point | ) | const |
Returns the position within a page of a point in the layout (in layout units).
Definition at line 254 of file qgslayoutpagecollection.cpp.
int QgsLayoutPageCollection::predictPageNumberForPoint | ( | QPointF | point | ) | const |
Returns the theoretical page number corresponding to a point in the layout (in layout units), assuming that enough pages exist in the layout to cover that point.
If there are insufficient pages currently in the layout, this method will assume that extra "imaginary" pages have been added at the end of the layout until that point is reached. These imaginary pages will inherit the size of the existing final page in the layout.
Page numbers in collections begin at 0 - so a page number of 0 indicates the first page.
Definition at line 184 of file qgslayoutpagecollection.cpp.
|
overridevirtual |
Sets the collection's state from a DOM element.
collectionElement is the DOM node corresponding to the collection.
Implements QgsLayoutSerializableObject.
Definition at line 385 of file qgslayoutpagecollection.cpp.
|
slot |
Triggers a redraw for all pages.
Definition at line 447 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::reflow | ( | ) |
Forces the page collection to reflow the arrangement of pages, e.g.
to account for page size/orientation change.
Definition at line 105 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::resizeToContents | ( | const QgsMargins & | margins, |
Qgis::LayoutUnit | marginUnits | ||
) |
Resizes the layout to a single page which fits the current contents of the layout.
Calling this method resets the number of pages to 1, with the size set to the minimum size required to fit all existing layout items. Items will also be repositioned so that the new top-left bounds of the layout is at the point (marginLeft, marginTop). An optional margin can be specified.
Definition at line 294 of file qgslayoutpagecollection.cpp.
void QgsLayoutPageCollection::setPageStyleSymbol | ( | QgsFillSymbol * | symbol | ) |
Sets the symbol to use for drawing pages in the collection.
Ownership is not transferred, and a copy of the symbol is created internally.
Definition at line 44 of file qgslayoutpagecollection.cpp.
bool QgsLayoutPageCollection::shouldExportPage | ( | int | page | ) | const |
Returns whether the specified page number should be included in exports of the layouts.
true
unless the layout is being currently exported – it cannot be used in advance to determine whether a given page will be exported!Definition at line 547 of file qgslayoutpagecollection.cpp.
double QgsLayoutPageCollection::spaceBetweenPages | ( | ) | const |
Returns the space between pages, in layout units.
Definition at line 284 of file qgslayoutpagecollection.cpp.
|
inlineoverridevirtual |
Returns the object type as a string.
This string must be a unique, single word, character only representation of the item type, eg "LayoutScaleBar"
Implements QgsLayoutSerializableObject.
Definition at line 53 of file qgslayoutpagecollection.h.
QgsLayoutItemPage * QgsLayoutPageCollection::takePage | ( | QgsLayoutItemPage * | page | ) |
Takes a page from the collection, returning ownership of the page to the caller.
Definition at line 727 of file qgslayoutpagecollection.cpp.
QList< int > QgsLayoutPageCollection::visiblePageNumbers | ( | const QRectF & | region | ) | const |
Returns a list of the page numbers which are visible within the specified region (in layout coordinates).
Definition at line 498 of file qgslayoutpagecollection.cpp.
QList< QgsLayoutItemPage * > QgsLayoutPageCollection::visiblePages | ( | const QRectF & | region | ) | const |
Returns a list of the pages which are visible within the specified region (in layout coordinates).
Definition at line 486 of file qgslayoutpagecollection.cpp.
|
overridevirtual |
Stores the collection's state in a DOM element.
The parentElement should refer to the parent layout's DOM element.
Implements QgsLayoutSerializableObject.
Definition at line 367 of file qgslayoutpagecollection.cpp.
|
friend |
Definition at line 430 of file qgslayoutpagecollection.h.