QAbstractTextDocumentLayout 類

QAbstractTextDocumentLayout 類是用於實現 QTextDocument 自定義布局的抽象基類。 更多...

頭: #include <QAbstractTextDocumentLayout>
qmake: QT += gui
繼承: QObject
繼承者:

QPlainTextDocumentLayout

注意: 此類的所有函數 可重入 .

公共類型

struct PaintContext
struct Selection

公共函數

QAbstractTextDocumentLayout (QTextDocument * document )
QString anchorAt (const QPointF & position ) const
virtual QRectF blockBoundingRect (const QTextBlock & block ) const = 0
QTextBlock blockWithMarkerAt (const QPointF & pos ) const
QTextDocument * document () const
virtual QSizeF documentSize () const = 0
virtual void draw (QPainter * painter , const QAbstractTextDocumentLayout::PaintContext & context ) = 0
QTextFormat formatAt (const QPointF & pos ) const
virtual QRectF frameBoundingRect (QTextFrame * frame ) const = 0
QTextObjectInterface * handlerForObject (int objectType ) const
virtual int hitTest (const QPointF & point , Qt::HitTestAccuracy accuracy ) const = 0
QString imageAt (const QPointF & pos ) const
virtual int pageCount () const = 0
QPaintDevice * paintDevice () const
void registerHandler (int objectType , QObject * component )
void setPaintDevice (QPaintDevice * device )
void unregisterHandler (int objectType , QObject * component = nullptr)

信號

void documentSizeChanged (const QSizeF & newSize )
void pageCountChanged (int newPages )
void update (const QRectF & rect = QRectF(0., 0., 1000000000., 1000000000.))
void updateBlock (const QTextBlock & block )

保護函數

virtual void documentChanged (int position , int charsRemoved , int charsAdded ) = 0
virtual void drawInlineObject (QPainter * painter , const QRectF & rect , QTextInlineObject object , int posInDocument , const QTextFormat & format )
QTextCharFormat format (int position )
virtual void positionInlineObject (QTextInlineObject item , int posInDocument , const QTextFormat & format )
virtual void resizeInlineObject (QTextInlineObject item , int posInDocument , const QTextFormat & format )

詳細描述

The standard layout provided by Qt can handle simple word processing including inline images, lists and tables.

Some applications, e.g., a word processor or a DTP application might need more features than the ones provided by Qt's layout engine, in which case you can subclass QAbstractTextDocumentLayout to provide custom layout behavior for your text documents.

An instance of the QAbstractTextDocumentLayout subclass can be installed on a QTextDocument 對象采用 setDocumentLayout() 函數。

You can insert custom objects into a QTextDocument ;見 QTextObjectInterface 類描述瞭解細節。

另請參閱 QTextObjectInterface .

成員函數文檔編製

QAbstractTextDocumentLayout:: QAbstractTextDocumentLayout ( QTextDocument * document )

創建新的文本文檔布局為給定 document .

[signal] void QAbstractTextDocumentLayout:: documentSizeChanged (const QSizeF & newSize )

This signal is emitted when the size of the document layout changes to newSize .

子類化的 QAbstractTextDocumentLayout should emit this signal when the document's entire layout size changes. This signal is useful for widgets that display text documents since it enables them to update their scroll bars correctly.

另請參閱 documentSize ().

[signal] void QAbstractTextDocumentLayout:: pageCountChanged ( int newPages )

This signal is emitted when the number of pages in the layout changes; newPages is the updated page count.

子類化的 QAbstractTextDocumentLayout should emit this signal when the number of pages in the layout has changed. Changes to the page count are caused by changes to the layout or the document content itself.

另請參閱 pageCount ().

[signal] void QAbstractTextDocumentLayout:: update (const QRectF & rect = QRectF(0., 0., 1000000000., 1000000000.))

此信號被發射當矩形 rect 已更新。

子類化的 QAbstractTextDocumentLayout should emit this signal when the layout of the contents change in order to repaint.

[signal] void QAbstractTextDocumentLayout:: updateBlock (const QTextBlock & block )

此信號發射,當指定 block 已更新。

子類化的 QAbstractTextDocumentLayout should emit this signal when the layout of block has changed in order to repaint.

該函數在 Qt 4.4 引入。

QString QAbstractTextDocumentLayout:: anchorAt (const QPointF & position ) const

Returns the reference of the anchor the given position ,或空字符串若該點處不存在錨點。

[pure virtual] QRectF QAbstractTextDocumentLayout:: blockBoundingRect (const QTextBlock & block ) const

Returns the bounding rectangle of block .

QTextBlock QAbstractTextDocumentLayout:: blockWithMarkerAt (const QPointF & pos ) const

Returns the block (probably a list item) whose marker is found at the given position pos .

該函數在 Qt 5.14 引入。

QTextDocument *QAbstractTextDocumentLayout:: document () const

Returns the text document that this layout is operating on.

[pure virtual protected] void QAbstractTextDocumentLayout:: documentChanged ( int position , int charsRemoved , int charsAdded )

This function is called whenever the contents of the document change. A change occurs when text is inserted, removed, or a combination of these two. The change is specified by position , charsRemoved ,和 charsAdded corresponding to the starting character position of the change, the number of characters removed from the document, and the number of characters added.

For example, when inserting the text "Hello" into an empty document, charsRemoved would be 0 and charsAdded would be 5 (the length of the string).

Replacing text is a combination of removing and inserting. For example, if the text "Hello" gets replaced by "Hi", charsRemoved would be 5 and charsAdded would be 2.

For subclasses of QAbstractTextDocumentLayout , this is the central function where a large portion of the work to lay out and position document contents is done.

For example, in a subclass that only arranges blocks of text, an implementation of this function would have to do the following:

另請參閱 QTextLayout .

[pure virtual] QSizeF QAbstractTextDocumentLayout:: documentSize () const

返迴文檔布局的總大小。

This information can be used by display widgets to update their scroll bars correctly.

另請參閱 documentSizeChanged () 和 QTextDocument::pageSize .

[pure virtual] void QAbstractTextDocumentLayout:: draw ( QPainter * painter , const QAbstractTextDocumentLayout::PaintContext & context )

Draws the layout with the given painter 使用給定 context .

[virtual protected] void QAbstractTextDocumentLayout:: drawInlineObject ( QPainter * painter , const QRectF & rect , QTextInlineObject object , int posInDocument , const QTextFormat & format )

調用此函數以繪製內聯對象 object ,采用給定 painter 在矩形內指定通過 rect using the specified text format .

posInDocument specifies the position of the object within the document.

The default implementation calls drawObject() on the object handlers. This function is called only within Qt. Subclasses can reimplement this function to customize the drawing of inline objects.

另請參閱 draw ().

[protected] QTextCharFormat QAbstractTextDocumentLayout:: format ( int position )

Returns the character format that is applicable at the given position .

QTextFormat QAbstractTextDocumentLayout:: formatAt (const QPointF & pos ) const

Returns the text format at the given position pos .

該函數在 Qt 5.8 引入。

[pure virtual] QRectF QAbstractTextDocumentLayout:: frameBoundingRect ( QTextFrame * frame ) const

Returns the bounding rectangle of frame .

QTextObjectInterface *QAbstractTextDocumentLayout:: handlerForObject ( int objectType ) const

Returns a handler for objects of the given objectType .

[pure virtual] int QAbstractTextDocumentLayout:: hitTest (const QPointF & point , Qt::HitTestAccuracy accuracy ) const

Returns the cursor position for the given point 采用指定 accuracy . Returns -1 if no valid cursor position was found.

QString QAbstractTextDocumentLayout:: imageAt (const QPointF & pos ) const

Returns the source of the image at the given position pos , or an empty string if no image exists at that point.

該函數在 Qt 5.8 引入。

[pure virtual] int QAbstractTextDocumentLayout:: pageCount () const

Returns the number of pages contained in the layout.

另請參閱 pageCountChanged ().

QPaintDevice *QAbstractTextDocumentLayout:: paintDevice () const

Returns the paint device used to render the document's layout.

另請參閱 setPaintDevice ().

[virtual protected] void QAbstractTextDocumentLayout:: positionInlineObject ( QTextInlineObject item , int posInDocument , const QTextFormat & format )

Lays out the inline object item using the given text format .

posInDocument specifies the position of the object within the document.

The default implementation does nothing. This function is called only within Qt. Subclasses can reimplement this function to customize the position of inline objects.

另請參閱 drawInlineObject ().

void QAbstractTextDocumentLayout:: registerHandler ( int objectType , QObject * component )

注冊給定 component as a handler for items of the given objectType .

注意: registerHandler() has to be called once for each object type. This means that there is only one handler for multiple replacement characters of the same object type.

The text document layout does not take ownership of component .

[virtual protected] void QAbstractTextDocumentLayout:: resizeInlineObject ( QTextInlineObject item , int posInDocument , const QTextFormat & format )

Sets the size of the inline object item corresponding to the text format .

posInDocument specifies the position of the object within the document.

The default implementation resizes the item to the size returned by the object handler's intrinsicSize() function. This function is called only within Qt. Subclasses can reimplement this function to customize the resizing of inline objects.

void QAbstractTextDocumentLayout:: setPaintDevice ( QPaintDevice * device )

Sets the paint device used for rendering the document's layout to the given device .

另請參閱 paintDevice ().

void QAbstractTextDocumentLayout:: unregisterHandler ( int objectType , QObject * component = nullptr)

Unregisters the given component as a handler for items of the given objectType , or any handler if the component 未指定。

該函數在 Qt 5.2 引入。