Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Classes principales  ·  Annotées  ·  Classes groupées  ·  Modules  ·  Fonctions  · 

QListView Class Reference
[QtGui module]

The QListView class provides a list or icon view onto a model. More...

#include <QListView>

Inherits QAbstractItemView.

Inherited by QListWidget.

Public Types

Properties

Public Functions

Protected Functions

Additional Inherited Members


Detailed Description

The QListView class provides a list or icon view onto a model.

A QListView presents items stored in a model, either as a simple non-hierarchical list, or as a collection of icons. This class is used to provide lists and icon views that were previously provided by the QListBox and QIconView classes, but using the more flexible approach provided by Qt's model/view architecture.

The QListView class is one of the Model/View Classes and is part of Qt's model/view framework.

This view does not display horizontal or vertical headers; to display a list of items with a horizontal header, use QTreeView instead.

QListView implements the interfaces defined by the QAbstractItemView class to allow it to display data provided by models derived from the QAbstractItemModel class.

Items in a list view can be displayed using one of two view modes: In ListMode, the items are displayed in the form of a simple list; in IconMode, the list view takes the form of an icon view in which the items are displayed with icons like files in a file manager. By default, the list view is in ListMode. To change the view mode, use the setViewMode() function, and to determine the current view mode, use viewMode().

Items in these views are laid out in the direction specified by the flow() of the list view. The items may be fixed in place, or allowed to move, depending on the view's movement() state.

If the items in the model cannot be completely laid out in the direction of flow, they can be wrapped at the boundary of the view widget; this depends on isWrapping(). This property is useful when the items are being represented by an icon view.

The resizeMode() and layoutMode() govern how and when the items are laid out. Items are spaced according to their spacing(), and can exist within a notional grid of size specified by gridSize(). The items can be rendered as large or small icons depending on their iconSize().

Screenshot of a Windows XP style list viewScreenshot of a Macintosh style table viewScreenshot of a Plastique style table view
A Windows XP style list view.A Macintosh style list view.A Plastique style list view.

See also Model/View Programming, QTreeView, QTableView, and QListWidget.


Member Type Documentation

enum QListView::Flow

ConstantValueDescription
QListView::LeftToRight0The items are laid out in the view from the left to the right.
QListView::TopToBottom1The items are laid out in the view from the top to the bottom.

enum QListView::LayoutMode

ConstantValueDescription
QListView::SinglePass0The items are laid out all at once.
QListView::Batched1The items are laid out in batches of 100 items.

enum QListView::Movement

ConstantValueDescription
QListView::Static0The items cannot be moved by the user.
QListView::Free1The items can be moved freely by the user.
QListView::Snap2The items snap to the specified grid when moved; see setGridSize().

enum QListView::ResizeMode

ConstantValueDescription
QListView::Fixed0The items will only be laid out the first time the view is shown.
QListView::Adjust1The items will be laid out every time the view is resized.

enum QListView::ViewMode

ConstantValueDescription
QListView::ListMode0The items are layed out using TopToBottom flow, with Small size and Static movement
QListView::IconMode1The items are layed out using LeftToRight flow, with Large size and Free movement


Property Documentation

flow : Flow

This property holds which direction the items layout should flow.

If this property is LeftToRight, the items will be laid out left to right. If the isWrapping property is true, the layout will wrap when it reaches the right side of the visible area. If this property is TopToBottom, the items will be laid out from the top of the visible area, wrapping when it reaches the bottom.

Setting this property when the view is visible will cause the items to be laid out again.

Access functions:

  • Flow flow () const
  • void setFlow ( Flow flow )

gridSize : QSize

This property holds the size of the layout grid.

This property is the size of the grid in which the items are laid out. The default is an empty size which means that there is no grid and the layout is not done in a grid. Setting this property to a non-empty size switches on the grid layout. (When a grid layout is in force the spacing property is ignored.)

Setting this property when the view is visible will cause the items to be laid out again.

Access functions:

  • QSize gridSize () const
  • void setGridSize ( const QSize & size )

isWrapping : bool

This property holds whether the items layout should wrap.

This property holds whether the layout should wrap when there is no more space in the visible area. The point at which the layout wraps depends on the flow property.

Setting this property when the view is visible will cause the items to be laid out again.

Access functions:

  • bool isWrapping () const
  • void setWrapping ( bool enable )

layoutMode : LayoutMode

This property holds whether the layout of items should happen immediately or be delayed.

This property holds the layout mode for the items. When the mode is SinglePass (the default), the items are laid out all in one go. When the mode is Batched, the items are laid out in batches of 100 items, while processing events. This makes it possible to instantly view and interact with the visible items while the rest are being laid out.

Access functions:

  • LayoutMode layoutMode () const
  • void setLayoutMode ( LayoutMode mode )

modelColumn : int

This property holds the column in the model that is visible.

Access functions:

  • int modelColumn () const
  • void setModelColumn ( int column )

movement : Movement

This property holds whether the items can be moved freely, are snapped to a grid, or cannot be moved at all.

This property determines how the user can move the items in the view. Static means that the items can't be moved the user. Free means that the user can drag and drop the items to any position in the view. Snap means that the user can drag and drop the items, but only to the positions in a notional grid signified by the gridSize property.

Setting this property when the view is visible will cause the items to be laid out again.

Access functions:

  • Movement movement () const
  • void setMovement ( Movement movement )

See also gridSize.

resizeMode : ResizeMode

This property holds whether the items are laid out again when the view is resized.

If this property is Adjust, the items will be laid out again when the view is resized. If the value is Fixed, the items will not be laid out when the view is resized.

Access functions:

  • ResizeMode resizeMode () const
  • void setResizeMode ( ResizeMode mode )

spacing : int

This property holds the space between items in the layout.

This property is the size of the empty space between items in the layout.

Setting this property when the view is visible will cause the items to be laid out again.

Access functions:

  • int spacing () const
  • void setSpacing ( int space )

uniformItemSizes : bool

This property holds whether all items in the listview have the same size.

This property should only be set to true if it is guaranteed that all items in the view have the same size. This enables the view to do some optimizations.

This property was introduced in Qt 4.1.

Access functions:

  • bool uniformItemSizes () const
  • void setUniformItemSizes ( bool enable )

viewMode : ViewMode

This property holds the view mode of the QListView.

This property will change the other unset properties to conform with the set view mode. Properties that have already been set will not be changed, unless clearPropertyFlags() has been called.

Access functions:

  • ViewMode viewMode () const
  • void setViewMode ( ViewMode mode )

Member Function Documentation

QListView::QListView ( QWidget * parent = 0 )

Creates a new QListView with the given parent to view a model. Use setModel() to set the model.

QListView::~QListView ()

Destroys the view.

void QListView::clearPropertyFlags ()

Clears the property flags. See viewMode.

bool QListView::event ( QEvent * e )   [virtual protected]

bool QListView::isRowHidden ( int row ) const

Returns true if the row is hidden, otherwise returns false.

See also setRowHidden.

QRect QListView::rectForIndex ( const QModelIndex & index ) const   [protected]

Returns the rectangle of the item at position index in the model. The rectangle is in contents coordinates.

void QListView::setPositionForIndex ( const QPoint & position, const QModelIndex & index )   [protected]

Sets the contents position of the item at index in the model to the given position. If the list view's movement mode is Static, this function will have no effect.

This function was introduced in Qt 4.1.

void QListView::setRowHidden ( int row, bool hide )

If hide is true the row will be hidden, otherwise the row will be shown.

See also isRowHidden().

Publicité

Best Of

Actualités les plus lues

Semaine
Mois
Année
  1. « Quelque chose ne va vraiment pas avec les développeurs "modernes" », un développeur à "l'ancienne" critique la multiplication des bibliothèques 64
  2. Apercevoir la troisième dimension ou l'utilisation multithreadée d'OpenGL dans Qt, un article des Qt Quarterly traduit par Guillaume Belz 0
  3. Les développeurs ignorent-ils trop les failles découvertes dans leur code ? Prenez-vous en compte les remarques des autres ? 17
  4. BlackBerry 10 : premières images du prochain OS de RIM qui devrait intégrer des widgets et des tuiles inspirées de Windows Phone 0
  5. Quelles nouveautés de C++11 Visual C++ doit-il rapidement intégrer ? Donnez-nous votre avis 10
  6. Adieu qmake, bienvenue qbs : Qt Building Suite, un outil déclaratif et extensible pour la compilation de projets Qt 17
  7. La rubrique Qt a besoin de vous ! 1
Page suivante

Le blog Digia au hasard

Logo

Créer des applications avec un style Metro avec Qt, exemples en QML et C++, un article de Digia Qt traduit par Thibaut Cuvelier

Le blog Digia est l'endroit privilégié pour la communication sur l'édition commerciale de Qt, où des réponses publiques sont apportées aux questions les plus posées au support. Lire l'article.

Communauté

Ressources

Liens utiles

Contact

  • Vous souhaitez rejoindre la rédaction ou proposer un tutoriel, une traduction, une question... ? Postez dans le forum Contribuez ou contactez-nous par MP ou par email (voir en bas de page).

Qt dans le magazine

Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt 4.1
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web