The QwtDynGridLayout class lays out widgets in a grid, adjusting the number of columns and rows to the current size.
More...
#include <qwt_dyngrid_layout.h>
|
void | layoutGrid (uint numCols, QVector< int > &rowHeight, QVector< int > &colWidth) const |
|
void | stretchGrid (const QRect &rect, uint numCols, QVector< int > &rowHeight, QVector< int > &colWidth) const |
|
The QwtDynGridLayout class lays out widgets in a grid, adjusting the number of columns and rows to the current size.
QwtDynGridLayout takes the space it gets, divides it up into rows and columns, and puts each of the widgets it manages into the correct cell(s). It lays out as many number of columns as possible (limited by maxColumns()).
Definition at line 27 of file qwt_dyngrid_layout.h.
QwtDynGridLayout::QwtDynGridLayout |
( |
QWidget * |
parent, |
|
|
int |
margin = 0 , |
|
|
int |
spacing = -1 |
|
) |
| |
|
explicit |
QwtDynGridLayout::QwtDynGridLayout |
( |
int |
spacing = -1 | ) |
|
|
explicit |
QwtDynGridLayout::~QwtDynGridLayout |
( |
| ) |
|
|
virtual |
void QwtDynGridLayout::addItem |
( |
QLayoutItem * |
item | ) |
|
|
virtual |
uint QwtDynGridLayout::columnsForWidth |
( |
int |
width | ) |
const |
|
virtual |
int QwtDynGridLayout::count |
( |
| ) |
const |
|
virtual |
Qt::Orientations QwtDynGridLayout::expandingDirections |
( |
| ) |
const |
|
virtual |
Returns whether this layout can make use of more space than sizeHint().
A value of Qt::Vertical or Qt::Horizontal means that it wants to grow in only one dimension, while Qt::Vertical | Qt::Horizontal means that it wants to grow in both dimensions.
- Returns
- Orientations, where the layout expands
- See also
- setExpandingDirections()
Definition at line 213 of file qwt_dyngrid_layout.cpp.
bool QwtDynGridLayout::hasHeightForWidth |
( |
| ) |
const |
|
virtual |
int QwtDynGridLayout::heightForWidth |
( |
int |
width | ) |
const |
|
virtual |
void QwtDynGridLayout::init |
( |
| ) |
|
|
private |
void QwtDynGridLayout::invalidate |
( |
| ) |
|
|
virtual |
bool QwtDynGridLayout::isEmpty |
( |
| ) |
const |
|
virtual |
QLayoutItem * QwtDynGridLayout::itemAt |
( |
int |
index | ) |
const |
|
virtual |
uint QwtDynGridLayout::itemCount |
( |
| ) |
const |
void QwtDynGridLayout::layoutGrid |
( |
uint |
numColumns, |
|
|
QVector< int > & |
rowHeight, |
|
|
QVector< int > & |
colWidth |
|
) |
| const |
|
protected |
Calculate the dimensions for the columns and rows for a grid of numColumns columns.
- Parameters
-
numColumns | Number of columns. |
rowHeight | Array where to fill in the calculated row heights. |
colWidth | Array where to fill in the calculated column widths. |
Definition at line 419 of file qwt_dyngrid_layout.cpp.
QList< QRect > QwtDynGridLayout::layoutItems |
( |
const QRect & |
rect, |
|
|
uint |
numColumns |
|
) |
| const |
Calculate the geometries of the layout items for a layout with numColumns columns and a given rectangle.
- Parameters
-
rect | Rect where to place the items |
numColumns | Number of columns |
- Returns
- item geometries
Definition at line 344 of file qwt_dyngrid_layout.cpp.
uint QwtDynGridLayout::maxColumns |
( |
| ) |
const |
Return the upper limit for the number of columns.
0 means unlimited, what is the default.
- Returns
- Upper limit for the number of columns
- See also
- setMaxColumns()
Definition at line 121 of file qwt_dyngrid_layout.cpp.
int QwtDynGridLayout::maxItemWidth |
( |
| ) |
const |
|
virtual |
int QwtDynGridLayout::maxRowWidth |
( |
int |
numColumns | ) |
const |
|
private |
Calculate the width of a layout for a given number of columns.
- Parameters
-
numColumns | Given number of columns |
itemWidth | Array of the width hints for all items |
Definition at line 287 of file qwt_dyngrid_layout.cpp.
uint QwtDynGridLayout::numColumns |
( |
| ) |
const |
- Returns
- Number of columns of the current layout.
- See also
- numRows()
- Warning
- The number of columns might change whenever the geometry changes
Definition at line 590 of file qwt_dyngrid_layout.cpp.
uint QwtDynGridLayout::numRows |
( |
| ) |
const |
- Returns
- Number of rows of the current layout.
- See also
- numColumns()
- Warning
- The number of rows might change whenever the geometry changes
Definition at line 580 of file qwt_dyngrid_layout.cpp.
void QwtDynGridLayout::setExpandingDirections |
( |
Qt::Orientations |
expanding | ) |
|
Set whether this layout can make use of more space than sizeHint(). A value of Qt::Vertical or Qt::Horizontal means that it wants to grow in only one dimension, while Qt::Vertical | Qt::Horizontal means that it wants to grow in both dimensions. The default value is 0.
- Parameters
-
expanding | Or'd orientations |
- See also
- expandingDirections()
Definition at line 198 of file qwt_dyngrid_layout.cpp.
void QwtDynGridLayout::setGeometry |
( |
const QRect & |
rect | ) |
|
|
virtual |
Reorganizes columns and rows and resizes managed items within a rectangle.
- Parameters
-
Definition at line 224 of file qwt_dyngrid_layout.cpp.
void QwtDynGridLayout::setMaxColumns |
( |
uint |
maxColumns | ) |
|
QSize QwtDynGridLayout::sizeHint |
( |
| ) |
const |
|
virtual |
void QwtDynGridLayout::stretchGrid |
( |
const QRect & |
rect, |
|
|
uint |
numColumns, |
|
|
QVector< int > & |
rowHeight, |
|
|
QVector< int > & |
colWidth |
|
) |
| const |
|
protected |
Stretch columns in case of expanding() & QSizePolicy::Horizontal and rows in case of expanding() & QSizePolicy::Vertical to fill the entire rect. Rows and columns are stretched with the same factor.
- Parameters
-
rect | Bounding rectangle |
numColumns | Number of columns |
rowHeight | Array to be filled with the calculated row heights |
colWidth | Array to be filled with the calculated column widths |
- See also
- setExpanding(), expanding()
Definition at line 489 of file qwt_dyngrid_layout.cpp.
QLayoutItem * QwtDynGridLayout::takeAt |
( |
int |
index | ) |
|
|
virtual |
Find the item at a specific index and remove it from the layout
- Parameters
-
- Returns
- Layout item, removed from the layout
- See also
- itemAt()
Definition at line 174 of file qwt_dyngrid_layout.cpp.
The documentation for this class was generated from the following files: