QTableView获取可见的行数

2024-04-19 10:12
文章标签 获取 行数 qtableview

本文主要是介绍QTableView获取可见的行数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

场景

      当我们需要实时刷新QTableView时,而此时tableView的数据量较大,如果全部刷新显然不合理,如果可以只对用户看的到的数据进行刷新那就最好了,经过一番摸索找到了几种方式,可供参考

代码

方法1

QVector<int> getVisibleRows(QTableView* tableView)
{QVector<int> visibleRows;int numRows = tableView->model()->rowCount();//可见的第一行int firstVisibleRow = tableView->rowAt(0);if (firstVisibleRow != -1){//可见的最后一行int lastVisibleRow = tableView->rowAt(tableView->viewport()->height() - 1);if (lastVisibleRow == -1){lastVisibleRow = numRows - 1;}//遍历所有可见行for (int row = firstVisibleRow; row <= lastVisibleRow; ++row) {visibleRows.append(row);}}return visibleRows;
}

方法2

QVector<int> getVisibleRows2(QTableView* tableView) 
{QVector<int> visibleRows;QAbstractItemModel* model = tableView->model();QRect viewportRect = tableView->viewport()->rect();int numRows = model->rowCount();for (int row = 0; row < numRows; ++row){QModelIndex index = model->index(row, 0);QRect rowRect = tableView->visualRect(index);if (rowRect.isValid() && viewportRect.intersects(rowRect)) {visibleRows.append(row);}}return visibleRows;
}

对比

    现在来写一个main函数,简单测试一下哪种方法更有效率:

int main(int argc, char *argv[])
{QApplication a(argc, argv);// 创建一个QTableView并设置数据模型QTableView* tableView = new QTableView;QStandardItemModel model(10000, 2);tableView->setModel(&model);QPushButton* btnPrint = new QPushButton("GetRows");QObject::connect(btnPrint, &QPushButton::clicked, [tableView]() {// 获取可见行的索引QElapsedTimer timer;timer.start();//第一种方式QVector<int> visibleRows = getVisibleRows(tableView);//第二种方式QVector<int> visibleRows = getVisibleRows2(tableView);qint64 elapsed = timer.elapsed(); // 获取经过的毫秒数qDebug() << "Time elapsed:" << elapsed << "milliseconds";qDebug() << "Visible Rows:";for (int row : visibleRows)qDebug() << row;});QVBoxLayout* mainLayout = new QVBoxLayout;mainLayout->addWidget(tableView);mainLayout->addWidget(btnPrint);QWidget* mainWin = new QWidget;mainWin->setLayout(mainLayout);mainWin->show();return a.exec();
}

   我模拟了10000行的数据,两种方式下的耗时分别为

 方法1:

 方法2

这篇关于QTableView获取可见的行数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/917248

相关文章

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

JS和jQuery获取节点的兄弟,父级,子级元素

原文转自http://blog.csdn.net/duanshuyong/article/details/7562423 先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比。 JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当最DOM元素。 <div id="test"><div></div><div></div

vcpkg子包路径批量获取

获取vcpkg 子包的路径,并拼接为set(CMAKE_PREFIX_PATH “拼接路径” ) import osdef find_directories_with_subdirs(root_dir):# 构建根目录下的 "packages" 文件夹路径root_packages_dir = os.path.join(root_dir, "packages")# 如果 "packages"

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

Weex入门教程之4,获取当前全局环境变量和配置信息(屏幕高度、宽度等)

$getConfig() 获取当前全局环境变量和配置信息。 Returns: config (object): 配置对象;bundleUrl (string): bundle 的 url;debug (boolean): 是否是调试模式;env (object): 环境对象; weexVersion (string): Weex sdk 版本;appName (string): 应用名字;

MFC中App,Doc,MainFrame,View各指针的互相获取

纸上得来终觉浅,为了熟悉获取方法,我建了个SDI。 首先说明这四个类的执行顺序是App->Doc->Main->View 另外添加CDialog类获得各个指针的方法。 多文档的获取有点小区别,有时间也总结一下。 //  App void CSDIApp::OnApp() {      //  App      //  Doc     CDocument *pD

android两种日志获取log4j

android   log4j 加载日志使用方法; 先上图: 有两种方式: 1:直接使用架包 加载(两个都要使用); 架包:android-logging-log4j-1.0.3.jar 、log4j-1.2.15.jar  (说明:也可以使用架包:log4j-1.2.17.jar)  2:对架包输入日志的二次封装使用; 1:直接使用 log4j 日志框架获取日志信息: A:配置 日志 文

17 通过ref代替DOM用来获取元素和组件的引用

重点 ref :官网给出的解释是: ref: 用于注册对元素或子组件的引用。引用将在父组件的$refs 对象下注册。如果在普通DOM元素上使用,则引用将是该元素;如果在子组件上使用,则引用将是组件实例: <!-- vm.$refs.p will be the DOM node --><p ref="p">hello</p><!-- vm.$refs.child will be the c

react笔记 8-19 事件对象、获取dom元素、双向绑定

1、事件对象event 通过事件的event对象获取它的dom元素 run=(event)=>{event.target.style="background:yellowgreen" //event的父级为他本身event.target.getAttribute("aid") //这样便获取到了它的自定义属性aid}render() {return (<div><h2>{

react笔记 8-18 事件 方法 定义方法 获取/改变数据 传值

1、定义方法并绑定 class News extends React.Component {constructor(props) {super(props)this.state = {msg:'home组件'}}run(){alert("我是一个run") //方法写在类中}render() {return (<div><h2>{this.state.msg}</h2><button onCli