Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Qt编写安防视频监控系统11-动态换肤

Qt编写安防视频监控系统11-动态换肤

原创
作者头像
feiyangqingyun
修改于 2019-08-21 02:16:54
修改于 2019-08-21 02:16:54
1.4K0
举报
文章被收录于专栏:Qt项目实战Qt项目实战

一、前言

Qt中的动态换肤技术是非常一流的,直接调用qApp->setStyleSheet(qss);就可以对整个应用程序进行换肤,如果样式表内容不多,或者对应的贴图不对,效率还是蛮好的,不过据说有些人写了几千行的样式表,加载起来能够明显感觉卡顿,毕竟此时全部刷新加载重绘,是非常耗CPU的,这种情况就需要避免尽量统一样式表,能合并的就合并,当然,在性能比较好的电脑上,这个基本上遇不到的,也感觉不到的,好比现在的手机相比于十年前的手机,现在动不动都6GB内存了,比起以前256MB内存的时候,不知道爽了多少倍,软件上已经优化不了的事情,靠硬件升级到来的优化体验还是非常棒的。

在设置样式表的过程中,有时候会忘记对某些控件进行背景颜色的设置,我一般喜欢采用qApp->setPalette();来弥补这个缺陷,调用此方法以后,整体的背景颜色被统一设置成了一样的,统一美观。

二、系统介绍

监控系统是由摄像、传输、控制、显示、记录登记5大部分组成。摄像机通过同轴视频电缆将视频图像传输到控制主机,控制主机再将视频信号分配到各监视器及录像设备,同时可将需要传输的语音信号同步录入到录像机内。 通过控制主机,操作人员可发出指令,对云台的上、下、左、右的动作进行控制及对镜头进行调焦变倍的操作,并可通过控制主机实现在多路摄像机及云台之间的切换。利用特殊的录像处理模式,可对图像进行录入、回放、处理等操作,使录像效果达到最佳。

视频监控系统由实时控制系统、监视系统及管理信息系统组成。实时控制系统完成实时数据采集处理、存储、反馈的功能;监视系统完成对各个监控点的全天候的监视,能在多操作控制点上切换多路图像;管理信息系统完成各类所需信息的采集、接收、传输、加工、处理,是整个系统的控制核心。视频监控系统是安全防范系统的组成部分,它是一种防范能力较强的综合系统。视频监控以其直观、方便、信息内容丰富而广泛应用于许多场合。

三、功能特点

  1. 支持16画面切换,全屏切换等,包括1+4+6+8+9+13+16画面切换。
  2. 支持alt+enter全屏,esc退出全屏。
  3. 自定义信息框+错误框+询问框+右下角提示框。
  4. 17套皮肤样式随意更换,所有样式全部统一,包括菜单等。
  5. 云台仪表盘鼠标移上去高亮,八个方位精准识别。
  6. 底部画面工具栏(画面分割切换+截图声音等设置)移上去高亮。
  7. 可在配置文件更改左上角logo+中文软件名称+英文软件名称。
  8. 封装了百度地图,三维切换,设备点位,鼠标按下获取经纬度等。
  9. 堆栈窗体,每个窗体都是个单独的qwidget,方便编写自己的代码。
  10. 顶部鼠标右键菜单,可动态控制时间CPU+左上角面板+左下角面板+右上角面板+右下角面板的显示和隐藏,支持恢复默认布局。
  11. 工具栏可以放置多个小图标和关闭图标。
  12. 左侧右侧可拖动拉伸,并自动记忆宽高位置,重启后恢复。
  13. 双击摄像机节点自动播放视频,双击节点自动依次添加视频,会自动跳到下一个,双击父节点自动添加该节点下的所有视频。
  14. 摄像机节点拖曳到对应窗体播放视频,同时支持拖曳本地文件直接播放。
  15. 视频画面窗体支持拖曳交换,瞬间响应。
  16. 双击节点+拖曳节点+拖曳窗体交换位置,均自动更新url.txt。
  17. 支持从url.txt中加载16通道视频播放,自动记忆最后通道对应的视频,软件启动后自动打开播放。
  18. 右下角音量条控件,失去焦点自动隐藏,音量条带静音图标。
  19. 集成百度地图,可以添加设备对应位置,自动生成地图,支持缩放和三维地图,提供地图风格选择,共12种风格。
  20. 视频拖动到通道窗体外自动删除视频。
  21. 鼠标右键可删除当前+所有视频,截图当前+所有视频。
  22. 录像机管理、摄像机管理,可添加删除修改导入导出打印信息,立即应用新的设备信息生成树状列表,不需重启。
  23. 在pro文件中可以自由开启是否加载地图。
  24. 视频播放可选四种内核自由切换,vlc+ffmpeg+easyplayer+海康sdk,均可在pro中设置。
  25. 可设置1+4+9+16画面轮询,可设置轮询间隔以及轮询码流类型等,直接在主界面底部工具栏右侧单击启动轮询按钮即可,再次单击停止轮询。
  26. 默认超过10秒钟未操作自动隐藏鼠标指针。
  27. 高度可定制化,用户可以很方便的在此基础上衍生自己的功能,支持linux系统。

四、效果图

在这里插入图片描述
在这里插入图片描述

五、核心代码

代码语言:txt
AI代码解释
复制
void AppInit::initStyle()
{
    QFile file(App::StyleName);
    if (file.open(QFile::ReadOnly)) {
        QString qss = QLatin1String(file.readAll());
        file.close();

        QUIHelper::getQssColor(qss, QUIConfig::TextColor, QUIConfig::PanelColor, QUIConfig::BorderColor, QUIConfig::NormalColorStart,
                               QUIConfig::NormalColorEnd, QUIConfig::DarkColorStart, QUIConfig::DarkColorEnd, QUIConfig::HighColor);

        //追加样式
        QStringList list;

        //主背景
        list.append(QString("QWidget#widgetMain{background:%1;}").arg(QUIConfig::BorderColor));

        //logo
        list.append(QString("#labLogoCn{font-size:%1px;}#labLogoEn{font-size:%2px;}")
                    .arg(QUIConfig::FontSize + 13).arg(QUIConfig::FontSize + 2));

        //右上角菜单
        list.append(QString("QWidget#widgetMenu>QPushButton{border-radius:0px;padding:0px;margin:1px 1px 2px 1px;}"));

        //视频画面
        list.append(QString("VlcWidget,FFmpegWidget,EasyPlayerWidget,VideoWidget{font-size:%1px;qproperty-borderWidth:%2;qproperty-borderColor:%3;qproperty-focusColor:%4;}")
                    .arg(QUIConfig::FontSize + 10).arg(App::VideoBorder * 2).arg(QUIConfig::BorderColor).arg(QUIConfig::HighColor));

        //画面分割栏
        list.append(QString("QWidget#widgetTool>QPushButton{background:transparent;border:none;}"));
        list.append(QString("QWidget#widgetTool>QPushButton:hover{color:%1;}").arg(QUIConfig::HighColor));
        list.append(QString("QWidget#widgetTool>QPushButton:pressed{color:%1;}").arg(QUIConfig::TextColor));
        list.append(QString("QWidget#widgetTool>QPushButton:checked{color:%1;}").arg(QUIConfig::HighColor));

        //顶部导航按钮,可以自行修改圆角角度
        int topBtnRadius = 20;
        list.append(QString("QWidget#widgetBtn>QPushButton{font-size:%1px;background:transparent;border:none;border-radius:%2px;}")
                    .arg(QUIConfig::FontSize + 3).arg(topBtnRadius));
        list.append(QString("QWidget#widgetBtn>QPushButton:checked,QWidget#widgetBtn>QPushButton:hover{background:%1;border:2px solid %2;}")
                    .arg(QUIConfig::DarkColorEnd).arg(QUIConfig::BorderColor));

        //左侧导航按钮,可以自行修改圆角角度
        int leftBtnRadius = 5;
        list.append(QString("QWidget[flag=\"btn\"]>QPushButton{min-height:%1px;max-height:%1px;}").arg(30));
        list.append(QString("QWidget[flag=\"btn\"]>QPushButton{font-size:%1px;background:transparent;border:none;border-radius:%2px;}")
                    .arg(QUIConfig::FontSize + 3).arg(leftBtnRadius));
        list.append(QString("QWidget[flag=\"btn\"]>QPushButton:checked,QWidget[flag=\"btn\"]>QPushButton:hover{background:%1;border:2px solid %2;}")
                    .arg(QUIConfig::DarkColorEnd).arg(QUIConfig::BorderColor));

        //面板框
        list.append(QString("QFrame[flag=\"btn\"]{background:%1;}").arg(QUIConfig::BorderColor));
        list.append(QString("QFrame[flag=\"btn\"]>QPushButton{font-size:%1px;font-weight:bold;}")
                    .arg(QUIConfig::FontSize + 3));

        //云台圆形按钮
        list.append(QString("#widgetAB>QPushButton{border-width:2px;border-radius:%1px;min-width:%2px;max-width:%2px;min-height:%2px;max-height:%2px;}").arg(17).arg(20));

        //左侧导航栏及按钮图标大小
        list.append(QString("QLineEdit#txtCard,QLabel#labTip,QLabel#labCard,QLabel#labTime{font-weight:bold;font-size:%1px;min-height:%2px;qproperty-alignment:AlignCenter;}").arg(QUIConfig::FontSize + 2).arg(28));
        list.append(QString("QWidget[flag=\"navbtn\"] QPushButton,QFrame[flag=\"navbtn\"] QPushButton{qproperty-iconSize:%1px;min-width:%2px;}").arg(App::BtnIconSize).arg(App::BtnMinWidth));

        //选项卡
        list.append(QString("QTabWidget::pane{border:0px;}QTabBar::tab{min-width:%1px;min-height:%2px;}").arg(48).arg(20));

        //树状控件
        list.append(QString("QTreeView{padding:5px 0px 5px 10px;border-width:0px;}"));

        //文本框控件
        list.append(QString("QTextEdit,QTextEdit:hover,QTextEdit:focus{border-width:0px;border-radius:0px;}"));

        //分隔条背景颜色
        list.append(QString("QSplitter{qproperty-handleWidth:1px;}QSplitter::handle{background:%1;}").arg(QUIConfig::BorderColor));

        //根据不同的样式设置不同,云台控件
        if (App::StyleName == ":/qss/blackblue.css") {
            list.append(QString("GaugeCloud{qproperty-cloudStyle:CloudStyle_Blue;}"));
        } else if (App::StyleName.contains("black")) {
            list.append(QString("GaugeCloud{qproperty-cloudStyle:CloudStyle_Black;}"));
        } else if (App::StyleName == ":/qss/blackblue.css") {
            list.append(QString("GaugeCloud{qproperty-cloudStyle:CloudStyle_Blue;}"));
        } else if (App::StyleName == ":/qss/darkblue.css") {
            list.append(QString("GaugeCloud{qproperty-cloudStyle:CloudStyle_Blue;}"));
        } else if (App::StyleName == ":/qss/purple.css") {
            list.append(QString("GaugeCloud{qproperty-cloudStyle:CloudStyle_Purple;}"));
        } else {
            list.append(QString("GaugeCloud{qproperty-cloudStyle:CloudStyle_White;}"));
        }

        //云台控件鼠标进入+按下颜色设置
        list.append(QString("GaugeCloud{qproperty-pressColor:%1;qproperty-enterColor:%2;}")
                    .arg(QUIConfig::HighColor).arg("#47CAF6"));

        //视频回放控件
        list.append(QString("VideoPlayback{qproperty-bgColor:%1;qproperty-videoBgColor:%1;"
                            "qproperty-textColor:%2;qproperty-videoTextColor:%2;qproperty-videoDataColor:%3;}")
                    .arg(QUIConfig::PanelColor).arg(QUIConfig::TextColor).arg(QUIConfig::HighColor));


        //开关按钮
        bool black = (App::StyleName.contains("black") || App::StyleName.contains("darkblue") || App::StyleName.contains("purple"));
        if (App::StyleName.contains("darkblue") || App::StyleName.contains("darkblack") || App::StyleName.contains("purple") || App::StyleName.contains("blackblue") || App::StyleName.contains("blackvideo")) {
            list.append(QString("SwitchButton{min-width:%1px;max-width:%1px;min-height:%2px;max-height:%2px;"
                                "qproperty-bgColorOn:%3;qproperty-bgColorOff:%4;"
                                "qproperty-textColorOn:%5;qproperty-textColorOff:%5;"
                                "qproperty-sliderColorOn:%6;qproperty-sliderColorOff:%6;}")
                        .arg(App::SwitchBtnWidth).arg(App::SwitchBtnHeight)
                        .arg(black ? QUIConfig::DarkColorEnd : QUIConfig::NormalColorEnd)
                        .arg(black ? QUIConfig::NormalColorEnd : QUIConfig::DarkColorEnd)
                        .arg(QUIConfig::TextColor).arg(QUIConfig::PanelColor));
        } else {
            list.append(QString("SwitchButton{min-width:%1px;max-width:%1px;min-height:%2px;max-height:%2px;"
                                "qproperty-bgColorOn:%3;qproperty-bgColorOff:%4;"
                                "qproperty-textColorOn:%5;qproperty-textColorOff:%5;"
                                "qproperty-sliderColorOn:%6;qproperty-sliderColorOff:%6;}")
                        .arg(App::SwitchBtnWidth).arg(App::SwitchBtnHeight)
                        .arg(QColor(21, 156, 119).name()).arg(QColor(111, 122, 126).name())
                        .arg(QColor(250, 250, 250).name()).arg(QColor(255, 255, 255).name()));
        }

        //导航标题栏
        list.append(QString("NavTitle{qproperty-bgColor:%1;qproperty-textColor:%2;qproperty-borderColor:%3;min-height:%4px;}")
                    .arg(QUIConfig::NormalColorStart).arg(QUIConfig::TextColor).arg(QUIConfig::BorderColor).arg(32));
        list.append(QString("NavTitle{qproperty-iconNormalColor:%1;qproperty-iconHoverColor:%2;qproperty-iconPressColor:%3;}")
                    .arg(QUIConfig::TextColor).arg(QUIConfig::HighColor).arg(QUIConfig::TextColor));

        //将新增的样式加到统一样式表中
        qss += list.join("");
        qApp->setPalette(QPalette(QUIConfig::PanelColor));
        qApp->setStyleSheet(qss);

        if (App::StyleName.contains("gray")) {
            App::LogoBg = "config/logo_black.png";
        } else if (App::StyleName.contains("blue") || App::StyleName.contains("flatblack")) {
            App::LogoBg = "logo.png";
        } else if (App::StyleName.contains("black") || App::StyleName.contains("dark")) {
            App::LogoBg = "config/logo_white.png";
        } else if (App::StyleName.contains("light") || App::StyleName.contains("flat")) {
            App::LogoBg = "config/logo_black.png";
        } else {
            App::LogoBg = "logo.png";
        }
    }
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Qt编写自定义控件70-扁平化flatui
对于现在做前端开发人员来说,FlatUI肯定不陌生,最近几年扁平化的设计越来越流行,大概由于现在PC端和移动端的设备的分辨率越来越高,扁平化反而看起来更让人愉悦,而通过渐变色产生的质感色彩反而没有扁平化来得亲切。
feiyangqingyun
2019/10/16
2.2K0
Qt编写自定义控件70-扁平化flatui
Qt编写数据可视化大屏界面电子看板2-配色方案
做完整个数据可视化大屏界面电子看板系统后,为了提升点逼格,需要提供好几套默认的风格样式以供选择,这样用户可以选择自己喜欢的配色方案来作为整个系统的颜色方案,去看了下市面上大部分的大屏电子看板系统,都是以蓝色为主,部分黑色,估计也许这就是大众的审美吧,那就在数据可视化大屏界面电子看板系统中也加入蓝色风格、深蓝色风格、黑色风格,三种,加上默认的紫色风格,共计内置4套风格选择,Qt的QSS是我见过的最牛逼的换肤控制样式界面颜色的东东,这个工具用好了,别提有多爽,直接qApp->setStyleSheet(qss);可以对整个应用程序换肤,如果自定义的控件定义了Q_PROPERTY的话,也会立即更改自定义控件的属性。
feiyangqingyun
2019/08/19
1.3K0
Qt开源作品9-扁平化样式flatui
对于现在做前端开发人员来说,FlatUI肯定不陌生,最近几年扁平化的设计越来越流行,大概由于现在PC端和移动端的设备的分辨率越来越高,扁平化反而看起来更让人愉悦,而通过渐变色产生的质感色彩反而没有扁平化来得亲切。
feiyangqingyun
2020/05/14
1.2K0
Qt开源作品9-扁平化样式flatui
Qt编写自定义控件34-磁盘容量统计
磁盘容量统计控件,说白了,就是用来统计本地盘符占用的容量,包括但不限于已用空间、剩余空间、总大小、已用百分比等,其中对应的百分比采用进度条显示,该进度条的前景色和背景色及文字颜色可以设置,在整体换肤的时候就需要用到。
feiyangqingyun
2019/08/27
1.6K0
Qt编写自定义控件34-磁盘容量统计
27.QT-QProgressBar动态实现多彩进度条(详解)
通过qss实现,只需要一个多彩背景图,通过QImage获取颜色,然后来设置进度条,便可以实现动态多彩进度条(根据图片设定颜色)
诺谦
2018/07/31
2.7K0
27.QT-QProgressBar动态实现多彩进度条(详解)
【QT】QT界面的美容院 -- QSS
🔥 在网页前端开发领域中,CSS 是一个至关重要的部分,描述了一个网页的 “样式”,从而起到对网页 美化 的作用。
IsLand1314
2025/04/15
5960
【QT】QT界面的美容院 -- QSS
QListWidget小例子
❝该例子演示如何实现QListWidget窗口列表的动态「添加」和「删除」。❞ 演示 一. 实现 小例子主要由MyListWidget和ItemWidget组成。 使用QListWidget的insertItem动态添加一项元素; 使用QListWidget的removeItemWidget动态删除一项元素; 使用QListWidget的setItemWidget设置指定的QWidget模板。 由于ItemWidget继承QWidget和QListWidgetItem,于是就有了以下操作: /* 添加一
Qt君
2023/03/17
9680
QListWidget小例子
Qt编写安防视频监控系统9-自动隐藏光标
这个效果的灵感来自于大屏电子看板系统,在很多系统中尤其是上了大屏的时候,其实在用户不在操作的时候,是很不希望看到那个鼠标箭头指针的,只有当用户操作的时候才显示出来,这个就需要开个定时器定时计算最后一次用户操作的时间,和当前时间比较,如果超过了鼠标未操作隐藏时间,则隐藏鼠标,在Qt中提供了方法qApp->setOverrideCursor(Qt::BlankCursor);这样设置个空白的鼠标指针就表示隐藏鼠标,如果需要恢复调用qApp->restoreOverrideCursor();即可,怎么触发恢复鼠标指针呢?搞个bool存储当前鼠标是否隐藏,在鼠标隐藏的时候置为真,拦截鼠标移动事件,一旦发现之前鼠标处于隐藏状态,则立即恢复指针状态,同时将标志位改为假,不然频繁恢复指针没有意义,只有当指针隐藏的时候才需要恢复一次。
feiyangqingyun
2019/08/21
1.6K0
Qt编写安防视频监控系统9-自动隐藏光标
Qt音视频开发33-ffmpeg安卓版
一直都想搞个安卓版本的视频监控程序,很早以前弄过一个,采用的是早期的ffmpeg2的lib文件,对于现在众多的网络流媒体格式,支持有限,而且新的Qt编写安卓程序,结构上也变动了,新的安卓系统权限要求也和以前处理不一样了,现在需要动态授权,以前是直接配置文件写好需要哪些权限就行,所以近期特意全部重写了一遍安卓版本的视频监控程序,内核还是采用的ffmpeg,换成了最新的ffmpeg4版本,在ubuntu系统上用安卓编译器编译了对应的lib文件,然后放到win上编写Qt+安卓程序。
feiyangqingyun
2020/10/13
9810
Qt音视频开发33-ffmpeg安卓版
Qt编写自定义控件68-IP地址输入框
这个IP地址输入框控件,估计写烂了,网上随便一搜索,保证一大堆,估计也是因为这个控件太容易了,非常适合新手练手,一般的思路都是用4个qlineedit控件拼起来,然后每个输入框设置正则表达式过滤只能输入3位数字,然后安装事件过滤器识别回车自动跳到下一个输入框。关于如何设置正则表达式过滤,这个可以搜索查到,本人也不大懂这个规则,貌似还有专门的书籍专门介绍正则表达式,可能这块非常强大。
feiyangqingyun
2019/10/16
2.2K0
Qt编写自定义控件68-IP地址输入框
Qt编写安防视频监控系统38-onvif校时
在视频监控系统中,对摄像机进行时间设置也是很有必要的,这样就和服务器或者软件这边统一了时间,一般在摄像机的画面上可以设置OSD标识当前时间,这样存储到视频文件中回放的时候,也能和本地的时间一致,一般的视频监控系统默认都会开启ONVIF校时,通过标准的公开的onvif协议来对前端摄像机设备进行时间设置,当然也可以获取时间。前端摄像机设备和后端管理软件或者服务器时间统一是非常重要的一个因素,本人经历过很多视频监控系统相关的项目,很多时候的报修情况就是因为前端设备时间和服务器端不一致的情况,导致的各种奇奇怪怪的问题。
feiyangqingyun
2021/07/01
1.1K0
Qt编写安防视频监控系统38-onvif校时
Qt编写自定义控件13-多态进度条
多态进度条,顾名思义,有多重状态,其实本控件主要是用来表示百分比进度的,由于之前已经存在了百分比进度条控件,名字被霸占了,按照先来先得原则,只好另外取个别名叫做多态进度条,应用场景是,某种任务有三种状态,比如正常状态、警戒状态、报警状态,这三种状态都分别有一个占比,需要用不同的颜色表示,这样就衍生出了此控件,类似于堆积图。接下来节假日四天,可以全身心投入研发还未完工的大屏UI程序,基础控件部分+二级界面部分都已经做好,现在专心整合到主界面和打通数据流(采用数据库采集+网络采集两种方式)。多态进度条也是为了此项目特意定制的。
feiyangqingyun
2019/08/23
1.1K0
Qt编写自定义控件13-多态进度条
QListWidget的QSS用法「建议收藏」
https://blog.csdn.net/u011125673/article/details/51753997
全栈程序员站长
2022/09/06
5.5K0
QListWidget的QSS用法「建议收藏」
【Html.js——页面布局】个人博客(蓝桥杯真题-1766)【合集】
通过以上步骤,HTML 和 CSS 代码协同工作,实现了一个具有导航栏、首页 banner、文章列表和右侧栏的个人博客页面布局。
Rossy Yan
2025/01/24
1650
【Html.js——页面布局】个人博客(蓝桥杯真题-1766)【合集】
Qt编写自定义控件35-GIF录屏控件
在平时的写作过程中,经常需要将一些操作动作和效果图截图成gif格式,使得涵盖的信息更全面更生动,有时候可以将整个操作过程和运行效果录制成MP4,但是文件体积比较大,而且很多网站不便于上传,基本上都支持gif动图,一般一个5秒左右的gif,800*600分辨率,可以很好的控制在500KB内,这样就比较完美的支持各大网站上传动图。
feiyangqingyun
2019/08/27
1.5K0
Qt编写自定义控件35-GIF录屏控件
自定义Qt对话框
今天就简单简单写个自定义对话框分享给大家。 演示 上代码! 自定义对话框的使用: #include <QApplication> #include <QDebug> #include "Dialog
Qt君
2020/07/17
1.8K0
qt tabwidget样式_qt tablewidget使用
ui.tabWidget->setStyleSheet( “QTabWidget{background: #f0f0f0;}” “QTabBar::tab{background:transparent;color:black;font:22px; min-width:103.8px;min-height:49px;}” “QTabBar::tab:first:selected{border-image:url(:/png/images/chat_state.png);}” “QTabBar::tab:first{border-image:url(:/png/images/chat.png);}” “QTabBar::tab:middle:selected{border-image:url(:/png/images/message_state.png);}” “QTabBar::tab:middle{border-image:url(:/png/images/message.png);}” “QTabBar::tab:last:selected{border-image:url(:/png/images/members_state.png);}” “QTabBar::tab:last{border-image:url(:/png/images/members.png);}” );
全栈程序员站长
2022/11/09
9990
Qt编写安防视频监控系统3-通道交换
最开始写通道交换的功能的时候,走了很多弯路,比如最开始用最初级的办法,触发交换的时候,先关闭视频,然后设置新的url重新打开视频,这样处理非常低级而且耗内存还卡还很慢,毕竟重新打开视频都需要时间的,快则几百毫秒慢则几秒钟都很有可能,尤其是网络情况不好的情况下,更加糟糕,后面发现自己真傻,完全没有必要去关闭原有视频,毕竟交换仅仅是位置的交换,而不是重新设置视频,可以直接重新布局,将视频控件对应的布局位置调换下即可,这种方法就做到了瞬间交换,视频还是原来的视频,正常播放,根本就没有中断过。
feiyangqingyun
2019/08/20
1.1K0
Qt编写安防视频监控系统3-通道交换
Qt编写自定义控件24-图片轮播控件
上一篇文章写的广告轮播控件,采用的传统widget堆积设置样式表做的,这次必须要用到更高级的QPainter来绘制了,这个才是最高效的办法,本控件参考雨田哥的轮播控件,经过大规模的改造而成,相比于原来的广告轮播控件,本控件可以说完爆他,按在地上使劲摩擦。除了可以设置图片路径集合以外,还可以设置对应的提示信息,这个在众多的web轮播图片效果中最常见,比如新闻的标题等,可以更直观的显示当前图片,而且单击图片还可以支持跳转,指示器的位置也能设置左边+中间+右边,指示器的样式更加增加到椭圆条状+圆形+矩形+小圆点+长条状多种可选择,可以说涵盖了各种web轮播图片的效果,还可以设置鼠标悬停暂停轮播,以便看清说明后鼠标移开继续轮播。指示器的宽高颜色等,都是可以自由设定的,这个对于采用QPainter绘制来说,是最好自定义的,无非就是设置对应的画笔QPen和对应的画布QBrush的颜色啦。
feiyangqingyun
2019/08/27
2.1K0
Qt编写自定义控件24-图片轮播控件
【QT】QSS
在widget.cpp中使用setStyleSheet方法设置样式 这属于是给Widget设置样式,这对于子控件QPushButton等也会生效
s-little-monster
2024/11/18
1970
【QT】QSS
相关推荐
Qt编写自定义控件70-扁平化flatui
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档