加快用户界面响应(wonder).docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
加快用户界面响应(wonder)

加快用户界面响应 在所有的QT例子在main()最后都调用了QApplication::exec()函数,它启动了Qt的事件循环。开始时Qt会发出一些事件来显示和绘制窗口部件。在这之后,事件循环就开始运行,不断地检查是否有事件发生并把这些事件交给QObject目标对象或其子对象处理。 当一个事件被处理时,其他的事件也可能产生并追加到Qt的事件队列中。如果在一个特定事件的处理上消耗过多时间,用户界面就有可能冻结而无法响应。例如,当程序存在大量长时间I/O操作时,窗口系统产生的一些事件将无法得到处理直到I/O操作完成,从而导致这段时间内用户界面冻结。 在Qt中解决上述问题有三种方法: 第一种方法是使用线程,一个线程处理应用程序用户响应,另一个处理特定事件上的耗时操作。我们在第11章已做介绍。 第二种方法是在处理耗时事件时频繁调用QApplication::processEvents()。 第三种方法是推迟耗时事件处理,直到应用程序空闲下来。 使用processEvents()函数 QApplication::processEvents()函数告知Qt处理任何没有被处理的事件,并且将控制权返回给调用者。实际上QApplication::exec()就是一个不停调用processEvents()函数的小while循环。下面我们编写了一个复制文本文件的示例,如下图所示。 当复制的文件很大时,I/O操作将持续较长时间,在此期间,程序的其他事件处理将被影响,如产生界面冻结。为了解决这个问题,在复制函数doCopy()中调用了processEvents()来保持用户界面响应,代码如下: void Dialog::doCopy() { while(bytesToWrite 0) { if(isStop){ rFile-close(); wFile-close(); wFile-remove(currentFile); progressBar-setMaximum(totalBytes); progressBar-setValue(0); statusLabel-setText(tr(终止)); saveButton-setEnabled(false); stopButton-setEnabled(false); qApp-processEvents(); return; }else{ tempBuf = rFile-read(qMin(bytesToWrite, loadSize)); wFile-write(tempBuf); bytesWritten += qMin(bytesToWrite, loadSize); bytesToWrite -= qMin(bytesToWrite, loadSize); progressBar-setMaximum(totalBytes); progressBar-setValue(bytesWritten); statusLabel-setText(tr(已拷贝 %1MB) .arg(bytesWritten / (1024 * 1024))); tempBuf.resize(0); qApp-processEvents(); } } rFile-close(); wFile-close(); } 当还有要复制的数据(bytesToWrite变量值大于0)且用户没有单击“中断”按钮(isStop变量为false)时,在本次循环中从源文件读取4K字节内容并将它写入目标文件,然后更新进度条和状态显示,最后强制调用processEvents()函数增加一次出来其他类型事件的机会。如果用户中途中断了本次复制操作,将清理尚未复制完成的文件,更新程序显示状态。这里没有人为的对QProgressDialog调用show()?函数,因为进度条对话框会自动调用,如果因为某些原因,如文件太小伙机器处理速度太快,使得操作很快就完成了,QProgressDialog会检测到这个情况并不再显示。 但是上述方式存在一个潜在的威胁,那就是如果用户在文件复制过程中关闭了窗口,或者又一次选择了保存按钮,程序的执行结果将是不确定的。对于这个问题,最简单的解决方式是把: qApp-processEvents(); 函数调用替换为: qApp-eventLoop()-processEvents(QEventLoop::ExcludeUserInput); 函数调用,它告诉Qt忽略鼠标和键盘事件。 使用定时器 对于处理长时间操作还有另一

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档