Qt 4.8
|
The QTextTable class represents a table in a QTextDocument. More...
#include <qtexttable.h>
Public Functions | |
void | appendColumns (int count) |
Appends count columns at the right side of the table. More... | |
void | appendRows (int count) |
Appends count rows at the bottom of the table. More... | |
QTextTableCell | cellAt (int row, int col) const |
Returns the table cell at the given row and column in the table. More... | |
QTextTableCell | cellAt (int position) const |
Returns the table cell that contains the character at the given position in the document. More... | |
QTextTableCell | cellAt (const QTextCursor &c) const |
Returns the table cell containing the given cursor. More... | |
int | columns () const |
Returns the number of columns in the table. More... | |
QTextTableFormat | format () const |
Returns the table's format. More... | |
void | insertColumns (int pos, int num) |
Inserts a number of columns before the column with the specified index. More... | |
void | insertRows (int pos, int num) |
Inserts a number of rows before the row with the specified index. More... | |
void | mergeCells (int row, int col, int numRows, int numCols) |
Merges the cell at the specified row and column with the adjacent cells into one cell. More... | |
void | mergeCells (const QTextCursor &cursor) |
Merges the cells selected by the provided cursor. More... | |
QTextTable (QTextDocument *doc) | |
void | removeColumns (int pos, int num) |
Removes a number of columns starting with the column at the specified index. More... | |
void | removeRows (int pos, int num) |
Removes a number of rows starting with the row at the specified index. More... | |
void | resize (int rows, int cols) |
Resizes the table to contain the required number of rows and columns. More... | |
QTextCursor | rowEnd (const QTextCursor &c) const |
Returns a cursor pointing to the end of the row that contains the given cursor. More... | |
int | rows () const |
Returns the number of rows in the table. More... | |
QTextCursor | rowStart (const QTextCursor &c) const |
Returns a cursor pointing to the start of the row that contains the given cursor. More... | |
void | setFormat (const QTextTableFormat &format) |
Sets the table's format. More... | |
void | splitCell (int row, int col, int numRows, int numCols) |
Splits the specified cell at row and column into an array of multiple cells with dimensions specified by numRows and numCols. More... | |
~QTextTable () | |
Public Functions inherited from QTextFrame | |
iterator | begin () const |
Returns an iterator pointing to the first document element inside the frame. More... | |
QList< QTextFrame * > | childFrames () const |
Returns a (possibly empty) list of the frame's child frames. More... | |
iterator | end () const |
Returns an iterator pointing to the position past the last document element inside the frame. More... | |
QTextCursor | firstCursorPosition () const |
Returns the first cursor position inside the frame. More... | |
int | firstPosition () const |
Returns the first document position inside the frame. More... | |
QTextFrameFormat | frameFormat () const |
Returns the frame's format. More... | |
QTextCursor | lastCursorPosition () const |
Returns the last cursor position inside the frame. More... | |
int | lastPosition () const |
Returns the last document position inside the frame. More... | |
QTextFrameLayoutData * | layoutData () const |
QTextFrame * | parentFrame () const |
Returns the frame's parent frame. More... | |
QTextFrame (QTextDocument *doc) | |
Creates a new empty frame for the text document. More... | |
void | setFrameFormat (const QTextFrameFormat &format) |
Sets the frame's format. More... | |
void | setLayoutData (QTextFrameLayoutData *data) |
~QTextFrame () | |
Destroys the frame, and removes it from the document's layout. More... | |
Public Functions inherited from QTextObject | |
QTextDocumentPrivate * | docHandle () const |
QTextDocument * | document () const |
Returns the document this object belongs to. More... | |
QTextFormat | format () const |
Returns the text object's format. More... | |
int | formatIndex () const |
Returns the index of the object's format in the document's internal list of formats. More... | |
int | objectIndex () const |
Returns the object index of this object. More... | |
Public Functions inherited from QObject | |
bool | blockSignals (bool b) |
If block is true, signals emitted by this object are blocked (i.e., emitting a signal will not invoke anything connected to it). More... | |
const QObjectList & | children () const |
Returns a list of child objects. More... | |
bool | connect (const QObject *sender, const char *signal, const char *member, Qt::ConnectionType type=Qt::AutoConnection) const |
bool | disconnect (const char *signal=0, const QObject *receiver=0, const char *member=0) |
bool | disconnect (const QObject *receiver, const char *member=0) |
void | dumpObjectInfo () |
Dumps information about signal connections, etc. More... | |
void | dumpObjectTree () |
Dumps a tree of children to the debug output. More... | |
QList< QByteArray > | dynamicPropertyNames () const |
Returns the names of all properties that were dynamically added to the object using setProperty(). More... | |
virtual bool | event (QEvent *) |
This virtual function receives events to an object and should return true if the event e was recognized and processed. More... | |
virtual bool | eventFilter (QObject *, QEvent *) |
Filters events if this object has been installed as an event filter for the watched object. More... | |
template<typename T > | |
T | findChild (const QString &aName=QString()) const |
Returns the child of this object that can be cast into type T and that is called name, or 0 if there is no such object. More... | |
template<typename T > | |
QList< T > | findChildren (const QString &aName=QString()) const |
Returns all children of this object with the given name that can be cast to type T, or an empty list if there are no such objects. More... | |
template<typename T > | |
QList< T > | findChildren (const QRegExp &re) const |
bool | inherits (const char *classname) const |
Returns true if this object is an instance of a class that inherits className or a QObject subclass that inherits className; otherwise returns false. More... | |
void | installEventFilter (QObject *) |
Installs an event filter filterObj on this object. More... | |
bool | isWidgetType () const |
Returns true if the object is a widget; otherwise returns false. More... | |
void | killTimer (int id) |
Kills the timer with timer identifier, id. More... | |
virtual const QMetaObject * | metaObject () const |
Returns a pointer to the meta-object of this object. More... | |
void | moveToThread (QThread *thread) |
Changes the thread affinity for this object and its children. More... | |
QString | objectName () const |
QObject * | parent () const |
Returns a pointer to the parent object. More... | |
QVariant | property (const char *name) const |
Returns the value of the object's name property. More... | |
Q_INVOKABLE | QObject (QObject *parent=0) |
Constructs an object with parent object parent. More... | |
void | removeEventFilter (QObject *) |
Removes an event filter object obj from this object. More... | |
void | setObjectName (const QString &name) |
void | setParent (QObject *) |
Makes the object a child of parent. More... | |
bool | setProperty (const char *name, const QVariant &value) |
Sets the value of the object's name property to value. More... | |
void | setUserData (uint id, QObjectUserData *data) |
bool | signalsBlocked () const |
Returns true if signals are blocked; otherwise returns false. More... | |
int | startTimer (int interval) |
Starts a timer and returns a timer identifier, or returns zero if it could not start a timer. More... | |
QThread * | thread () const |
Returns the thread in which the object lives. More... | |
QObjectUserData * | userData (uint id) const |
virtual | ~QObject () |
Destroys the object, deleting all its child objects. More... | |
Friends | |
class | QTextTableCell |
Additional Inherited Members | |
Public Types inherited from QTextFrame | |
typedef iterator | Iterator |
Qt-style synonym for QTextFrame::iterator. More... | |
Public Slots inherited from QObject | |
void | deleteLater () |
Schedules this object for deletion. More... | |
Signals inherited from QObject | |
void | destroyed (QObject *=0) |
This signal is emitted immediately before the object obj is destroyed, and can not be blocked. More... | |
Static Public Functions inherited from QObject | |
static bool | connect (const QObject *sender, const char *signal, const QObject *receiver, const char *member, Qt::ConnectionType=Qt::AutoConnection) |
Creates a connection of the given type from the signal in the sender object to the method in the receiver object. More... | |
static bool | connect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type=Qt::AutoConnection) |
static bool | disconnect (const QObject *sender, const char *signal, const QObject *receiver, const char *member) |
Disconnects signal in object sender from method in object receiver. More... | |
static bool | disconnect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &member) |
static uint | registerUserData () |
static QString | tr (const char *sourceText, const char *comment=0, int n=-1) |
static QString | trUtf8 (const char *sourceText, const char *comment=0, int n=-1) |
Static Public Variables inherited from QObject | |
static const QMetaObject | staticMetaObject |
This variable stores the meta-object for the class. More... | |
Protected Functions inherited from QTextFrame | |
QTextFrame (QTextFramePrivate &p, QTextDocument *doc) | |
Protected Functions inherited from QTextObject | |
QTextObject (QTextDocument *doc) | |
Creates a new QTextObject for the given document. More... | |
QTextObject (QTextObjectPrivate &p, QTextDocument *doc) | |
void | setFormat (const QTextFormat &format) |
Sets the text object's format. More... | |
~QTextObject () | |
Destroys the text object. More... | |
Protected Functions inherited from QObject | |
virtual void | childEvent (QChildEvent *) |
This event handler can be reimplemented in a subclass to receive child events. More... | |
virtual void | connectNotify (const char *signal) |
This virtual function is called when something has been connected to signal in this object. More... | |
virtual void | customEvent (QEvent *) |
This event handler can be reimplemented in a subclass to receive custom events. More... | |
virtual void | disconnectNotify (const char *signal) |
This virtual function is called when something has been disconnected from signal in this object. More... | |
QObject (QObjectPrivate &dd, QObject *parent=0) | |
int | receivers (const char *signal) const |
Returns the number of receivers connected to the signal. More... | |
QObject * | sender () const |
Returns a pointer to the object that sent the signal, if called in a slot activated by a signal; otherwise it returns 0. More... | |
int | senderSignalIndex () const |
virtual void | timerEvent (QTimerEvent *) |
This event handler can be reimplemented in a subclass to receive timer events for the object. More... | |
Protected Variables inherited from QObject | |
QScopedPointer< QObjectData > | d_ptr |
Static Protected Variables inherited from QObject | |
static const QMetaObject | staticQtMetaObject |
Related Functions inherited from QObject | |
T | qFindChildqFindChildren (const QObject *obj, const QString &name)() |
QList< T > | qFindChildrenqFindChildren (const QObject *obj, const QString &name)() |
QList< T > | qFindChildrenqFindChildren (const QObject *obj, const QRegExp ®Exp)() |
T * | qobject_cast (QObject *object) |
QObjectList | |
void * | qt_find_obj_child (QObject *parent, const char *type, const QString &name) |
Returns a pointer to the object named name that inherits type and with a given parent. More... | |
The QTextTable class represents a table in a QTextDocument.
A table is a group of cells ordered into rows and columns. Each table contains at least one row and one column. Each cell contains a block, and is surrounded by a frame.
Tables are usually created and inserted into a document with the QTextCursor::insertTable() function. For example, we can insert a table with three rows and two columns at the current cursor position in an editor using the following lines of code:
The table format is either defined when the table is created or changed later with setFormat().
The table currently being edited by the cursor is found with QTextCursor::currentTable(). This allows its format or dimensions to be changed after it has been inserted into a document.
A table's size can be changed with resize(), or by using insertRows(), insertColumns(), removeRows(), or removeColumns(). Use cellAt() to retrieve table cells.
The starting and ending positions of table rows can be found by moving a cursor within a table, and using the rowStart() and rowEnd() functions to obtain cursors at the start and end of each row.
Rows and columns within a QTextTable can be merged and split using the mergeCells() and splitCell() functions. However, only cells that span multiple rows or columns can be split. (Merging or splitting does not increase or decrease the number of rows and columns.)
Note that if you have merged multiple columns and rows into one cell, you will not be able to split the merged cell into new cells spanning over more than one row or column. To be able to split cells spanning over several rows and columns you need to do this over several iterations.
Suppose we have a 2x3 table of names and addresses. To merge both columns in the first row we invoke mergeCells() with row = 0, column = 0, numRows = 1 and numColumns = 2. table->mergeCells(0, 0, 1, 2); | |
This gives us the following table. To split the first row of the table back into two cells, we invoke the splitCell() function with numRows and numCols = 1. table->splitCell(0, 0, 1, 1); | |
This results in the original table. |
Definition at line 103 of file qtexttable.h.
|
explicit |
Definition at line 606 of file qtexttable.cpp.
QTextTable::~QTextTable | ( | ) |
Destroys the table.
Definition at line 615 of file qtexttable.cpp.
void QTextTable::appendColumns | ( | int | count | ) |
Appends count columns at the right side of the table.
Definition at line 915 of file qtexttable.cpp.
void QTextTable::appendRows | ( | int | count | ) |
Appends count rows at the bottom of the table.
Definition at line 901 of file qtexttable.cpp.
QTextTableCell QTextTable::cellAt | ( | int | row, |
int | column | ||
) | const |
Returns the table cell at the given row and column in the table.
Definition at line 630 of file qtexttable.cpp.
Referenced by QTextCursorPrivate::aboutToRemoveCell(), QTextCursorPrivate::adjustCursor(), cellAt(), QTextCursorPrivate::clearCells(), QTextCursorPrivate::complexSelectionTable(), QTextCopyHelper::copy(), QTextDocumentLayoutPrivate::drawFrame(), QTextDocumentLayoutPrivate::drawTableCell(), QTextHtmlExporter::emitTable(), QTextControlPrivate::gotoNextTableCell(), QTextControlPrivate::gotoPreviousTableCell(), QTextDocumentLayoutPrivate::hitTest(), QTextDocumentLayoutPrivate::layoutTable(), mergeCells(), QTextCursorPrivate::movePosition(), removeColumns(), removeRows(), rowEnd(), rowStart(), QTextCursorPrivate::selectedTableCells(), QTextCursor::selectedText(), QTextCursorPrivate::setBlockCharFormat(), QTextCursorPrivate::setBlockFormat(), QTextCursorPrivate::setCharFormat(), splitCell(), and QTextOdfWriter::writeFrame().
QTextTableCell QTextTable::cellAt | ( | int | position | ) | const |
Returns the table cell that contains the character at the given position in the document.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Definition at line 651 of file qtexttable.cpp.
QTextTableCell QTextTable::cellAt | ( | const QTextCursor & | cursor | ) | const |
Returns the table cell containing the given cursor.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Definition at line 680 of file qtexttable.cpp.
int QTextTable::columns | ( | ) | const |
Returns the number of columns in the table.
Definition at line 1340 of file qtexttable.cpp.
Referenced by QTextCursorPrivate::aboutToRemoveCell(), appendColumns(), QTextDocumentLayoutPrivate::drawFrame(), QTextDocumentLayoutPrivate::drawTableCell(), QTextHtmlExporter::emitTable(), QTextControlPrivate::gotoNextTableCell(), QTextControlPrivate::gotoPreviousTableCell(), QTextDocumentLayoutPrivate::layoutTable(), mergeCells(), QTextCursorPrivate::movePosition(), resize(), setFormat(), and QTextOdfWriter::writeFrame().
|
inline |
Returns the table's format.
Definition at line 133 of file qtexttable.h.
Referenced by QTextCopyHelper::copy(), QTextDocumentLayoutPrivate::drawFrame(), QTextDocumentLayoutPrivate::drawTableCell(), QTextHtmlExporter::emitTable(), insertColumns(), QTextDocumentLayoutPrivate::layoutFlow(), QTextDocumentLayoutPrivate::layoutTable(), removeColumns(), and setFormat().
void QTextTable::insertColumns | ( | int | index, |
int | columns | ||
) |
Inserts a number of columns before the column with the specified index.
Definition at line 797 of file qtexttable.cpp.
Referenced by appendColumns(), and resize().
void QTextTable::insertRows | ( | int | index, |
int | rows | ||
) |
Inserts a number of rows before the row with the specified index.
Definition at line 732 of file qtexttable.cpp.
Referenced by appendRows(), QTextControlPrivate::gotoNextTableCell(), and resize().
void QTextTable::mergeCells | ( | int | row, |
int | column, | ||
int | numRows, | ||
int | numCols | ||
) |
Merges the cell at the specified row and column with the adjacent cells into one cell.
The new cell will span numRows rows and numCols columns. If numRows or numCols is less than the current number of rows or columns the cell spans then this method does nothing.
Definition at line 1072 of file qtexttable.cpp.
Referenced by columns(), mergeCells(), and QTextHtmlImporter::scanTable().
void QTextTable::mergeCells | ( | const QTextCursor & | cursor | ) |
Merges the cells selected by the provided cursor.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Definition at line 1231 of file qtexttable.cpp.
void QTextTable::removeColumns | ( | int | index, |
int | columns | ||
) |
Removes a number of columns starting with the column at the specified index.
Definition at line 995 of file qtexttable.cpp.
Referenced by resize().
void QTextTable::removeRows | ( | int | index, |
int | rows | ||
) |
Removes a number of rows starting with the row at the specified index.
Definition at line 930 of file qtexttable.cpp.
Referenced by resize().
void QTextTable::resize | ( | int | rows, |
int | columns | ||
) |
Resizes the table to contain the required number of rows and columns.
Definition at line 695 of file qtexttable.cpp.
QTextCursor QTextTable::rowEnd | ( | const QTextCursor & | cursor | ) | const |
Returns a cursor pointing to the end of the row that contains the given cursor.
Definition at line 1390 of file qtexttable.cpp.
int QTextTable::rows | ( | ) | const |
Returns the number of rows in the table.
Definition at line 1326 of file qtexttable.cpp.
Referenced by QTextCursorPrivate::aboutToRemoveCell(), appendRows(), QTextDocumentLayoutPrivate::drawFrame(), QTextDocumentLayoutPrivate::drawTableCell(), QTextHtmlExporter::emitTable(), QTextControlPrivate::gotoNextTableCell(), QTextDocumentLayoutPrivate::layoutCell(), QTextDocumentLayoutPrivate::layoutTable(), mergeCells(), and resize().
QTextCursor QTextTable::rowStart | ( | const QTextCursor & | cursor | ) | const |
Returns a cursor pointing to the start of the row that contains the given cursor.
Definition at line 1366 of file qtexttable.cpp.
void QTextTable::setFormat | ( | const QTextTableFormat & | format | ) |
Sets the table's format.
Definition at line 1414 of file qtexttable.cpp.
void QTextTable::splitCell | ( | int | row, |
int | column, | ||
int | numRows, | ||
int | numCols | ||
) |
Splits the specified cell at row and column into an array of multiple cells with dimensions specified by numRows and numCols.
Definition at line 1255 of file qtexttable.cpp.
|
friend |
Definition at line 138 of file qtexttable.h.
Referenced by cellAt().