Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Z
ZLMediaKit
概览
Overview
Details
Activity
Cycle Analytics
版本库
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
问题
0
Issues
0
列表
Board
标记
里程碑
合并请求
0
Merge Requests
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
Snippets
成员
Collapse sidebar
Close sidebar
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
张翔宇
ZLMediaKit
Commits
5b6ff0af
Commit
5b6ff0af
authored
Jan 11, 2022
by
ziyue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
完善mingw编译环境的适配
parent
fdcc29e0
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
14 行增加
和
17 行删除
+14
-17
3rdpart/ZLToolKit
+1
-1
src/Common/MediaSource.cpp
+0
-8
src/Common/MediaSource.h
+6
-2
src/Rtp/GB28181Process.cpp
+3
-3
src/Rtp/GB28181Process.h
+1
-1
tests/CMakeLists.txt
+3
-2
没有找到文件。
ZLToolKit
@
dd101bcc
Subproject commit
86407d4cea8a344cf737082215fe7ffcabaa33b3
Subproject commit
dd101bcc31290e3d1ec1ae939d937f2712719a0d
src/Common/MediaSource.cpp
查看文件 @
5b6ff0af
...
...
@@ -747,14 +747,6 @@ std::shared_ptr<MediaSourceEvent> MediaSourceEventInterceptor::getDelegate() con
/////////////////////////////////////FlushPolicy//////////////////////////////////////
template
<>
bool
PacketCache
<
RtpPacket
>::
flushImmediatelyWhenCloseMerge
()
{
//因为rtp的包很小,一个RtpPacket包中也不是完整的一帧图像,所以在关闭合并写时,
//还是有必要缓冲一帧的rtp(也就是时间戳相同的rtp)再输出,这样虽然会增加一帧的延时
//但是却对性能提升很大,这样做还是比较划算的
return
false
;
}
static
bool
isFlushAble_default
(
bool
is_video
,
uint64_t
last_stamp
,
uint64_t
new_stamp
,
size_t
cache_size
)
{
if
(
new_stamp
+
500
<
last_stamp
)
{
//时间戳回退比较大(可能seek中),由于rtp中时间戳是pts,是可能存在一定程度的回退的
...
...
src/Common/MediaSource.h
查看文件 @
5b6ff0af
...
...
@@ -376,9 +376,13 @@ private:
}
bool
flushImmediatelyWhenCloseMerge
()
{
//一般的协议关闭合并写时,立即刷新缓存,这样可以减少一帧的延时,但是rtp例外,请看相应的模板特例化函数
//一般的协议关闭合并写时,立即刷新缓存,这样可以减少一帧的延时,但是rtp例外
//因为rtp的包很小,一个RtpPacket包中也不是完整的一帧图像,所以在关闭合并写时,
//还是有必要缓冲一帧的rtp(也就是时间戳相同的rtp)再输出,这样虽然会增加一帧的延时
//但是却对性能提升很大,这样做还是比较划算的
GET_CONFIG
(
int
,
mergeWriteMS
,
General
::
kMergeWriteMS
);
return
mergeWriteMS
<=
0
;
return
std
::
is_same
<
packet
,
RtpPacket
>::
value
?
false
:
(
mergeWriteMS
<=
0
)
;
}
private
:
...
...
src/Rtp/GB28181Process.cpp
查看文件 @
5b6ff0af
...
...
@@ -50,10 +50,10 @@ private:
///////////////////////////////////////////////////////////////////////////////////////////
GB28181Process
::
GB28181Process
(
const
MediaInfo
&
media_info
,
MediaSinkInterface
*
interface
)
{
assert
(
interface
);
GB28181Process
::
GB28181Process
(
const
MediaInfo
&
media_info
,
MediaSinkInterface
*
sink
)
{
assert
(
sink
);
_media_info
=
media_info
;
_interface
=
interface
;
_interface
=
sink
;
}
GB28181Process
::~
GB28181Process
()
{}
...
...
src/Rtp/GB28181Process.h
查看文件 @
5b6ff0af
...
...
@@ -25,7 +25,7 @@ class RtpReceiverImp;
class
GB28181Process
:
public
ProcessInterface
{
public
:
typedef
std
::
shared_ptr
<
GB28181Process
>
Ptr
;
GB28181Process
(
const
MediaInfo
&
media_info
,
MediaSinkInterface
*
interface
);
GB28181Process
(
const
MediaInfo
&
media_info
,
MediaSinkInterface
*
sink
);
~
GB28181Process
()
override
;
/**
...
...
tests/CMakeLists.txt
查看文件 @
5b6ff0af
...
...
@@ -2,14 +2,15 @@
aux_source_directory
(
. TEST_SRC_LIST
)
foreach
(
TEST_SRC
${
TEST_SRC_LIST
}
)
get_filename_component
(
TEST_EXE_NAME
${
TEST_SRC
}
NAME_WE
)
if
(
NOT ENABLE_WEBRTC
)
# 暂时过滤掉依赖 WebRTC 的测试模块
if
(
"
${
TEST_
SRC
}
"
MATCHES
"test_rtcp_nack\.cpp
"
)
if
(
"
${
TEST_
EXE_NAME
}
"
MATCHES
"test_rtcp_nack
"
)
continue
()
endif
()
endif
()
get_filename_component
(
TEST_EXE_NAME
${
TEST_SRC
}
NAME_WE
)
message
(
STATUS
"add test:
${
TEST_EXE_NAME
}
"
)
add_executable
(
${
TEST_EXE_NAME
}
${
TEST_SRC
}
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论