模型视图(11):【类】QAbstractItemView[官翻]

QAbstractItemView 类

QAbstractItemView类提供了项视图类的基本功能。

Header:#include < QAbstractItemView >
qmake:QT += widgets
Inherits:QAbstractScrollArea
Inherited By:QColumnView, QHeaderView, QListView, QTableView, and QTreeView

详述

QAbstractItemView类是每个使用QAbstractItemModel的标准视图的基类。QAbstractItemView是一个抽象类,本身不能实例化。它为通过信号和插槽机制与模型进行交互提供了一个标准接口,使子类能够随着模型的变化而保持最新。这个类提供了对键盘和鼠标导航、视口滚动、项目编辑和选择的标准支持。键盘导航实现了这个功能:

KeysFunctionality
Arrow keys更改当前项并选择它。
Ctrl+Arrow keys更改当前项,但不选择它。
Shift+Arrow keys更改当前项并选择它。先前选定的项目不会被取消。
Ctr+Space切换当前项的选择。
Tab/Backtab将当前项更改为下一个/前一个项。
Home/End选择模型中的第一/最后一项。
Page up/Page down根据视图中可见的行数向上/向下滚动行。
Ctrl+A选择模型中的所有项。

注意,上面的表假设选择模式允许操作。例如,如果选择模式是QAbstractItemView::NoSelection,则无法选择项目。

QAbstractItemView类是模型/视图类之一,是Qt的模型/视图框架的一部分。

继承QAbstractItemView的视图类只需要实现它们自己特定于视图的功能,比如绘制项目、返回项目的几何形状、查找项目等。

QAbstractItemView提供了一些通用插槽,比如edit()和setCurrentIndex()。还提供了许多受保护的插槽,包括dataChanged()、rowsInserted()、rowsAboutToBeRemoved()、selectionChanged()和currentChanged()。

根项由rootIndex()返回,当前项由currentIndex()返回。使用scrollTo()确保项目可见。

QAbstractItemView的一些函数与滚动有关,例如setHorizontalScrollMode()和setVerticalScrollMode()。要设置滚动条的范围,你可以重新实现视图的resizeEvent()函数:

 void MyView::resizeEvent(QResizeEvent *event) {
     horizontalScrollBar()->setRange(0, realWidth - width());
     ...
 }

注意,在显示小部件之前,范围不会更新。

其他几个函数与选择控制有关;例如setSelectionMode()和setSelectionBehavior()。这个类提供了一个可以使用的默认选择模型(selectionModel()),但是可以使用带有QItemSelectionModel实例的setSelectionModel()来替换它。

要完全控制项的显示和编辑,可以使用setItemDelegate()指定一个委托。

QAbstractItemView提供了很多受保护的函数。有些与编辑有关,例如,edit()和commitData(),而其他是键盘和鼠标事件处理程序。

注意:如果您继承QAbstractItemView并打算更新viewport的内容,那么您应该使用viewport->update()而不是update(),因为所有绘制操作都在viewport上进行。

公共类型

enum DragDropMode

描述视图可以操作的各种拖放事件 ,默认情况下,视图不支持拖放(NoDragDrop)。

ConstantValueDescription
NoDragDrop0不支持拖放。
DragOnly1视图支持拖动自己的项目
DropOnly2视图接受drop
DragDrop3视图同时支持拖放
InternalMove4视图只接受自身的移动(而不是复制)操作。

注意,所使用的模型需要提供对拖放操作的支持。

enum DropIndicatorPosition

当前鼠标位置下拉指示器相对于索引的位置

ConstantValueDescription
OnItem0该项将被拖放到索引。
AboveItem1该项将被拖放到索引上面。
BelowItem2项目将被拖放到索引下面。
OnViewport3该项目将被拖放到没有项目的视窗区域。每个视图处理拖放到视口的项的方式取决于所使用的底层模型的行为。

enum EditTrigger

flags EditTriggers

将启动项目编辑的操作

ConstantValueDescription
NoEditTriggers0编辑不可能的。
CurrentChanged1当当前项发生变化时开始编辑。
DoubleClicked2当双击一个项目时,编辑就开始了。
SelectedClicked4当单击一个已经选择的项目时开始编辑。
EditKeyPressed8当在一个项目上按下平台编辑键时,编辑就开始了。
AnyKeyPressed16当按下一个项目上的任何键时,编辑就开始了。
AllEditTriggers31开始对以上所有操作进行编辑。

enum ScrollHint

ConstantValueDescription
EnsureVisible0滚动以确保项目可见。
PositionAtTop1滚动以定位项目在视窗的顶部。
PositionAtBottom2滚动以定位项目在viewport的底部。
PositionAtCenter3滚动可将项目定位在视口中的中心。

enum ScrollMode

滚动条的行为方式

当设置滚动模式为ScrollPerPixel时,单步长将自动调整,除非它是使用setSingleStep()显式设置的。通过将单步长设置为-1,可以恢复自动调节。

ConstantValueDescription
ScrollPerItem0视图将滚动内容,一次滚动一项。
ScrollPerPixel1视图将滚动内容,每次滚动一个像素。

enum SelectionBehavior

ConstantValueDescription
SelectItems0单项选择。
SelectRows1选择行。
SelectColumns2选择列。

enum SelectionMode

视图如何响应用户的选择

ConstantValueDescription
SingleSelection1当用户选择一个项目时,任何已经选择的项目将变为未选择。当用户单击所选项目时,可以通过按Ctrl键取消选中项目。
ContiguousSelection4当用户以通常的方式选择一个项目时,选择被清除,新项目被选中。但是,如果用户在单击某个项目时按下Shift键,则会选择或取消当前项目和已单击项目之间的所有项目,具体取决于已单击项目的状态。
ExtendedSelection3当用户以通常的方式选择一个项目时,选择被清除,新项目被选中。但是,如果用户在单击项目时按下Ctrl键,则所单击的项目将被切换,而其他所有项目将保持不变。如果用户在单击某个项目时按下Shift键,则会选择或取消当前项目和已单击项目之间的所有项目,具体取决于已单击项目的状态。可以通过拖动鼠标在多个项目上进行选择。
MultiSelection2当用户以通常的方式选择一个项目时,该项目的选择状态是切换的,而其他项目将保持不变。多个项目可以通过拖动鼠标来切换。
NoSelection0无法选择项目。

最常用的模式是单选和扩展选择。

enum State

描述视图的不同状态

这通常只有在重新实现您自己的视图时才有趣。

ConstantValueDescription
NoState0是默认状态。
DraggingState1用户正在拖动项目。
DragSelectingState2用户正在选择项目。
EditingState3用户正在小部件编辑器中编辑一个项目。
ExpandingState4用户正在打开项目的一个分支。
CollapsingState5用户正在关闭项目的一个分支。
AnimatingState6项目视图正在执行动画。

属性

  1. alternatingRowColors: bool 是否使用交替颜色绘制背景
    项目的背景将使用QPalette::Base和QPalette::AlternateBase绘制;否则背景将使用QPalette::Base color绘制

  2. autoScroll: bool 是否启用了拖动移动事件中的自动滚动
    如果这个属性被设置为true(默认),如果用户拖拽到视口边缘的16像素范围内,QAbstractItemView会自动滚动视图的内容。如果当前项发生了变化,那么视图将自动滚动以确保当前项完全可见。

    此属性在viewport接受drop时工作。自动滚动通过将此属性设置为false关闭。

  3. autoScrollMargin: int 当自动滚动被触发时,此属性保存区域的大小
    此属性控制触发自动滚动的视口边缘区域的大小。默认值是16像素。

  4. defaultDropAction: Qt::DropAction QAbstractItemView::drag()中默认使用的拖放操作
    如果未设置该属性,则当所支持的操作支持复制时,删除操作为复制操作。

  5. dragDropMode: DragDropMode 视图将要操作的拖放事件

  6. dragDropOverwriteMode: bool 视图的拖放行为
    如果它的值为真,所选数据将在删除时覆盖现有的项数据,而移动数据将清除项。如果其值为false,则在所选数据被删除时将作为新项插入。当数据被移动时,项目也被移除。

    默认值为false,在QListView和QTreeView子类中也是如此。另一方面,在QTableView子类中,属性被设置为true。
    注意:这并不是为了防止覆盖项目。模型的flags()实现应该通过不返回Qt::ItemIsDropEnabled来实现。

  7. dragEnabled: bool 支持拖动自身项

  8. editTriggers: EditTriggers 启动项编辑的操作
    此属性是由EditTrigger使用OR操作符组合定义的标志的选择。只有在此属性中设置了执行的操作时,视图才会启动对项的编辑。

  9. horizontalScrollMode: ScrollMode 视图如何在水平方向滚动它的内容
    此属性控制视图如何水平滚动其内容。可以按像素或按项滚动。它的默认值通过QStyle::SH_ItemView_ScrollMode样式提示来自于样式。

  10. iconSize: QSize 保存项目图标的大小
    在视图可见时设置此属性将导致条目再次被布局。

  11. selectionBehavior: SelectionBehavior 保存视图使用的选择行为
    无论选择是根据单个项、行还是列进行的,此属性都保持。

  12. selectionMode: SelectionMode 保存视图操作的选择模式
    此属性控制用户是否可以选择一个或多个项,以及在多个项选择中,所选项是否必须是一个连续的项范围。

  13. showDropIndicator: bool 在拖放项和拖放时是否显示拖放指示器

  14. tabKeyNavigation: bool 是否启用了带有选项卡和backtab的项导航。

  15. textElideMode: Qt::TextElideMode 此属性在省略文本中保存“…”的位置
    所有项目视图的默认值是Qt::ElideRight。

  16. verticalScrollMode: ScrollMode 视图如何在垂直方向滚动它的内容
    此属性控制视图如何垂直滚动其内容。可以按像素或按项滚动。它的默认值通过QStyle::SH_ItemView_ScrollMode样式提示来自于样式。

公共函数

构造及析构

  1. QAbstractItemView(QWidget *parent = nullptr)
  2. virtual ~QAbstractItemView()

属性及选型

  1. QAbstractItemModel * model() const
  2. virtual void setModel(QAbstractItemModel *model)
  3. bool alternatingRowColors() const
  4. void setAlternatingRowColors(bool enable)
  5. QSize iconSize() const
  6. void setIconSize(const QSize &size)
  7. QWidget * indexWidget(const QModelIndex &index) const
  8. void setIndexWidget(const QModelIndex &index, QWidget *widget)
  9. virtual int sizeHintForColumn(int column) const
  10. virtual int sizeHintForRow(int row) const
  11. QSize sizeHintForIndex(const QModelIndex &index) const
  12. virtual void keyboardSearch(const QString &search)
  13. bool tabKeyNavigation() const
  14. void setTabKeyNavigation(bool enable)
  15. Qt::TextElideMode textElideMode() const
  16. void setTextElideMode(Qt::TextElideMode mode)

滚动

  1. int autoScrollMargin() const
  2. void setAutoScrollMargin(int margin)
  3. bool hasAutoScroll() const
  4. void setAutoScroll(bool enable)
  5. QAbstractItemView::ScrollMode horizontalScrollMode() const
  6. void setHorizontalScrollMode(QAbstractItemView::ScrollMode mode)
  7. void resetHorizontalScrollMode()
  8. void resetVerticalScrollMode()
  9. virtual void scrollTo(const QModelIndex &index, QAbstractItemView::ScrollHint hint = EnsureVisible) = 0
  10. QAbstractItemView::ScrollMode verticalScrollMode() const
  11. void setVerticalScrollMode(QAbstractItemView::ScrollMode mode)
  12. virtual QRect visualRect(const QModelIndex &index) const = 0

编辑

  1. void closePersistentEditor(const QModelIndex &index)
  2. void openPersistentEditor(const QModelIndex &index)
  3. bool isPersistentEditorOpen(const QModelIndex &index) const
  4. QAbstractItemView::EditTriggers editTriggers() const
  5. void setEditTriggers(QAbstractItemView::EditTriggers triggers)

模型索引

  1. QModelIndex currentIndex() const
  2. QModelIndex rootIndex() const
  3. virtual QModelIndex indexAt(const QPoint &point) const = 0

拖放

  1. Qt::DropAction defaultDropAction() const
  2. void setDefaultDropAction(Qt::DropAction dropAction)
  3. QAbstractItemView::DragDropMode dragDropMode() const
  4. void setDragDropMode(QAbstractItemView::DragDropMode behavior)
  5. bool dragDropOverwriteMode() const
  6. void setDragDropOverwriteMode(bool overwrite)
  7. bool dragEnabled() const
  8. void setDragEnabled(bool enable)
  9. bool showDropIndicator() const
  10. void setDropIndicatorShown(bool enable)

代理

  1. QAbstractItemDelegate * itemDelegate() const
  2. QAbstractItemDelegate * itemDelegate(const QModelIndex &index) const
  3. void setItemDelegate(QAbstractItemDelegate *delegate)
  4. QAbstractItemDelegate * itemDelegateForColumn(int column) const
  5. void setItemDelegateForColumn(int column, QAbstractItemDelegate *delegate)
  6. QAbstractItemDelegate * itemDelegateForRow(int row) const
  7. void setItemDelegateForRow(int row, QAbstractItemDelegate *delegate)

选择项

  1. QAbstractItemView::SelectionBehavior selectionBehavior() const
  2. void setSelectionBehavior(QAbstractItemView::SelectionBehavior behavior)
  3. QAbstractItemView::SelectionMode selectionMode() const
  4. void setSelectionMode(QAbstractItemView::SelectionMode mode)
  5. QItemSelectionModel * selectionModel() const
  6. virtual void setSelectionModel(QItemSelectionModel *selectionModel)

重写的公共函数

  1. virtual QVariant inputMethodQuery(Qt::InputMethodQuery query) const override
    Reimplements: QWidget::inputMethodQuery(Qt::InputMethodQuery query) const.

公共槽

  1. void clearSelection()
  2. void edit(const QModelIndex &index)
  3. virtual void reset()
  4. void scrollToBottom()
  5. void scrollToTop()
  6. virtual void selectAll()
  7. void setCurrentIndex(const QModelIndex &index)
  8. virtual void setRootIndex(const QModelIndex &index)
  9. void update(const QModelIndex &index)

信号

  1. void activated(const QModelIndex &index)
  2. void clicked(const QModelIndex &index)
  3. void doubleClicked(const QModelIndex &index)
  4. void entered(const QModelIndex &index)
  5. void iconSizeChanged(const QSize &size)
  6. void pressed(const QModelIndex &index)
  7. void viewportEntered()

受保护的函数

  1. QPoint dirtyRegionOffset() const
  2. QAbstractItemView::DropIndicatorPosition dropIndicatorPosition() const
  3. virtual bool edit(const QModelIndex &index, QAbstractItemView::EditTrigger trigger, QEvent *event)
  4. void executeDelayedItemsLayout()
  5. virtual int horizontalOffset() const = 0
  6. virtual bool isIndexHidden(const QModelIndex &index) const = 0
  7. virtual QModelIndex moveCursor(QAbstractItemView::CursorAction cursorAction, Qt::KeyboardModifiers modifiers) = 0
  8. void scheduleDelayedItemsLayout()
  9. void scrollDirtyRegion(int dx, int dy)
  10. virtual QModelIndexList selectedIndexes() const
  11. virtual QItemSelectionModel::SelectionFlags selectionCommand(const QModelIndex &index, const QEvent *event = nullptr) const
  12. void setDirtyRegion(const QRegion &region)
  13. virtual void setSelection(const QRect &rect, QItemSelectionModel::SelectionFlags flags) = 0
  14. void setState(QAbstractItemView::State state)
  15. virtual void startDrag(Qt::DropActions supportedActions)
  16. QAbstractItemView::State state() const
  17. virtual int verticalOffset() const = 0
  18. virtual QStyleOptionViewItem viewOptions() const
  19. virtual QRegion visualRegionForSelection(const QItemSelection &selection) const = 0

重写的受保护的函数

  1. virtual void dragEnterEvent(QDragEnterEvent *event) override
  2. virtual void dragLeaveEvent(QDragLeaveEvent *event) override
  3. virtual void dragMoveEvent(QDragMoveEvent *event) override
  4. virtual void dropEvent(QDropEvent *event) override
  5. virtual bool event(QEvent *event) override
  6. virtual bool eventFilter(QObject *object, QEvent *event) override
  7. virtual void focusInEvent(QFocusEvent *event) override
  8. virtual bool focusNextPrevChild(bool next) override
  9. virtual void focusOutEvent(QFocusEvent *event) override
  10. virtual void inputMethodEvent(QInputMethodEvent *event) override
  11. virtual void keyPressEvent(QKeyEvent *event) override
  12. virtual void mouseDoubleClickEvent(QMouseEvent *event) override
  13. virtual void mouseMoveEvent(QMouseEvent *event) override
  14. virtual void mousePressEvent(QMouseEvent *event) override
  15. virtual void mouseReleaseEvent(QMouseEvent *event) override
  16. virtual void resizeEvent(QResizeEvent *event) override
  17. virtual void timerEvent(QTimerEvent *event) override
  18. virtual bool viewportEvent(QEvent *event) override
  19. virtual QSize viewportSizeHint() const override

受保护的槽

  1. virtual void closeEditor(QWidget *editor, QAbstractItemDelegate::EndEditHint hint)
  2. virtual void commitData(QWidget *editor)
  3. virtual void currentChanged(const QModelIndex &current, const QModelIndex &previous)
  4. virtual void dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight, const QVector< int> &roles = QVector< int>())
  5. virtual void editorDestroyed(QObject *editor)
  6. virtual void rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end)
  7. virtual void rowsInserted(const QModelIndex &parent, int start, int end)
  8. virtual void selectionChanged(const QItemSelection &selected, const QItemSelection &deselected)
  9. virtual void updateGeometries()

参见

  • 视图类
  • 模型/视图编程
  • QAbstractItemModel
  • 图表示例。
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值