QGIS/python/gui/layout/qgslayoutview.sip.in

615 lines
14 KiB
Plaintext

/************************************************************************
* This file has been generated automatically from *
* *
* src/gui/layout/qgslayoutview.h *
* *
* Do not edit manually ! Edit header and run scripts/sipify.pl again *
************************************************************************/
class QgsLayoutView: QGraphicsView
{
%Docstring
A graphical widget to display and interact with QgsLayouts.
QgsLayoutView manages the layout interaction tools and mouse/key events.
.. versionadded:: 3.0
%End
%TypeHeaderCode
#include "qgslayoutview.h"
%End
public:
enum ClipboardOperation
{
ClipboardCut,
ClipboardCopy,
};
enum PasteMode
{
PasteModeCursor,
PasteModeCenter,
PasteModeInPlace,
};
QgsLayoutView( QWidget *parent /TransferThis/ = 0 );
%Docstring
Constructor for QgsLayoutView.
%End
~QgsLayoutView();
QgsLayout *currentLayout();
%Docstring
Returns the current layout associated with the view.
.. seealso:: :py:func:`setCurrentLayout`
.. seealso:: :py:func:`layoutSet`
%End
void setCurrentLayout( QgsLayout *layout /KeepReference/ );
%Docstring
Sets the current ``layout`` to edit in the view.
.. seealso:: :py:func:`currentLayout`
.. seealso:: :py:func:`layoutSet`
%End
QgsLayoutViewTool *tool();
%Docstring
Returns the currently active tool for the view.
.. seealso:: :py:func:`setTool`
%End
void setTool( QgsLayoutViewTool *tool );
%Docstring
Sets the ``tool`` currently being used in the view.
.. seealso:: :py:func:`unsetTool`
.. seealso:: :py:func:`tool`
%End
void unsetTool( QgsLayoutViewTool *tool );
%Docstring
Unsets the current view tool, if it matches the specified ``tool``.
This is called from destructor of view tools to make sure
that the tool won't be used any more.
You don't have to call it manually, QgsLayoutViewTool takes care of it.
%End
void setPreviewModeEnabled( bool enabled );
%Docstring
Sets whether a preview effect should be used to alter the view's appearance.
:param enabled: Set to true to enable the preview effect on the view.
.. seealso:: :py:func:`setPreviewMode`
%End
bool previewModeEnabled() const;
%Docstring
Returns true if a preview effect is being used to alter the view's appearance.
.. seealso:: :py:func:`setPreviewModeEnabled`
%End
void setPreviewMode( QgsPreviewEffect::PreviewMode mode );
%Docstring
Sets the preview ``mode`` which should be used to modify the view's appearance. Preview modes are only used
if previewModeEnabled() is true.
.. seealso:: :py:func:`setPreviewModeEnabled`
.. seealso:: :py:func:`previewMode`
%End
QgsPreviewEffect::PreviewMode previewMode() const;
%Docstring
Returns the preview mode which may be used to modify the view's appearance. Preview modes are only used
if previewModeEnabled() is true.
.. seealso:: :py:func:`setPreviewMode`
.. seealso:: :py:func:`previewModeEnabled`
%End
void scaleSafe( double scale );
%Docstring
Scales the view in a safe way, by limiting the acceptable range
of the scale applied. The ``scale`` parameter specifies the zoom factor to scale the view by.
%End
void setZoomLevel( double level );
%Docstring
Sets the zoom ``level`` for the view, where a zoom level of 1.0 corresponds to 100%.
%End
void setHorizontalRuler( QgsLayoutRuler *ruler );
%Docstring
Sets a horizontal ``ruler`` to synchronize with the view state.
.. seealso:: :py:func:`setVerticalRuler`
%End
void setVerticalRuler( QgsLayoutRuler *ruler );
%Docstring
Sets a vertical ``ruler`` to synchronize with the view state.
.. seealso:: :py:func:`setHorizontalRuler`
%End
void setMenuProvider( QgsLayoutViewMenuProvider *provider /Transfer/ );
%Docstring
Sets a ``provider`` for context menus. Ownership of the provider is transferred to the view.
.. seealso:: :py:func:`menuProvider`
%End
QgsLayoutViewMenuProvider *menuProvider() const;
%Docstring
Returns the provider for context menus. Returned value may be None if no provider is set.
.. seealso:: :py:func:`setMenuProvider`
%End
int currentPage() const;
%Docstring
Returns the page visible in the view. This method
considers the page at the center of the view as the current visible
page.
.. seealso:: :py:func:`pageChanged`
%End
QList< QgsLayoutItemPage * > visiblePages() const;
%Docstring
Returns a list of page items which are currently visible in the view.
.. seealso:: :py:func:`visiblePageNumbers`
%End
QList< int > visiblePageNumbers() const;
%Docstring
Returns a list of page numbers for pages which are currently visible in the view.
.. seealso:: :py:func:`visiblePages`
%End
void alignSelectedItems( QgsLayoutAligner::Alignment alignment );
%Docstring
Aligns all selected items using the specified ``alignment``.
.. seealso:: :py:func:`distributeSelectedItems`
.. seealso:: :py:func:`resizeSelectedItems`
%End
void distributeSelectedItems( QgsLayoutAligner::Distribution distribution );
%Docstring
Distributes all selected items using the specified ``distribution``.
.. seealso:: :py:func:`alignSelectedItems`
.. seealso:: :py:func:`resizeSelectedItems`
%End
void resizeSelectedItems( QgsLayoutAligner::Resize resize );
%Docstring
Resizes all selected items using the specified ``resize`` mode.
.. seealso:: :py:func:`alignSelectedItems`
.. seealso:: :py:func:`distributeSelectedItems`
%End
void copySelectedItems( ClipboardOperation operation );
%Docstring
Cuts or copies the selected items, respecting the specified ``operation``.
.. seealso:: :py:func:`copyItems`
.. seealso:: :py:func:`pasteItems`
%End
void copyItems( const QList< QgsLayoutItem * > &items, ClipboardOperation operation );
%Docstring
Cuts or copies the a list of ``items``, respecting the specified ``operation``.
.. seealso:: :py:func:`copySelectedItems`
.. seealso:: :py:func:`pasteItems`
%End
QList< QgsLayoutItem * > pasteItems( PasteMode mode );
%Docstring
Pastes items from clipboard, using the specified ``mode``.
A list of pasted items is returned.
.. seealso:: :py:func:`copySelectedItems`
.. seealso:: :py:func:`hasItemsInClipboard`
%End
QList< QgsLayoutItem * > pasteItems( QPointF layoutPoint );
%Docstring
Pastes items from clipboard, at the specified ``layoutPoint``,
in layout units.
A list of pasted items is returned.
.. seealso:: :py:func:`copySelectedItems`
.. seealso:: :py:func:`hasItemsInClipboard`
%End
bool hasItemsInClipboard() const;
%Docstring
Returns true if the current clipboard contains layout items.
.. seealso:: :py:func:`pasteItems`
%End
QPointF deltaForKeyEvent( QKeyEvent *event );
%Docstring
Returns the delta (in layout coordinates) by which to move items
for the given key ``event``.
%End
void setSectionLabel( const QString &label );
%Docstring
Sets a section ``label``, to display above the first page shown in the
view.
%End
public slots:
void zoomFull();
%Docstring
Zooms the view to the full extent of the layout.
.. seealso:: :py:func:`zoomIn`
.. seealso:: :py:func:`zoomOut`
.. seealso:: :py:func:`zoomActual`
%End
void zoomWidth();
%Docstring
Zooms the view to the full width of the layout.
.. seealso:: :py:func:`zoomIn`
.. seealso:: :py:func:`zoomOut`
.. seealso:: :py:func:`zoomActual`
%End
void zoomIn();
%Docstring
Zooms in to the view by a preset amount.
.. seealso:: :py:func:`zoomFull`
.. seealso:: :py:func:`zoomOut`
.. seealso:: :py:func:`zoomActual`
%End
void zoomOut();
%Docstring
Zooms out of the view by a preset amount.
.. seealso:: :py:func:`zoomFull`
.. seealso:: :py:func:`zoomIn`
.. seealso:: :py:func:`zoomActual`
%End
void zoomActual();
%Docstring
Zooms to the actual size of the layout.
.. seealso:: :py:func:`zoomFull`
.. seealso:: :py:func:`zoomIn`
.. seealso:: :py:func:`zoomOut`
%End
void emitZoomLevelChanged();
void selectAll();
%Docstring
Selects all items in the view.
.. seealso:: :py:func:`deselectAll`
.. seealso:: :py:func:`invertSelection`
.. seealso:: :py:func:`selectNextItemAbove`
.. seealso:: :py:func:`selectNextItemBelow`
%End
void deselectAll();
%Docstring
Deselects all items in the view.
.. seealso:: :py:func:`selectAll`
.. seealso:: :py:func:`invertSelection`
%End
void invertSelection();
%Docstring
Inverts the current selection, selecting deselected items
and deselecting and selected items.
.. seealso:: :py:func:`selectAll`
.. seealso:: :py:func:`deselectAll`
%End
void selectNextItemAbove();
%Docstring
Selects the next item above the existing selection, by item z order.
.. seealso:: :py:func:`selectNextItemBelow`
.. seealso:: :py:func:`selectAll`
.. seealso:: :py:func:`deselectAll`
%End
void selectNextItemBelow();
%Docstring
Selects the next item below the existing selection, by item z order.
.. seealso:: :py:func:`selectNextItemAbove`
.. seealso:: :py:func:`selectAll`
.. seealso:: :py:func:`deselectAll`
%End
void raiseSelectedItems();
%Docstring
Raises the selected items up the z-order.
.. seealso:: :py:func:`lowerSelectedItems`
.. seealso:: :py:func:`moveSelectedItemsToTop`
.. seealso:: :py:func:`moveSelectedItemsToBottom`
%End
void lowerSelectedItems();
%Docstring
Lowers the selected items down the z-order.
.. seealso:: :py:func:`raiseSelectedItems`
.. seealso:: :py:func:`moveSelectedItemsToTop`
.. seealso:: :py:func:`moveSelectedItemsToBottom`
%End
void moveSelectedItemsToTop();
%Docstring
Raises the selected items to the top of the z-order.
.. seealso:: :py:func:`raiseSelectedItems`
.. seealso:: :py:func:`lowerSelectedItems`
.. seealso:: :py:func:`moveSelectedItemsToBottom`
%End
void moveSelectedItemsToBottom();
%Docstring
Lowers the selected items to the bottom of the z-order.
.. seealso:: :py:func:`raiseSelectedItems`
.. seealso:: :py:func:`lowerSelectedItems`
.. seealso:: :py:func:`moveSelectedItemsToTop`
%End
void lockSelectedItems();
%Docstring
Locks any selected items, preventing them from being interacted with
by mouse interactions.
.. seealso:: :py:func:`unlockAllItems`
%End
void unlockAllItems();
%Docstring
Unlocks all locked items in the layout.
.. seealso:: :py:func:`lockSelectedItems`
%End
void deleteSelectedItems();
%Docstring
Deletes all selected items.
.. seealso:: :py:func:`deleteItems`
%End
void deleteItems( const QList< QgsLayoutItem * > &items );
%Docstring
Delete the specified ``items``.
.. seealso:: :py:func:`deleteSelectedItems`
%End
void groupSelectedItems();
%Docstring
Groups all selected items.
.. seealso:: :py:func:`ungroupSelectedItems`
%End
void ungroupSelectedItems();
%Docstring
Ungroups all selected items.
.. seealso:: :py:func:`groupSelectedItems`
%End
void viewChanged();
%Docstring
Updates associated rulers and other widgets after view extent or zoom has changed.
This should be called after calling any of the QGraphicsView
base class methods which alter the view's zoom level or extent,
i.e. QGraphicsView.fitInView().
%End
void pushStatusMessage( const QString &message );
%Docstring
Pushes a new status bar ``message`` to the view. This causes statusMessage()
to be emitted, which should cause the message to appear in the status bar
for the parent window.
.. seealso:: :py:func:`statusMessage`
%End
signals:
void layoutSet( QgsLayout *layout );
%Docstring
Emitted when a ``layout`` is set for the view.
.. seealso:: :py:func:`currentLayout`
.. seealso:: :py:func:`setCurrentLayout`
%End
void toolSet( QgsLayoutViewTool *tool );
%Docstring
Emitted when the current ``tool`` is changed.
.. seealso:: :py:func:`setTool`
%End
void zoomLevelChanged();
%Docstring
Is emitted whenever the zoom level of the view is changed.
%End
void cursorPosChanged( QPointF layoutPoint );
%Docstring
Is emitted when the mouse cursor coordinates change within the view.
The ``layoutPoint`` argument indicates the cursor position within
the layout coordinate system.
%End
void pageChanged( int page );
%Docstring
Emitted when the page visible in the view is changed. This signal
considers the page at the center of the view as the current visible
page.
.. seealso:: :py:func:`currentPage`
%End
void statusMessage( const QString &message );
%Docstring
Emitted when the view has a ``message`` for display in a parent window's
status bar.
.. seealso:: :py:func:`pushStatusMessage`
%End
void itemFocused( QgsLayoutItem *item );
%Docstring
Emitted when an ``item`` is "focused" in the view, i.e. it becomes the active
item and should have its properties displayed in any designer windows.
%End
void willBeDeleted();
%Docstring
Emitted in the destructor when the view is about to be deleted,
but is still in a perfectly valid state.
%End
protected:
virtual void mousePressEvent( QMouseEvent *event );
virtual void mouseReleaseEvent( QMouseEvent *event );
virtual void mouseMoveEvent( QMouseEvent *event );
virtual void mouseDoubleClickEvent( QMouseEvent *event );
virtual void wheelEvent( QWheelEvent *event );
virtual void keyPressEvent( QKeyEvent *event );
virtual void keyReleaseEvent( QKeyEvent *event );
virtual void resizeEvent( QResizeEvent *event );
virtual void scrollContentsBy( int dx, int dy );
virtual void dragEnterEvent( QDragEnterEvent *e );
virtual void paintEvent( QPaintEvent *event );
};
class QgsLayoutViewMenuProvider
{
%Docstring
Interface for a QgsLayoutView context menu.
Implementations of this interface can be made to allow QgsLayoutView
instances to provide custom context menus (opened upon right-click).
.. seealso:: :py:class:`QgsLayoutView`
.. versionadded:: 3.0
%End
%TypeHeaderCode
#include "qgslayoutview.h"
%End
public:
virtual ~QgsLayoutViewMenuProvider();
virtual QMenu *createContextMenu( QWidget *parent /Transfer/, QgsLayout *layout, QPointF layoutPoint ) const = 0 /Factory/;
%Docstring
Return a newly created menu instance (or null pointer on error)
%End
};
/************************************************************************
* This file has been generated automatically from *
* *
* src/gui/layout/qgslayoutview.h *
* *
* Do not edit manually ! Edit header and run scripts/sipify.pl again *
************************************************************************/