QT的MVC(View/Delegate)模型十分强大,可以利用各种控件来对表格的输入进行限制,不过我以前一直没有过,这几天研究了一下,写个小例子,希望大家喜欢。

如果看不懂这个例子,请先看QT的自带例子:http://qt-project.org/doc/qt-4.8/itemviews-spinboxdelegate.html

思路:

1:为每一列定义委托:
A:第一列是编号列,使用只读委托,令该列的单元格是只读的
B:第三列是ID列,只能输入1-12个数字,利用QLineEdit委托和正则表达式对输入进行限制
C:第四年龄列,利用QSpinBox委托进行输入限制,只能输入1-100之间的数字
D:第五列是性别列,利用QComboBox委托对输入进行限制,该列的单元格只能输入Male或Female
E:第六列是头像列,在该列的单元格中央放置一张头像

2:定义代理类,把所有单元格中的字符居中显示。

3:利用QSS,将表格的背景色弄成黄蓝相间。

截图:

上代码:

    1. #include <QtGui>
    2. //编号列,只读委托
    3. //这个方法我还真想不到,呵呵
    4. class ReadOnlyDelegate : public QItemDelegate
    5. {
    6. Q_OBJECT
    7. public:
    8. ReadOnlyDelegate(QObject *parent = 0): QItemDelegate(parent) { }
    9. QWidget *createEditor(QWidget*parent, const QStyleOptionViewItem &option,
    10. const QModelIndex &index) const
    11. {
    12. return NULL;
    13. }
    14. };
    15. //ID列,只能输入1-12个数字
    16. //利用QLineEdit委托和正则表达式对输入进行限制
    17. class UserIDDelegate : public QItemDelegate
    18. {
    19. Q_OBJECT
    20. public:
    21. UserIDDelegate(QObject *parent = 0): QItemDelegate(parent) { }
    22. QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option,
    23. const QModelIndex &index) const
    24. {
    25. QLineEdit *editor = new QLineEdit(parent);
    26. QRegExp regExp("[0-9]{0,10}");
    27. editor->setValidator(new QRegExpValidator(regExp, parent));
    28. return editor;
    29. }
    30. void setEditorData(QWidget *editor, const QModelIndex &index) const
    31. {
    32. QString text = index.model()->data(index, Qt::EditRole).toString();
    33. QLineEdit *lineEdit = static_cast<QLineEdit*>(editor);
    34. lineEdit->setText(text);
    35. }
    36. void setModelData(QWidget *editor, QAbstractItemModel *model,
    37. const QModelIndex &index) const
    38. {
    39. QLineEdit *lineEdit = static_cast<QLineEdit*>(editor);
    40. QString text = lineEdit->text();
    41. model->setData(index, text, Qt::EditRole);
    42. }
    43. void updateEditorGeometry(QWidget *editor,
    44. const QStyleOptionViewItem &option, const QModelIndex &index) const
    45. {
    46. editor->setGeometry(option.rect);
    47. }
    48. };
    49. //年龄列,利用QSpinBox委托进行输入限制,只能输入1-100之间的数字
    50. class AgeDelegate : public QItemDelegate
    51. {
    52. Q_OBJECT
    53. public:
    54. AgeDelegate(QObject *parent = 0): QItemDelegate(parent) { }
    55. QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option,
    56. const QModelIndex &index) const
    57. {
    58. QSpinBox *editor = new QSpinBox(parent);
    59. editor->setMinimum(1);
    60. editor->setMaximum(100);
    61. return editor;
    62. }
    63. void setEditorData(QWidget *editor, const QModelIndex &index) const
    64. {
    65. int value = index.model()->data(index, Qt::EditRole).toInt();
    66. QSpinBox *spinBox = static_cast<QSpinBox*>(editor);
    67. spinBox->setValue(value);
    68. }
    69. void setModelData(QWidget *editor, QAbstractItemModel *model,
    70. const QModelIndex &index) const
    71. {
    72. QSpinBox *spinBox = static_cast<QSpinBox*>(editor);
    73. spinBox->interpretText();
    74. int value = spinBox->value();
    75. model->setData(index, value, Qt::EditRole);
    76. }
    77. void updateEditorGeometry(QWidget *editor,
    78. const QStyleOptionViewItem &option, const QModelIndex &index) const
    79. {
    80. editor->setGeometry(option.rect);
    81. }
    82. };
    83. //性别列,利用QComboBox委托对输入进行限制
    84. //这一列的单元格只能输入Male或Female
    85. class SexDelegate : public QItemDelegate
    86. {
    87. Q_OBJECT
    88. public:
    89. SexDelegate(QObject *parent = 0): QItemDelegate(parent) { }
    90. QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option,
    91. const QModelIndex &index) const
    92. {
    93. QComboBox *editor = new QComboBox(parent);
    94. editor->addItem("Female");
    95. editor->addItem("Male");
    96. return editor;
    97. }
    98. void setEditorData(QWidget *editor, const QModelIndex &index) const
    99. {
    100. QString text = index.model()->data(index, Qt::EditRole).toString();
    101. QComboBox *comboBox = static_cast<QComboBox*>(editor);
    102. int tindex = comboBox->findText(text);
    103. comboBox->setCurrentIndex(tindex);
    104. }
    105. void setModelData(QWidget *editor, QAbstractItemModel *model,
    106. const QModelIndex &index) const
    107. {
    108. QComboBox *comboBox = static_cast<QComboBox*>(editor);
    109. QString text = comboBox->currentText();
    110. model->setData(index, text, Qt::EditRole);
    111. }
    112. void updateEditorGeometry(QWidget *editor,
    113. const QStyleOptionViewItem &option, const QModelIndex &index) const
    114. {
    115. editor->setGeometry(option.rect);
    116. }
    117. };
    118. //头像列,只是在单元格中央放一张小图而已
    119. class IconDelegate : public QItemDelegate
    120. {
    121. Q_OBJECT
    122. public:
    123. IconDelegate(QObject *parent = 0): QItemDelegate(parent) { }
    124. void paint(QPainter *painter, const QStyleOptionViewItem &option,
    125. const QModelIndex & index ) const
    126. {
    127. //show.bmp是在工程目录中的一张图片(其实就是QQ的图标啦,呵呵)
    128. QPixmap pixmap = QPixmap("show.bmp").scaled(24, 24);
    129. qApp->style()->drawItemPixmap(painter, option.rect,  Qt::AlignCenter, QPixmap(pixmap));
    130. }
    131. };
    132. //代理类,把所有单元格中的字符居中显示
    133. class VIPModel : public QStandardItemModel
    134. {
    135. Q_OBJECT
    136. public:
    137. VIPModel(QObject *parent=NULL) : QStandardItemModel(parent) { }
    138. VIPModel(int row, int column, QObject *parent=NULL)
    139. : QStandardItemModel(row, column, parent) { }
    140. QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const
    141. {
    142. if( Qt::TextAlignmentRole == role )
    143. return Qt::AlignCenter;
    144. return QStandardItemModel::data(index, role);
    145. }
    146. };
    147. #include "main.moc"
    148. int main(int argc, char *argv[])
    149. {
    150. QApplication app(argc, argv);
    151. VIPModel *model = new VIPModel(5, 5);
    152. QTableView *tableView = new QTableView;
    153. //把表格的背景调成黄蓝相间
    154. //这种方法是在网上看到的,用起来还真方便啊
    155. tableView->setAlternatingRowColors(true);
    156. tableView->setStyleSheet("QTableView{background-color: rgb(250, 250, 115);"
    157. "alternate-background-color: rgb(141, 163, 215);}");
    158. tableView->setWindowTitle("VIP List");
    159. tableView->resize(700, 400);
    160. tableView->setModel(model);
    161. QStringList headerList;
    162. headerList << "No." << "ID" << "Name" << "Age" << "Sex" << "Show";
    163. model->setHorizontalHeaderLabels(headerList);
    164. tableView->verticalHeader()->setVisible(false);
    165. tableView->horizontalHeader()->setStretchLastSection(true);
    166. //为每一列加载委托
    167. ReadOnlyDelegate readOnlyDelegate;
    168. tableView->setItemDelegateForColumn(0, &readOnlyDelegate);
    169. UserIDDelegate userIDDelegate;
    170. tableView->setItemDelegateForColumn(1, &userIDDelegate);
    171. AgeDelegate spinBoxDelegate;
    172. tableView->setItemDelegateForColumn(3, &spinBoxDelegate);
    173. SexDelegate comboBoxDelegate;
    174. tableView->setItemDelegateForColumn(4, &comboBoxDelegate);
    175. IconDelegate iconDelegate;
    176. tableView->setItemDelegateForColumn(5, &iconDelegate);
    177. for(int i=0; i<10; i++)
    178. {
    179. QModelIndex index = model->index(i, 0, QModelIndex());
    180. model->setData(index, i);
    181. }
    182. tableView->show();
    183. return app.exec();
    184. }

http://blog.csdn.net/small_qch/article/details/7753434

在QTableView中使用各种自定义委托的更多相关文章

  1. Qt自定义委托在QTableView中绘制控件、图片、文字(内容比较全)

    自定义委托,继承于,QStyledItemDelegate类,重载Paint()函数, 1.实现在QTableView中绘制 格式字符串 2.实现在QTableView中绘制进度条 3.实现在QTab ...

  2. Qt自定义委托在QTableView中绘制控件、图片、文字

    自定义委托,继承于,QStyledItemDelegate类,重载Paint()函数, 1.实现在QTableView中绘制 格式字符串 2.实现在QTableView中绘制进度条 3.实现在QTab ...

  3. C#中在多个地方调用同一个触发器从而触发同一个自定义委托的事件

    场景 在Winfom中可以在页面上多个按钮或者右键的点击事件中触发同一个自定义的委托事件. 实现 在位置一按钮点击事件中触发 string parentPath = System.IO.Directo ...

  4. QTableView中嵌入复选框CheckBox 的四种方法总结

    搜索了一下,QTableView中嵌入复选框CheckBox方法有四种: 第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简单,通常用这种方法. 第三种只适合静态显示静态数据用 第四 ...

  5. 转载:QTableView中嵌入可视化组件

    出处:http://qimo601.iteye.com/blog/1538364 QTableView中嵌入可视化组件方法有四种: 第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简 ...

  6. qt QTableView中嵌入复选框CheckBox 的四种方法总结

    第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简单,通常用这种方法. 第三种只适合静态显示静态数据用 第四种比较适合扩展,它除了可以嵌入复选框,还可以通过paint()绘制其它控件 ...

  7. 自定义委托类型 - .Net自带委托类型

    委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递. 与其他的类不同,委托类具有一个签名,并且它只能对与其签名匹配的方法进行引用. 一.自定义委托类型 1.语法结构:访问修 ...

  8. c#中的delegate(委托)和event(事件)

    c#中的delegate(委托)和event(事件) 一.delegate是什么东西? 完全可以把delegate理解成C中的函数指针,它允许你传递一个类A的方法m给另一个类B的对象,使得类B的对象能 ...

  9. 26.QT-模型视图之自定义委托

    在上一章学习 25.QT-模型视图 后,本章接着学习视图委托 视图委托(Delegate)简介 由于模型负责组织数据,而视图负责显示数据,所以当用户想修改显示的数据时,就要通过视图中的委托来完成 视图 ...

随机推荐

  1. Android 中常用代码片段

    一:AsyncTask 的使用 (1)activity_main.xml <TextView android:id="@+id/tvInfo" android:layout_ ...

  2. ubuntu下hadoop完全分布式部署

    三台机器分别命名为: hadoop-master ip:192.168.0.25 hadoop-slave1 ip:192.168.0.26 hadoop-slave2 ip:192.168.0.27 ...

  3. eclipse中误删了servers文件

    Eclipse中误删了servers文件,需要重新添加tomcat服务器,这时就会遇到在New Server对话框中选择了Tomcat 6/7后却无法单击"Next"按钮的问题,如 ...

  4. Unity扩展让枚举视图中变成多选框

    如图: 定义属性描述特性(因为没有描述的数据,让绘制类去绘制所以为空) using UnityEngine; using System.Collections; public class EnumFl ...

  5. iOS 苹果app提交 ITC.apps.validation.prerelease_build_missing

    提示这信息,由于没有选择包文件, 在提交页面以下bulid的区域, 加入你的app就可以 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYWxpbmNleG ...

  6. nand烧写分析/内核在启动过程中式如何将这个文件映射成/目录及各子目录的?

    我用的是ramdisk.image.gz,烧写在flash的0x10140000处 我不太明白内核在启动过程中式如何将这个文件映射成/目录及各子目录的? 如果ramdisk.image.gz在flas ...

  7. PHP在Windows下安装配置第一步

    第一步就是下载和安装PHP解释器了: 1.下载Windows版本号的PHP解释器,下载地址:官方下载 我下载的是 VC11 x64 Thread Safe 这个以下的zip包 2.下载完毕后,解压到 ...

  8. JS给元素循环添加事件的问题

    <ul> <li>男</li> <li>女</li> <li>老</li> <li>少</li&g ...

  9. 四个常用.NET的SqlHelper的方法

    至于我为什么要写这篇文章,也许很多人觉得网上大把的sqlhelper的封装类,的确,网上是有很多,我也看过网上很多的版本,但是我发现大多数都是代码生成器生成的,比如动软.CodeSmith等生成的,其 ...

  10. windows系统下搭建Python开发环境

    1.首先下载最新的Python http://www.python.org/download/,我下载的是最新的Python3.5.1 2.下载完成之后开始安装,安装就比较简单了,一路下一步. 3.安 ...