4382
- 收藏
- 点赞
- 分享
- 举报
关于3520D QT显示速度问题。欢迎大家讨论,已经有不少优化策略。
本帖最后由 ngswfx 于 2016-8-8 16:42 编辑
就界面部分而言,我这几天优化了很多东西,显示速度比以前快多了。
//主要动作如下:
1、将使用到的资源,尤其是QIcon这一类(例如NVR或者IPC的ICON),如果要在for循环里面频繁加载,对于同一种QIcon,直接弄成全局的,在设备启动时,直接创建完成,使用时,就没必要再多次创建了。能节约不少资源。
2、对于dlg之类的,也是放到设备启动时,直接加载好,然后隐藏起来,使用时直接show即可。
3、合理利用this->setUpdatesEnabled(false);以及this->setUpdatesEnabled(true);临时关闭刷新,所有控件准备好以后,统一刷新。尤其是某些控件,例如list,tree,以及自动产生的menu list等等。如果时一条条插入,底层实现如果是插入一次,绘制一次,势必浪费大量资源。全部准备完毕,统一界面绘制,估计会好一些。
4、强制刷新:qApp->processEvents(); this->update()。的使用。
5、不知为何menu也很慢,进行代码分析,慢的有些怪异,不是自己代码慢,是QT背后,在折腾防闪烁之类的,每次打开也会占用1秒以上,尤其是首次开启。解决方法类似,通过预先加载,并合理通过setWindowOpacity(0.0),设置窗体看不见,等等方式,让加载过程不可视,现在基本能做到,右键菜单完全正常,点击后,包括自己的代码,约100-200ms出现;
6、mainwindow,由于我的QT程序和主程序是2个程序,所以开启了一个看不见的mainwindow,并且全屏显示了,用来响应全屏下的鼠标动作,尤其时鼠标选定了哪个窗体,以前这个看不见的mainwindow被弄成全透明了,但底层估计还在浪费资源。使用this->setUpdatesEnabled(false)避免绘制。另外通过截获void MainWindow::paintEvent (QPaintEvent *)消息,不做任何绘制处理。这样速度的确有提升。
///////////就目前程序运行来看,速度明显快多了。缺点是启动加载慢(有进度条,慢些没关系)。运行中,内存占用稍大,估计多了几兆,和以前相比,没看出大太多,还基本可以接受。
//////但是我还想在3520D上更快,因为我看XM的界面就很快,至少比我这个快,呵呵:lol ,我就想知道,这个QT 4.86或者高一些的版本,能否直接支持opengl这类方式,直接使用GPU加速。当然前提条件是3520D这种cpu。如果是3798M这种(由于SDK带有openvg类的详细使用范例,估计在QT5.6上,可以直接使用显卡加速directfb),目前来看,不用加速,效果都没问题,速度很好,和普通windows下的窗体打开速度差不多。
//////
就界面部分而言,我这几天优化了很多东西,显示速度比以前快多了。
//主要动作如下:
1、将使用到的资源,尤其是QIcon这一类(例如NVR或者IPC的ICON),如果要在for循环里面频繁加载,对于同一种QIcon,直接弄成全局的,在设备启动时,直接创建完成,使用时,就没必要再多次创建了。能节约不少资源。
2、对于dlg之类的,也是放到设备启动时,直接加载好,然后隐藏起来,使用时直接show即可。
3、合理利用this->setUpdatesEnabled(false);以及this->setUpdatesEnabled(true);临时关闭刷新,所有控件准备好以后,统一刷新。尤其是某些控件,例如list,tree,以及自动产生的menu list等等。如果时一条条插入,底层实现如果是插入一次,绘制一次,势必浪费大量资源。全部准备完毕,统一界面绘制,估计会好一些。
4、强制刷新:qApp->processEvents(); this->update()。的使用。
5、不知为何menu也很慢,进行代码分析,慢的有些怪异,不是自己代码慢,是QT背后,在折腾防闪烁之类的,每次打开也会占用1秒以上,尤其是首次开启。解决方法类似,通过预先加载,并合理通过setWindowOpacity(0.0),设置窗体看不见,等等方式,让加载过程不可视,现在基本能做到,右键菜单完全正常,点击后,包括自己的代码,约100-200ms出现;
6、mainwindow,由于我的QT程序和主程序是2个程序,所以开启了一个看不见的mainwindow,并且全屏显示了,用来响应全屏下的鼠标动作,尤其时鼠标选定了哪个窗体,以前这个看不见的mainwindow被弄成全透明了,但底层估计还在浪费资源。使用this->setUpdatesEnabled(false)避免绘制。另外通过截获void MainWindow::paintEvent (QPaintEvent *)消息,不做任何绘制处理。这样速度的确有提升。
///////////就目前程序运行来看,速度明显快多了。缺点是启动加载慢(有进度条,慢些没关系)。运行中,内存占用稍大,估计多了几兆,和以前相比,没看出大太多,还基本可以接受。
//////但是我还想在3520D上更快,因为我看XM的界面就很快,至少比我这个快,呵呵:lol ,我就想知道,这个QT 4.86或者高一些的版本,能否直接支持opengl这类方式,直接使用GPU加速。当然前提条件是3520D这种cpu。如果是3798M这种(由于SDK带有openvg类的详细使用范例,估计在QT5.6上,可以直接使用显卡加速directfb),目前来看,不用加速,效果都没问题,速度很好,和普通windows下的窗体打开速度差不多。
//////
我来回答
回答5个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2017-04-07 17:56:51
-
2015-06-25 09:31:45
-
2010-01-02 08:52:02
-
12018-08-28 21:10:05
-
2019-05-31 17:02:57
-
2017-08-10 09:46:22
-
2016-11-02 19:07:52
-
2015-07-26 17:14:37
-
2017-03-20 15:51:59
-
2015-07-28 11:33:12
-
2018-07-18 14:38:34
-
2015-09-05 16:13:48
-
2015-10-22 10:11:00
-
2015-06-19 14:20:36
-
2017-02-27 19:56:54
-
2018-03-20 16:03:07
-
2015-03-05 20:35:17
-
02016-05-03 13:49:00
-
2018-12-27 10:43:39
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5SS928的emmc有32GB,bootargs设置使用16GB,但是为啥能用的只有rootfs的大小
-
33SS928怎样烧写ubuntu系统
-
10ToolPlatform下载rootfs提示网络失败
-
10谁有GK7205V500的SDK
-
5Hi3516CV610 烧录不进去
-
10Hi3559AV100 芯片硬解码h265编码格式的视频时出现视频播放错误,解码错误信息 s32PackErr:码流有错
-
5海思SS928 / SD3403的sample_venc.c摄像头编码Demo中,采集到的摄像头的YUV数据在哪个相关的函数中?
-
5海鸥派openEuler无法启动网卡,连接WIFI存在问题
-
66有没有ISP相关的巨佬帮忙看看SS928对接IMX347的图像问题
-
50求助hi3559与FPGA通过SLVS-EC接口对接问题
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认