简述

对以上节的排序,我们衍伸了两点:

  1. 把一个字符串前面的数据按照字符串比较,而后面的数据按照整形比较。
  2. 将整形显示为字符串,而排序依然正常呢。

为了分别描述,这里我们先解决问题1。

效果

处理大小显示

  1. // 定义GB、MB、KB的计算常量
  2. const int GB = 1024 * 1024 * 1024;
  3. const int MB = 1024 * 1024;
  4. const int KB = 1024;
  5. QString bytesToGBMBKB(qint64 size)
  6. {
  7. if (size / GB >= 1)
  8. return QString("%1 GB").arg(QString::number(size / (float)GB, 'f', 2));
  9. else if (size / MB >= 1)
  10. return QString("%1 MB").arg(QString::number(size / (float)MB, 'f', 2));
  11. else if (size / KB >= 1)
  12. return QString("%1 KB").arg(QString::number(size / (float)KB, 'f', 2));
  13. else
  14. return QString("%1 Bytes").arg(size);
  15. }

QAbstractTableModel

这里只修改了一行代码,其它代码和上节相同。

  1. // 表格项数据
  2. QVariant TableModel::data(const QModelIndex &index, int role) const
  3. {
  4. if (!index.isValid())
  5. return QVariant();
  6. int nRow = index.row();
  7. int nColumn = index.column();
  8. FileRecord record = m_recordList.at(nRow);
  9. switch (role)
  10. {
  11. case Qt::TextColorRole:
  12. return QColor(Qt::white);
  13. case Qt::TextAlignmentRole:
  14. return QVariant(Qt::AlignLeft | Qt::AlignVCenter);
  15. case Qt::DisplayRole:
  16. {
  17. if (nColumn == FILE_NAME_COLUMN)
  18. {
  19. return record.strFileName;
  20. }
  21. else if (nColumn == DATE_TIME_COLUMN)
  22. {
  23. return record.dateTime;
  24. }
  25. else if (nColumn == FILE_SIZE_COLUMN)
  26. {
  27. // 之前返回的qint64,现在转换为字符串
  28. return bytesToGBMBKB(record.nSize);
  29. }
  30. return "";
  31. }
  32. default:
  33. return QVariant();
  34. }
  35. return QVariant();
  36. }

QSortFilterProxyModel

QSortFilterProxyModel是用来排序和过滤的,不能单独使用,它只是一个“代理”,真正的数据需要QAbstractTableModel提供,可以重写lessThan来实现自己的排序算法。

  1. SortFilterProxyModel::SortFilterProxyModel(QWidget *parent)
  2. : QSortFilterProxyModel(parent)
  3. {
  4. }
  5. SortFilterProxyModel::~SortFilterProxyModel()
  6. {
  7. }
  8. bool SortFilterProxyModel::lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const
  9. {
  10. if (!source_left.isValid() || !source_right.isValid())
  11. return false;
  12. if ((source_left.column() == FILE_NAME_COLUMN) && (source_right.column() == FILE_NAME_COLUMN))
  13. {
  14. QVariant leftData = sourceModel()->data(source_left);
  15. QVariant rightData = sourceModel()->data(source_right);
  16. if (leftData.canConvert<QString>() && rightData.canConvert<QString>())
  17. {
  18. QString strLeft = leftData.toString();
  19. QString strRight = rightData.toString();
  20. // 去掉后缀.cpp
  21. if (strLeft.contains("."))
  22. {
  23. int nIndex = strLeft.lastIndexOf(".");
  24. strLeft = strLeft.left(nIndex);
  25. }
  26. if (strRight.contains("."))
  27. {
  28. int nIndex = strRight.lastIndexOf(".");
  29. strRight = strRight.left(nIndex);
  30. }
  31. // 比较大小,如果字符串相同,则比较后面的整形数据
  32. QStringList strLeftList = strLeft.split(" ");
  33. QStringList strRightList = strRight.split(" ");
  34. if ((strLeftList.count() >= 2) && (strRightList.count() >= 2))
  35. {
  36. int nResult = QString::compare(strLeftList.at(0), strRightList.at(0), Qt::CaseInsensitive);
  37. if (nResult == 0)
  38. {
  39. return strLeftList.at(1).toInt() < strRightList.at(1).toInt();
  40. }
  41. else
  42. {
  43. return nResult;
  44. }
  45. }
  46. }
  47. }
  48. return QSortFilterProxyModel::lessThan(source_left, source_right);
  49. }

提示

效果图中,只针对名称自定义排序了,大小只进行了转换,还尚未排序,因为存在多种解决方案,下节我会将方案一一列出,然后进行对比。

Qt之QHeaderView自定义排序(QSortFilterProxyModel)的更多相关文章

  1. Qt之QHeaderView自定义排序(终极版)

    简述 本节主要解决自定义排序衍生的第二个问题-将整形显示为字符串,而排序依然正常. 下面我们介绍三种方案: 委托绘制 用户数据 辅助列 很多人也许会有疑虑,平时都用delegate来绘制各种按钮.图标 ...

  2. Qt之QHeaderView自定义排序(获取正确的QModelIndex)

    简述 前几节中分享过关于自定义排序的功能,貌似我们之前的内容已经可以很好地解决排序问题了,但是,会由此引发一些很难发现的问题...比如:获取QModelIndex索引错误. 下面,我们先来实现一个整行 ...

  3. Java集合框架实现自定义排序

    Java集合框架针对不同的数据结构提供了多种排序的方法,虽然很多时候我们可以自己实现排序,比如数组等,但是灵活的使用JDK提供的排序方法,可以提高开发效率,而且通常JDK的实现要比自己造的轮子性能更优 ...

  4. DataTable自定义排序

    使用JQ DataTable 的时候,希望某列数据可以进行自定义排序,操作如下:(以中文排序和百分比排序为例) 1:定义排序类型: //百分率排序 jQuery.fn.dataTableExt.oSo ...

  5. 干货之UICollectionViewFlowLayout自定义排序和拖拽手势

    使用UICollectionView,需要使用UICollectionViewLayout控制UICollectionViewCell布局,虽然UICollectionViewLayout提供了高度自 ...

  6. DataGridView 绑定List集合后实现自定义排序

    这里只贴主要代码,dataList是已添加数据的全局变量,绑定数据源 datagridview1.DataSource = dataList,以下是核心代码. 实现点击列表头实现自定义排序 priva ...

  7. 【转】c++中Vector等STL容器的自定义排序

    如果要自己定义STL容器的元素类最好满足STL容器对元素的要求    必须要求:     1.Copy构造函数     2.赋值=操作符     3.能够销毁对象的析构函数    另外:     1. ...

  8. mysql如何用order by 自定义排序

    mysql如何用order by 自定义排序 id name roleId aaa bbb ccc ddd eee ,MySQL可以通过field()函数自定义排序,格式:field(value,st ...

  9. python 自定义排序函数

    自定义排序函数 Python内置的 sorted()函数可对list进行排序: >>>sorted([36, 5, 12, 9, 21]) [5, 9, 12, 21, 36] 但 ...

随机推荐

  1. 两台机器间libevent通信:No route to host问题

    最近学习libevent库,遂在两台虚拟机间模拟通信,程序没逻辑错误,但客户端总是提示No route to host问题,想到可能是linux的防火墙问题导致的,于是关掉防火墙: Ubuntu系统防 ...

  2. IE浏览器上传文件时本地路径变成”C:\fakepath\”的问题【转】

    转自:http://www.iefans.net/ie-shangchuan-bendi-lujing-fakepath/ 在使用<input id="file_upl" t ...

  3. SQLserver分页查询实例

    Sqlserver数据库分页查询一直是Sqlserver的短板,闲来无事,想出几种方法,假设有表ARTICLE,字段ID.YEAR...(其他省略),数据53210条(客户真实数据,量不大),分页查询 ...

  4. 小圣求职记B:总集篇

    1. 搜狐sohu 搜狐在正式招聘前邀请了部分应聘者到武汉研发中心开座谈会(因此简历尽量早投,机会多些),有研发的也有产品的,40人左右,座谈会期间介绍了搜狐汽车.北京研发中心.武汉研发中心和搜狐媒体 ...

  5. Git 10 周年之际,创始人 Linus Torvalds 访谈

    点这里 十年前的这一周,linux 内核社区面临一个根本性的挑战:他们不再能够使用他们的修复控制系统:BitKeeper,同时其他的软件配置管理遇到了对分布式系统的新需求.Linus Torvalds ...

  6. SQL技术内幕-13 SQL优化方法论之分析实例级别的等待

    优化方法论的第一步是在实例级别上找出什么类型的等待占用了大部分的等待时间,这可以通过查询动态管理图(DMV,dynamic management view)sys.dm_os_wait_stats 运 ...

  7. 什么是Nib文件?(Nib文件是一种特殊类型的资源文件,它用于保存iPhone OS或Mac OS X应用程序的用户接口)

    Nib文件是一种特殊类型的资源文件,它用于保存iPhone OS或Mac OS X应用程序的用户接口.Nib文件是Interface Builder文档.通常您会使用Interface Builder ...

  8. WCF分布式开发步步为赢(7):WCF数据契约与序列化

    本节继续学习WCF分布式开发步步为赢(7):WCF数据契约与序列化.数据契约是WCF应用程序开发中一个重要的概念,毫无疑问实现客户端与服务端数据契约的传递中序列化是非常重要的步骤.那么序列化是什么?为 ...

  9. Dom新find

    1.HTML标签和属性是不区分大小写的,但JS是区分大小写的:所以(1)HTML专有的接口的属性应该以小写字母开头,如果属性名由多个单词构成,第二个及接下来的每个单词的首字母都要大写.(2)有些HTM ...

  10. UNIX网络编程——网络IPC:套接字

    UNIX网络编程——网络IPC:套接字 Contents 套接字接口 套接字描述符 寻址 字节序 地址格式 地址查询 绑定地址 建立连接 数据传输 套接字选项 带外数据 UNIX域套接字 使用套接字的 ...