diff --git a/docs/video_system/index.html b/docs/video_system/index.html index 2144c83..f7e975d 100644 --- a/docs/video_system/index.html +++ b/docs/video_system/index.html @@ -201,6 +201,87 @@ mark .md-meta { color: rgb(0, 0, 0); } .md-inline-math-container mjx-container { zoom: 0.95; } +.CodeMirror { height: auto; } +.CodeMirror.cm-s-inner { background: inherit; } +.CodeMirror-scroll { overflow: auto hidden; z-index: 3; } +.CodeMirror-gutter-filler, .CodeMirror-scrollbar-filler { background-color: rgb(255, 255, 255); } +.CodeMirror-gutters { border-right: 1px solid rgb(221, 221, 221); background: inherit; white-space: nowrap; } +.CodeMirror-linenumber { padding: 0px 3px 0px 5px; text-align: right; color: rgb(153, 153, 153); } +.cm-s-inner .cm-keyword { color: rgb(119, 0, 136); } +.cm-s-inner .cm-atom, .cm-s-inner.cm-atom { color: rgb(34, 17, 153); } +.cm-s-inner .cm-number { color: rgb(17, 102, 68); } +.cm-s-inner .cm-def { color: rgb(0, 0, 255); } +.cm-s-inner .cm-variable { color: rgb(0, 0, 0); } +.cm-s-inner .cm-variable-2 { color: rgb(0, 85, 170); } +.cm-s-inner .cm-variable-3 { color: rgb(0, 136, 85); } +.cm-s-inner .cm-string { color: rgb(170, 17, 17); } +.cm-s-inner .cm-property { color: rgb(0, 0, 0); } +.cm-s-inner .cm-operator { color: rgb(152, 26, 26); } +.cm-s-inner .cm-comment, .cm-s-inner.cm-comment { color: rgb(170, 85, 0); } +.cm-s-inner .cm-string-2 { color: rgb(255, 85, 0); } +.cm-s-inner .cm-meta { color: rgb(85, 85, 85); } +.cm-s-inner .cm-qualifier { color: rgb(85, 85, 85); } +.cm-s-inner .cm-builtin { color: rgb(51, 0, 170); } +.cm-s-inner .cm-bracket { color: rgb(153, 153, 119); } +.cm-s-inner .cm-tag { color: rgb(17, 119, 0); } +.cm-s-inner .cm-attribute { color: rgb(0, 0, 204); } +.cm-s-inner .cm-header, .cm-s-inner.cm-header { color: rgb(0, 0, 255); } +.cm-s-inner .cm-quote, .cm-s-inner.cm-quote { color: rgb(0, 153, 0); } +.cm-s-inner .cm-hr, .cm-s-inner.cm-hr { color: rgb(153, 153, 153); } +.cm-s-inner .cm-link, .cm-s-inner.cm-link { color: rgb(0, 0, 204); } +.cm-negative { color: rgb(221, 68, 68); } +.cm-positive { color: rgb(34, 153, 34); } +.cm-header, .cm-strong { font-weight: 700; } +.cm-del { text-decoration: line-through; } +.cm-em { font-style: italic; } +.cm-link { text-decoration: underline; } +.cm-error { color: red; } +.cm-invalidchar { color: red; } +.cm-constant { color: rgb(38, 139, 210); } +.cm-defined { color: rgb(181, 137, 0); } +div.CodeMirror span.CodeMirror-matchingbracket { color: rgb(0, 255, 0); } +div.CodeMirror span.CodeMirror-nonmatchingbracket { color: rgb(255, 34, 34); } +.cm-s-inner .CodeMirror-activeline-background { background: inherit; } +.CodeMirror { position: relative; overflow: hidden; } +.CodeMirror-scroll { height: 100%; outline: 0px; position: relative; box-sizing: content-box; background: inherit; } +.CodeMirror-sizer { position: relative; } +.CodeMirror-gutter-filler, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-vscrollbar { position: absolute; z-index: 6; display: none; outline: 0px; } +.CodeMirror-vscrollbar { right: 0px; top: 0px; overflow: hidden; } +.CodeMirror-hscrollbar { bottom: 0px; left: 0px; overflow: auto hidden; } +.CodeMirror-scrollbar-filler { right: 0px; bottom: 0px; } +.CodeMirror-gutter-filler { left: 0px; bottom: 0px; } +.CodeMirror-gutters { position: absolute; left: 0px; top: 0px; padding-bottom: 10px; z-index: 3; overflow-y: hidden; } +.CodeMirror-gutter { white-space: normal; height: 100%; box-sizing: content-box; padding-bottom: 30px; margin-bottom: -32px; display: inline-block; } +.CodeMirror-gutter-wrapper { position: absolute; z-index: 4; background: 0px 0px !important; border: none !important; } +.CodeMirror-gutter-background { position: absolute; top: 0px; bottom: 0px; z-index: 4; } +.CodeMirror-gutter-elt { position: absolute; cursor: default; z-index: 4; } +.CodeMirror-lines { cursor: text; } +.CodeMirror pre { border-radius: 0px; border-width: 0px; background: 0px 0px; font-family: inherit; font-size: inherit; margin: 0px; white-space: pre; overflow-wrap: normal; color: inherit; z-index: 2; position: relative; overflow: visible; } +.CodeMirror-wrap pre { overflow-wrap: break-word; white-space: pre-wrap; word-break: normal; } +.CodeMirror-code pre { border-right: 30px solid transparent; width: fit-content; } +.CodeMirror-wrap .CodeMirror-code pre { border-right: none; width: auto; } +.CodeMirror-linebackground { position: absolute; inset: 0px; z-index: 0; } +.CodeMirror-linewidget { position: relative; z-index: 2; overflow: auto; } +.CodeMirror-wrap .CodeMirror-scroll { overflow-x: hidden; } +.CodeMirror-measure { position: absolute; width: 100%; height: 0px; overflow: hidden; visibility: hidden; } +.CodeMirror-measure pre { position: static; } +.CodeMirror div.CodeMirror-cursor { position: absolute; visibility: hidden; border-right: none; width: 0px; } +.CodeMirror div.CodeMirror-cursor { visibility: hidden; } +.CodeMirror-focused div.CodeMirror-cursor { visibility: inherit; } +.cm-searching { background: rgba(255, 255, 0, 0.4); } +span.cm-underlined { text-decoration: underline; } +span.cm-strikethrough { text-decoration: line-through; } +.cm-tw-syntaxerror { color: rgb(255, 255, 255); background-color: rgb(153, 0, 0); } +.cm-tw-deleted { text-decoration: line-through; } +.cm-tw-header5 { font-weight: 700; } +.cm-tw-listitem:first-child { padding-left: 10px; } +.cm-tw-box { border-style: solid; border-right-width: 1px; border-bottom-width: 1px; border-left-width: 1px; border-color: inherit; border-top-width: 0px !important; } +.cm-tw-underline { text-decoration: underline; } +@media print { + .CodeMirror div.CodeMirror-cursor { visibility: hidden; } +} + + :root { --side-bar-bg-color: #fafafa; --control-text-color: #777; @@ -593,11 +674,11 @@ header, .context-menu, .megamenu-content, footer{
使用说明
写法举例
V20220106
V20211220
V20211205
x1void QUIStyle::getStyle(QStringList &styleNames, QStringList &styleFiles)
2{
3 static QStringList names;
4 if (names.count() == 0) {
5 names << "黑蓝色" << "软件黑" << "视频黑";
6 names << "深黑色" << "深蓝色" << "深灰色";
7 names << "扁平黑" << "扁平蓝" << "扁平灰";
8 names << "浅黑色" << "浅蓝色" << "浅灰色";
9 names << "普通黑" << "普通蓝" << "普通灰";
10 names << "大蓝色" << "大紫色" << "大银色";
11 }
12
+https://pan.baidu.com/s/13LDRu6mXC6gaADtrGprNVA 提取码: ujm7。- 如果是64位的qt则对应的dll时候拷贝dll_ffmpeg4_64目录下的。
- 如果使用的ffmpeg3则对应dll目录就是dll_ffmpeg,在ffmpeg.pri文件中可以看到具体启用的是ffmpeg3(支持XP)还是ffmpeg4(不支持XP),默认是ffmpeg4。
- 如果编译运行提示miniblink文件不存在请先拷贝,则说明你当前用的Qt版本没有浏览器模块,要么没安装,要么不支持,你也不用担心啥,此时自动切换用的miniblink浏览器内核,你还需要将ffmpeg库下载的网盘的地方找到dll_miniblink.zip下载解压到可执行文件同一目录即可。
- 系统中所有的图标,都采用的图形字体,对照表在doc目录下的FontAwesome.png、FontAliBaBa.png,对应图形字体类IconHelper中加载的图形字体,后期如果还有增加的其他图形字体也是放在这里,一个类支持多种图形字体,通过不同的值范围自动设置。
- 如果发现地图打不开或者提示秘钥文件丢失,请先确认file目录下的所有文件有没有拷贝过去。
- 如果是用vs+qt可能报错 error LNK2026,解决办法详细见文档中其他说明。
- 默认用户名admin 密码admin。
- 系统配置参数在加载的时候会对节点值进行过滤判断,如果为空会自动用初始值生成新的配置文件,如果不想要显示版权所有公司,可以填xxx而不是删掉整个值。
- 如果是用vlc推流的rtsp地址,比如 rtsp://:8554/aabb,由于vlc推流默认写死的采用的udp协议,所以监控系统也必须在系统设置中通信方式选择udp才行(默认tcp)。
0.6.3 离线地图
- 离线地图可以用网上的瓦片地图下载器下载百度的离线地图放到对应目录即可。
- 也可以直接下载网盘中已经下载好的上海市的离线地图。
- 下载地址:https://pan.baidu.com/s/1d7TH_GEYl5nOecuNlWJJ7g 提取密码:01jf 文件名称:bin_map_tiles.zip
使用说明
- 将压缩包下的两个文件夹复制到对应可执行文件下的config文件夹下,和map.js文件同一级目录。
- tiles文件夹是街道图,tiles_hybrid文件夹是卫星图。
- 默认提供的是上海市徐汇区的瓦片地图,如果自己用万能地图下载器下载的百度地图的瓦片文件,也可以对应替换就行。
- 要注意的是格式,默认是jpg,如果下载的瓦片地图格式是png则需要打开config文件夹下的map_load.js文件,将.jpg改成.png保存即可。
0.7 视频格式
0.7.1 USB摄像头
- 内核ffmpeg写法:video=USB2.0 PC CAMERA(具体要看设备名)。
- 内核vlc写法:dshow://:dshow-vdev=Default (或者填USB2.0 PC CAMERA)
- 带参数写法:2020-12-12以后增加USB摄像头直接url带分辨率帧率写法,默认分辨率640x480。
写法举例
- video=USB2.0 PC CAMERA|1920x1080|30(表示1920*1080分辨率30帧)
- video=USB2.0 PC CAMERA|640x480(表示640*480分辨率)
- dshow://:dshow-vdev=USB2.0 PC CAMERA(表示打开视频设备USB2.0 PC CAMERA、其他参数全部默认)
- dshow://:dshow-vdev=USB2.0 PC CAMERA:dshow-adev=麦克风 (USB Audio Device):dshow-size=1920*1080:live-caching=300(表示打开视频设备USB2.0 PC CAMERA、打开音频设备麦克风 (USB Audio Device)、分辨率640x480、缓存时间300毫秒)
0.7.2 网络地址
- 下面的地址有时候会失效,可以自行网上找找其他的地址,网络视频地址建议在晚上测试会更流畅。
- 大雄兔:rtsp://184.72.239.149/vod/mp4://BigBuckBunny_175k.mov
- 大雄兔:http://r.ossrs.net/live/bbb.flv
- 海康萤石:https://hls01open.ys7.com/openlive/6e0b2be040a943489ef0b9bb344b96b8.hd.m3u8
- 在线摄像机:http://vts.simba-cn.com:280/gb28181/21100000001320000002.m3u8
- 摄像机格式:https://blog.csdn.net/qq_38880380/article/details/80652697
0.7.3 中央卫视
- 中央卫视1:rtmp://58.200.131.2:1935/livetv/cctv1
- 中央卫视2:rtmp://58.200.131.2:1935/livetv/cctv2
- 中央卫视3:rtmp://58.200.131.2:1935/livetv/cctv3
- 中央卫视4:rtmp://58.200.131.2:1935/livetv/cctv4
- 中央卫视5:rtmp://58.200.131.2:1935/livetv/cctv5
- 中央卫视6:rtmp://58.200.131.2:1935/livetv/cctv6
- 中央卫视7:rtmp://58.200.131.2:1935/livetv/cctv7
- 中央卫视8:rtmp://58.200.131.2:1935/livetv/cctv8
- 中央卫视9:rtmp://58.200.131.2:1935/livetv/cctv9
- 中央卫视10:rtmp://58.200.131.2:1935/livetv/cctv10
0.7.4 视频文件
- http://vfx.mtime.cn/Video/2019/02/04/mp4/190204084208765161.mp4
- http://vfx.mtime.cn/Video/2019/03/19/mp4/190319212559089721.mp4
- http://vfx.mtime.cn/Video/2019/03/17/mp4/190317150237409904.mp4
- http://vfx.mtime.cn/Video/2019/03/14/mp4/190314223540373995.mp4
0.7.5 网友提供
- rtmp://live.yihtc.com:10935/hls/stream_3
- rtmp://live.yihtc.com:10935/hls/stream_13
- rtmp://218.3.205.46/live/ggpd_sd
- rtmp://hls.hsrtv.cn/hls/hstv2
- rtmp://hls.hsrtv.cn/hls/hstv1
- rtmp://222.173.22.119:1935/live/jnyd_sd
- rtmp://222.173.22.119:1935/live/xwhd_hd
- rtmp://livetv.dhtv.cn:1935/live/peoples
- rtmp://livetv.dhtv.cn:1935/live/citylife
- rtmp://livetv.dhtv.cn:1935/live/financial
- rtmp://livetv.dhtv.cn:1935/live/news
0.8 版本说明
0.8.1 精益求精
0.8.2 破茧成蝶
V20220106
- 彻底修复全屏模式+webengine同时存在的情况下鼠标右键菜单无法弹出以及视频可能黑屏的BUG,这是Qt的BUG。
- 同时测试多屏幕下正常状态和全屏状态的情况,多屏幕不同分辨率。
- 增加其他设置界面,将串口设置、网络设置等移动到其他设置。随着功能越来越多,也很有必要单独拆分设置。
- 修复打印预览看不到文字的BUG,原来是设置了QGraphicsView的前景色导致的,把前景色和背景色设置成一样的了,其实是有文字的,鬼想得到QPrintPreviewDialog里面的预览原来用的是QGraphicsView绘制的。
- 修复qchart图表控件鼠标按下松开后会跟随窗体移动的BUG,因为qchart鼠标按下是UngrabMouse事件而不是MouseButtonRelease。
V20211220
- 重新梳理整个onvif模块,调整对应的结构,删除多余的变量和设置等,对应云台控制等操作需要指定profile,通过参数传入。
- 对应图片参数操作需要指定videosource,通过参数传入。
- 去除数据库字段mediaurl、ptzurl,因为这两个数据每次都是更新重新获取的,通过getServices获取,这两个字段改成了videosource、profiletoken,用来从数据库读取出来,每次使用的时候自动下发。
- 预置位表格中的按钮样式调整,去掉圆角,增加边距,效果更完美。
- 新增nvr多个通道onvif支持,改动onvif模块代码和数据库结构。
- 搜索设备后判断是否多个videosource,多个表示有多个视频源,一般是NVR,也有部分IPC自带多个视频源。
- 有多个则根据不同厂家不同规则,找出对应的每个通道的videosource、profiletoken、rtspmain、rtspsub用分隔符 | 插入到临时表格中。
- 摄像机管理界面接收到添加设备的时候,在addDevice槽函数中,判断发过来的数据,带了 | 要分别取出来作为通道添加到数据库中。
- 重新定义搜索的摄像机设备命名规则,按照摄像机#ip地址末尾数字的方式。
- 如果是NVR过来的摄像机,增加自动查找NVR的名称插入数据库。
- 获取预置位增加立即清空所有行,之前是先清空内容再根据读取到的预置位个数设置行数。
- 增加双击打开NVR(也叫分组)对应策略 0-最后空白通道 1-从头清空通道。
- 增加双击打开IPC(也叫设备)对应策略 0-最后空白通道 1-最后按下通道。
- 改进在分辨率不同缩放比例保持一致的UI体验,不受缩放比例的影响。
- 修正异或加密,增加对@String开头的密文进行过滤,防止高版本产生的配置文件到低版本的Qt程序不能正确解析的BUG。
- 如果打开视频流出错提示 Server returned 5XX Server Error reply 表示摄像机的码流满了,可能多个地方在拉取码流导致摄像机输出的视频流被占满,已经没有更多资源。
V20211205
- 地图内核增加了海量点接口。
- 路径规划模块彻底重写,支持重新绘制、沿线移动等模式,数据表格显示。
- 设备轨迹模块改成从gps点集合文本文件加载进行循环动态模拟移动,默认飞机图标,以便转动角度。
- 设备播放增加保存视频开关配置参数,可以直接在界面上开启,开启后,通过rtsp从nvr取流比如回放视频,可以将回放的视频保存MP4文件到本地。
- 修正Qt6通过属性设置标签labtip不能居中对齐的BUG。
- 封装通用的设置一堆按钮比如添加、删除、保存、导入、导出等按钮图形字体的函数,直接传入父面板即可,自动查找对应的objname设置图标,省去一堆重复代码。
- 新增飞行轨迹模块frmDeviceGps2,之前的frmDeviceGps作为通过外部函数调用移动。
- 样式统一整理规范,分类6大类:normal、black、light、dark、flat、other。
xxxxxxxxxx
261void QUIStyle::getStyle(QStringList &styleNames, QStringList &styleFiles)
2{
3 static QStringList names;
4 if (names.count() == 0) {
5 names << "黑蓝色" << "软件黑" << "视频黑";
6 names << "深黑色" << "深蓝色" << "深灰色";
7 names << "扁平黑" << "扁平蓝" << "扁平灰";
8 names << "浅黑色" << "浅蓝色" << "浅灰色";
9 names << "普通黑" << "普通蓝" << "普通灰";
10 names << "大蓝色" << "大紫色" << "大银色";
11 }
12
13 //中文皮肤名称对应样式表文件
14 static QStringList files;
15 if (files.count() == 0) {
16 files << ":/qss/blackblue.css" << ":/qss/blacksoft.css" << ":/qss/blackvideo.css";
17 files << ":/qss/darkblack.css" << ":/qss/darkblue.css" << ":/qss/darkgray.css";
18 files << ":/qss/flatblack.css" << ":/qss/flatblue.css" << ":/qss/flatgray.css";
19 files << ":/qss/lightblack.css" << ":/qss/lightblue.css" << ":/qss/lightgray.css";
20 files << ":/qss/normalblack.css" << ":/qss/normalblue.css" << ":/qss/normalgray.css";
21 files << ":/qss/otherblue.css" << ":/qss/otherpurple.css" << ":/qss/othersilvery.css";
22 }
23
24 styleNames = names;
25 styleFiles = files;
26}
V20211111
- ONVIF组件增加图片参数范围获取,之前默认0-255,有些设备是0-100 0-128之类的,获取后设置到滑动条范围。
- ONVIF组件增加网络参数设置,比如IP地址,子网掩码、网关地址、DNS设置等。
- ONVIF组件将结构体定义统一移到一个头文件onvifstruct.h,方便后期拓展管理。
- 预置位模块,调用、添加(调用)、删除三种功能,改成了以三个按钮的形式加到每个预置位信息的后面直接单击使用。之前是先选中预置位所在行,然后单击下面的按钮。
- 通道轮询全部移动单独的悬停的模块。
- 视频面板窗体指针改成了全局变量,多处需要引用。
- 修复1通道轮询后,再次启动程序无法正确加载通道面板布局的BUG。
- 修复底部通道切换,部分样式效果悬停时候颜色不正确的BUG。改成了取报警图标颜色和已处理颜色。
- 路径规划模块增加模拟轨迹设备自动旋转角度移动。
- 路径规划模块模拟轨迹增加移动间隔下拉框选择。
- 修复Qt4对应webkit模块不支持返回数组的问题,改成字符串拼接用 ; 符隔开。
- 修复Qt4对应webkit模块不支持路径规划的BUG,因为开启了实时路况属性。
- 路径规划增加绘制实时轨迹线条,不同颜色显示。
V20211101
- 修正开启轮询后关闭所有视频通道不弹出提示信息。
- 所有信息框增加阴影边框区分突出显示,并跟随系统换肤自动更新边框阴影。
- 修正视频轮询分隔符,将|改成;因为如果是竖杠遇到带有参数的url则会出错。
- 将设备图片统一存放到config/device目录,之前在config目录下,随着越来越多非常凌乱。
- 修复之前通过信号执行通道切换,对应文字显示反了的BUG(通道1交换到通道2,新的通道2应该显示之前通道1的文本)。
- 将鼠标按下两个通道交换的处理代码,复用信号槽切换通道的函数。
- 将视频监控布局切换部分单独提取类VideoBox,专门负责管理各种通道布局切换,复用代码并且方便后期拓展,这部分代码和具体的处理无关,一直以来就想要单独提取出来进行管理,后期可以方便的增加其他异形布局以及255通道布局等,很多项目都用到了这个切换逻辑。
- 同时增加了布局切换子菜单比如13画面子菜单切换到52_64通道。
- 修复Qt6中视频控件悬浮条无法显示的BUG,因为Qt6将void enterEvent(QEvent *);改成了void enterEvent(QEnterEvent *);也不打个招呼。这种改变编译也不会提示的。
- 数据库组件修正sqlserver数据库必须设置数据源的不足,改成了dsn字符串形式,不需要新建数据源也能直接通信。
- 数据库组件修正mysql数据库必须存在默认数据库mysql的不足,改成了不需要默认数据库也能正常通信。
- 数据库组件修正没有默认数据库也能在建立连接后新建数据库操作。
- 数据库脚本执行将DROP DATABASE IF EXIST改成了DROP DATABASE ,这样无论什么时候都能先删除原来的数据库然后再新建数据库CREATE DATABASE。有些数据库不支持IF EXIST。
V20211005
- 修正ffmpeg内核,在播放地址不存在的情况下,打开容易卡主引起崩溃的BUG,在打开回调函数中增加对线程停止标志位的判断,一旦在打开的回调中识别到需要停止线程则立即返回结束。
- 增加临时信息中间弹出框提示信息,比如一次性关闭所有通道的时候,界面会卡主的期间提示。
- 增加忙碌鼠标图标切换显示,忙完以后自动恢复鼠标样式。
- 修正ffmpeg内核,开始时间记录可能出现问题的BUG,会导致部分特殊MP4文件打不开。
- 应用程序关闭,增加全局退出信号关联到视频通道管理类,先关闭所有视频通道再彻底退出应用程序。不这样处理的话,发现vlc内核在开启了视频存储的时候,会关不掉程序。
- 修复在没有声音播放的情况下主动调用停止播放造成崩溃的BUG。
- 修复在linux系统上QUIWidget弹出的无边框窗体带系统标题栏的BUG。
- 修复ffmpeg内核关闭视频后opengl窗体来不及隐藏的BUG。
- 修复重复立即刷新打开所有通道,前一次还没执行后一次又来了的BUG,改成了定时器处理,在立即执行前将上一次还没来得及执行的先停止。
- 增加about关于对话框窗体,显示版本号、版权所有、网址、电话等信息。
- 所有弹出窗体都跟随软件主窗体默认居中,这个特性非常棒。
- 所有皮肤增加右键菜单选中图标样式、右键菜单二级子菜单右侧小三角箭头图标样式,单选框、复选框、禁用状态图标全部更新,从图形字体绘制,极其统一舒服。
- 着重对日志类savelog增加了最大行数、最大文件大小等参数设置,可以设置按照行数或者大小来自动分割日志文件。
- 日志类增加了可过滤不同的消息类型,不同消息类型增加消息头。
- 经过大量对比测试发现,使用miniblink浏览器内核,容易卡,说不定什么时候就失效了,问题集中在32位,64位的目前没有发现这个现象,webengine暂时没有这个现象,但是加载打开摄像机的网页配置,还是miniblink更优秀。
- 中文标题栏支持换行,既可以副标题写在英文标题上,也可以同等大小字体写在中文标题上。
V20210922
- 视频控件边框增加0像素选项,这样看起来没有边框,有些场景需要无缝拼接。
- 修复当采用NVR通道作为摄像机视频流显示的时候,ONVIF处理索引越界崩溃的情况,因为一台NVR同一个IP地址对应多个摄像机。
- 所有样式17套皮肤更新边框颜色。
- 系统信息增加对应的编译器名字、位数、版本等。
- 演示demo增加视频叠加演示功能,比如在主视频的左上角、右上角、左下角、右下角在增加一个视频缩略图显示。
- 新增天气预报模块,可设置城市、采集间隔、展示样式等。
- 增加了vlc内核下USB摄像头格式自动纠正,如果采用ffmpeg的格式video=USB2.0 PC CAMERA|1920x1080自动纠正。
- 纠正vlc内核下USB摄像头不自动拉伸的BUG。
- 修正vlc内核动态保存视频文件,文件命名不符合规范,重新按照设定的重命名。
- 修复vlc内核中USB摄像头会当做rtsp视频流的BUG。
- 天气预报模块新增城市显示,新增双击弹出天气预报设置,含打印信息。
- 系统信息,增加秘钥文件的内容,比如允许的设备数量、到期日期等。
- 修复配置文件一旦新增加节点,之前节点全部初始值运行的BUG,应该是存在的节点则读取节点值,不存在的节点以初始值运行。
V20210705
- 改进窗体居中显示算法,可设置参照窗体,默认基于当前屏幕中心,可设置参照主窗体则基于参照窗体,在大分辨率屏幕效果非常好,不然主窗体很小,弹个窗找不到还在很远的地方,还以为没有弹呢。
- 将登陆窗体、登出窗体、用户管理等公用界面,做成了通用库core_form。
- 修复MAC系统上无边框窗体无法最小化的BUG。
- 增加超级管理员密码A具有所有权限的机制,避免管理员误将系统设置权限取消后无法再次进去系统设置的问题。
- 图片参数增加锐度,图片参数设置滑块调节松开立即设置。
- 修复当没有启用图片地图的时候对应界面隐藏的时候保存设备坐标位置报错BUG,因为没有启用的情况下没有设置对应的对象指针。
V20210603
- 将onvif搜索的用户密码,设备播放界面的设备密码等配置参数全部改成了密文存储。
- 大量修改代码,全部支持Qt4-Qt6所有版本。
- 调整onvif代码执行机制,改成了异步执行。
- 云台协议增加了连续移动。
- 增加了预置位相关处理,包括获取预置位、调用预置位、添加预置位、删除预置位。
- 自动巡航按照预置位集合进行,采用定时器去调用预置位队列。
- 增加图文警情行数、窗口信息行数配置,0行表示自动处理。
- 做了大量的代码改进,比如onvif内核换成了QDom对象处理,之前是采用的QXmlQuery查询,由于XmlPatterns这个模块逐渐废弃了,而且在Qt6中不再有,所以彻底移除了XmlPatterns相关的代码,改用其他处理方式实现。
- 增加了预置位和自动巡航处理,其中包括获取预置位集合、调用预置位、添加预置位、删除预置位、设置起始位、调用起始位等。
- ONVIF内核几乎全部重写,将数据改成了结构体,比如设备信息、预置位信息、事件信息等,可以存储更多的数据,拓展也非常灵活。
- onvif处理部分增加了对非onvif设备的过滤,通过判断是否存在onvif地址。这样可以大大加快处理速度,打开视频的时候去实例化onvif通信,关闭视频的时候删除对应的onvif类,这样可以动态响应。
- 所有onvif指令改成了线程处理,处理完成一个立马处理下一个,排队处理。
V20210425
- 配置文件密码改成密文存储。
- 增加了无敌的牛逼的万能的完美入微级自动分页导航控件。
- 日志记录表增加索引,速度提升100倍以上。
- 新增多个设备轨迹 不同颜色+传入经纬度 单独示例。
- 对地图核心类所有覆盖物都增加颜色+粗细+透明度的参数,可动态传入对应值。
- 系统设置增加用户管理模块,可分别设置对应的权限。
- 万能权限管理算法,通过设置不同需要授权的模块名称,对应切换的按钮自动计算。
- 增加了appkey秘钥类,用于校验秘钥是否正确,运行时间等。
V20210403
- 增加全局变量AppData::LastLiveTime,记住程序最后的活动时间-包括键盘+鼠标活动,用于两个判断,一个是超过多久没有操作全屏下隐藏鼠标光标,一个是超过多久没有操作如果没有全屏则自动全屏。
- 增加App::TimeAutoFull配置参数用来判断比较超时自动全屏。
- 重命名为TimeHideCursor表示程序多久未操作自动隐藏光标,TimeAutoFull程序多久未操作自动全屏界面,下拉框选项值增加0,表示不启用此功能。
- 增加信息列表模块frmMsgList,用于图文列表显示信息,对应兄弟类frmMsgTable用于表格显示消息。
- 大改版,将中间部分全部改成了QMainWindow,子模块全部采用停靠窗体,可以悬浮半透明,自动记忆每个模块的最后的位置,启动后自动应用。
- 移除大改版后的所有不需要用的变量和配置参数,重新调整配置参数。
- 增加透明度参数用于停靠窗体独立出来后的透明度。
- 将摄像机控制部分比如云台+控制+预置位+巡航,单独分类到ipc模块,方便管理。
- 限定操作员不能移动停靠窗体等,需要管理员设计好。
- 修复系统设置中工作模式等切换造成的自动重启会弹出退出和登录两个窗体的BUG。
- 修复自动登录用户计算不正确的BUG,要以最后登录的用户为准。
V20210322
- USB摄像头增加参数帧率,第二个参数是分辨率,第三个参数为帧率,不设置则采用默认的帧率,video=USB2.0 PC CAMERA|1920x1080|25。
- 增加独立的demo模块,专门用于测试监控系统中用到的组件和控件,演示如何使用,比如视频图片界面演示从文件夹读取图片绘制到窗体,视频窗体演示系统的核心组件视频控件的设置参数如何使用等。
- 增加了对其他数据库的支持,比如posgres、oracle、odbc、kingbase等数据库,理论上只要支持odbc数据源方式的都支持。
- 增加IndexStart启动窗体索引配置参数,0-主程序 1-演示示例。
V20210305
- 修复数据库有时候没加载到的BUG。
- 新增配置参数控制画面切换的菜单和快捷图标是否显示。
- ffmpeg内核增加了可动态保存机制,点击开始保存按钮启动保存,单击结束则生成视频文件,如此往复。
- 海康内核判断主码流子码流改成了 /101? 和 /main/ 同时判断。
- 新增多屏幕的支持,自动在对应屏幕最大化全屏,对话框位置,右下角提示框等。
- 再次分类存放代码文件,分成core ui class三大类。
- 系统配置更改视频控件参数,统一一个函数设置,initCommonVideoWidget函数中做了过滤,必须关闭状态的视频控件设置才起作用。
- 设备播放模块增加大华NVR的远程回放地址,其他地址计算算法调整。
- 新增界面模块功能启用配置参数。
- 新增主界面顶部导航模块中间界面,用于不同的运行模式加载不同的模块。
0.8.3 快速迭代
V20201212
- 增加USB摄像机分辨率设置,直接url带掉。
- 所有地图内核公用一个,复用代码。
- 增加地图默认级别和中心点坐标设置参数。
- 主界面四个模块独立出来,做成了可配置,这样后期可以任意位置放置自定义模块。
- 四个模块标题栏自定义。
- vlc内核和mpv内核的离线判断,当句柄模式下,统一为getLastTime,当调用该函数的时候自动查询播放状态,如果正在播放则自动更新时间为当前时间。
- 将各种在代码中define定义不同内核的代码全部优化,统一为一个类,很大减少代码量,统一为CommonVideoWidget和CommonVideoManage类。
V20201108
- 轮询点模块增加批量生成功能。
- 录像机、摄像机、轮询点,增加导入导出功能。
- ffmpeg内核增加读取帧回调,超时识别,可以快速识别掉线。
20200828
- 增加了云台控制过滤,没有打开的视频禁用云台。
- linux上全屏BUG修复,采用showfullscreen。
- 增加轮询点管理模块。
- 修正轮询的可能崩溃的BUG。
V20200730
- 系统设置增加了视频上传模块,用来将本地的视频文件传输到服务器,多线程并发。
- 视频监控内核新增MPV内核,修正了其他内核的部分函数和处理。
- 海康内核进行大改动,同时支持视频流和本地MP4文件播放,自动分析切换。
- 海康内核增加回调处理,可以拿到每一张图片。
- 海康内核进行了linux上的实验,可以正常播放。
- ffmpeg内核增加保存到MP4。
- 本地文件回放vlc部分增加进度切换等。
- 悬浮条关闭按钮增加实际处理,之前只是打印消息。
- 改进了vlc和mpv的事件回调机制,使其同时支持qt4+qt5。
V20200620
- 增加了opengl显示实时视频,CPU占用极低。
- 增加了地图上设备点位置的调整。
- 设备点双击弹出实时视频预览。
- 增加GPS运动轨迹显示。
- ffmpeg解码类增加了音频播放,采用的QAudioOutput。
V20191105
- 增加云台控制功能,可以上下左右等八个方位控制云台,默认采用相对移动,云台中间按下表示复位。
- 系统设置增加码流类型选择,默认子码流,切换完自动应用。
- 云台控制增加速度功能,值越大,速度越快。
- 增加焦距控制,可放大缩小,速度也可控制。
1 用户登录退出
1.1 用户登录