Qt之模型/视图(委托)

# -*- coding: utf-8 -*-

# python:2.x

__author__ = ‘Administrator‘

from PyQt4.Qt import *

from PyQt4.QtGui import *

from PyQt4.QtCore import *

import sys,os

#视图和委托

"""

视图。在 model/view 架构中,视图是数据从模型到最终用户的途径。数据通过视图向用户进行显示。

此时,这种显示方式不必须同模型的存储结构相一致。实际上,很多情况下,数据的显示同底层数据的存储是完全不同的。

QAbstractItemModel提供标准的模型接口,使用 QAbstractItemView提供标准的视图接口,当结合这2个,可以对数据表示层分离,在视图中利用前面据说的模型索引,也可以来自模型的数据进行布局既可以直接渲染数据本身,也可以通过委托渲染和编辑数据。

视力不仅可以展示数据,还可以在数据项之间导航以及数据项选择,也需要支持很多基本用户界面的特性,比如:移动,编辑等,也可以把这些数据功能交给某个委托

视图可以脱离模型创建,但必须在显示之前存在,也就是说,视图显示完全基于模型的,这是不能脱离模型存在的,对于用户的选择,视图妈可以独立,也可以共享

-------

有些视图,比如QTableView和QTreeView,不仅显示数据,还会显示列头或者表头,通过QHeaderView视图类提供的实现,表头通常访问视图所包含的同一模型。它们使用QAbstractItemModel::headerData()函数从模型中获取数据,然后将其以标签 label 的形式显示出来。我们可以通过继承QHeaderView类,实现某些更特殊的功能。

"""

class SysTem(QWidget):

def __init__(self,parent=None):#初始化

super(SysTem,self).__init__(parent)#超类

d=QStringList()

d.append(‘0‘)

d.append(‘1‘)

d.append(‘2‘)

m=QStringListModel(self)

m.setStringList(d)

listView=QListView()

listView.setModel(m)

btnshow=QPushButton(‘show‘,self)

btnshow.clicked.connect(self.show)

buttonLayout=QHBoxLayout()

buttonLayout.addWidget(btnshow)

layout=QVBoxLayout()

layout.addWidget(listView)

layout.addLayout(buttonLayout)

self.setLayout(layout)

a=SysTem1()

#listView.setItemDelegate(SysTem1(listView))

#增加一个委托

class SysTem1(QStyledItemDelegate):

def __init__(self,parent=None):

self.createEditor()

#self.setEditorData()

#self.setModelData()

#self.updateEditorGeometry()

def createEditor(self,parent=None):#parent 参数会作为新的编辑器的父组件。

editor=QSpinBox(parent)

editor.setMinimum(0)

editor.setMaximum(100)

return editor

def setEditorData(self,editor=None,index=None):#setEditorData()函数从模型中获取需要编辑的数据(具有Qt::EditRole角色)。由于我们知道它就是一个整型,因此可以放心地调用toInt()函数。editor 就是所生成的编辑器实例,我们将其强制转换成QSpinBox实例,设置其数据作为默认值。

value=index.model().date(index,Qt.EditRole).toInt()

spinBox=editor

spinBox.setValue(value)

def setModelData(self,editor=None,model=None,index=None):

spinBox=editor

spinBox.interpretText()

value=spinBox.value()

model.setData(index,value,Qt.EditRole)

"""

委托会调用setModelData()函数将新的数据保存到模型中。因此,在这里我们首先获取QSpinBox实例,得到用户输入值,然后设置到模型相应的位置。标准的QStyledItemDelegate类会在完成编辑时发出closeEditor()信号,视图会保证编辑器已经关闭并且销毁,因此无需对内存进行管理。由于我们的处理很简单,无需在发出closeEditor()信号,但是在复杂的实现中,记得可以在这里发出这个信号。针对数据的任何操作都必须提交给QAbstractItemModel,

这使得委托独立于特定的视图。当然,在真实应用中,我们需要检测用户的输入是否合法,是否能够存入模型。

"""

def updateEditorGeometry(self,editor=None,index=None,option=None):

editor.setGeometry(option.rect)

"""

单将这个输入框的大小设置为单元格的大小(由option.rect提供)。如果是复杂的编辑器,我们需要根据单元格参数(由option提供)、数据(由index提供)结合编辑器(由editor提供)计算编辑器的显示位置和大小。

现在,我们的委托已经编写完毕。接下来需要将这个委托设置为QListView所使用的委托:"

"""

app=QApplication(sys.argv)

system=SysTem()

system.show()

sys.exit(app.exec_())

如图:

这边由于本人不懂(没有学过c++),所有地方请看到的朋友帮下,谢谢

原文是:http://www.devbean.net/2013/03/qt-study-road-2-view-delegate/

求帮c++的朋友帮下,谢谢

Qt之模型/视图(委托)

时间: 2024-11-08 22:57:01

Qt之模型/视图(委托)的相关文章

Qt之模型/视图(自定义风格)

Qt之模型/视图(自定义风格) 关于自定义风格是针对视图与委托而言的,使用事件与QSS都可以进行处理,今天关于美化的细节讲解一下. 先看下图: 先撇开界面的美观性(萝卜青菜,各有所爱),就现有的这些风格,使用QSS + Qt二维绘图已经绰绰有余了.当然,如何让界面更美观,这个没有什么捷径,我只能说一句:无他,唯手熟尔!基本功搞扎实了,实现起来就会游刃有余...void DetailProgressBar::paint(QPainter *painter, const QStyleOptionVi

Qt之模型/视图(委托)

概念 不同于模型 - 视图 - 控制器模式,模型/视图设计不包括用于管理与用户交互的一个完全独立的组件.一般情况,视图负责将模型数据呈现给用户以及处理用户输入.为了输入更加具有灵活性,则由委托来执行交互.这些组件提供输入功能,且在一些视图中还负责渲染个别项目.控制委托的标准接口在QAbstractItemDelegate类中定义. 委托能够通过实现的paint()和sizeHint()函数来展示它们的内容.然而,简单基础部件的委托可以继承QItemDelegate而不是QAbstractItem

Qt之模型/视图(实时更新数据)

上两节简单介绍了Qt中对于模型/视图的编程,大部分助手里说的很清楚了,现在就开始实战部分吧! 在实际应用中,视图展示的数据往往并非一成不变的,那么如何实时更新成了一个很重要的问题!功能:(1)添加委托(进度条)(2)显示文件名称.大小.进度.速度.剩余时间.状态等.(3)可进行添加.更新.删除.清空等操作.(4)实时更新数据先看一个效果图:委托(进度条):ProgressBarDelegate::ProgressBarDelegate(QObject *parent): QItemDelegat

Qt之模型/视图(自定义按钮)

简述 衍伸前面的章节,我们对QTableView实现了数据显示.自定义排序.显示复选框.进度条等功能的实现,本节主要针对自定义按钮进行讲解,这节过后,也希望大家对自定义有更深入的了解,在以后的功能开发过程中,相信无论遇到什么样式形式,我们都可以很好地实现. 简述 效果 QStyledItemDelegate 源码 衍伸 效果 QStyledItemDelegate 源码 .h 包含显示按钮需要用到的智能指针,按钮的宽度.高度.按钮之间的间距.鼠标的坐标等. class TableViewDele

Qt模型/视图、委托

MVC视图和控制器对象相结合,其结果是模型/视图结构,仍然分离了数据与呈现给用户的方式,使得它可以在几个不同的视图中显示相同的数据,并实现新类型的视图而无需改变底层的数据结构.为了灵活的处理数据输入,则引入委托的概念.在此框架中引入委托的有点事:允许项目数据显示和自定义编辑. 模型与数据源进行通信,在这个体系结构中为其它组件提供了一个接口.通信的性质依赖于数据源的类型以及模型的实现方式. 视图从模型中得到模型索引,这些都是引用到数据项.通过为模型提供模型索引,视图可以从数据远中检索数据项. 在标

QT 模型/视图 编程 委托篇

委托类 概述 与模型-视图-控制器模式不同,模型/视图设计不包括用于管理与用户交互的完全独立的组件.通常,视图负责向用户表示模型数据,并处理用户输入.为了在获取输入的方式上允许一定的灵活性,交互由委托执行.这些组件提供输入功能,并负责在某些视图中呈现各个项.控制委托的标准接口在QAbstractItemDelegate类中定义. 委托应该能够通过实现paint()和sizeHint()函数来呈现它们自己的内容.然而,简单的基于widget的委托可以子类化QItemDelegate而不是QAbst

QT——模型/视图(model/view)

数据项中引入模型/视图架构,可以方便的将数据与表现层分开. ------------------------------------- 模型Model:一般来说,Model里面并不真正存储数据(数据少的话也可以直接存储在Model里),只是负责从诸如磁盘文件,数据库,网络通讯等获得源数据,并提供给View,View对数据进行修改,然后再通过Model更新源数据. Model 另一个重要工作时为源数据添加索引(ModelIndex).列表形式采用row/colum编号,树形式为建立父子间的层次关系

Qt模型/视图中的data和headerData

QAbstractItemModel QAbstractItemModel是一个抽象类,该抽象类未实现的纯虚方法有 QModelIndex QAbstractItemModel::index(int row, int column, const QModelIndex & parent = QModelIndex()) const [pure virtual] QModelIndex QAbstractItemModel::parent(const QModelIndex & index)

38.Qt模型/视图结构

1 模型/视图类 InterView框架提供了一些可以直接使用的模型类和视图类,如QStandardModel类,QDirModel类,QStringListModel类,以及QColumnView类,QHeaderView类,QListView类,QTableView类和QTreeView类 简单目录浏览器: 1 #include "mainwindow.h" 2 #include <QApplication> 3 4 #include <QAbstractItem