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
6a7c76be
Commit
6a7c76be
authored
Oct 25, 2018
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
添加新的sdp解析算法
parent
062bdd6e
隐藏空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
122 行增加
和
36 行删除
+122
-36
src/Player/Frame.h
+1
-0
src/RtmpMuxer/RtmpMetedata.h
+1
-1
src/Rtsp/Rtsp.cpp
+82
-33
src/Rtsp/Rtsp.h
+37
-1
src/RtspMuxer/RtspSdp.h
+1
-1
没有找到文件。
src/Player/Frame.h
查看文件 @
6a7c76be
...
...
@@ -44,6 +44,7 @@ typedef enum {
TrackInvalid
=
-
1
,
TrackVideo
=
0
,
TrackAudio
,
TrackTitle
,
TrackMax
}
TrackType
;
...
...
src/RtmpMuxer/RtmpMetedata.h
查看文件 @
6a7c76be
...
...
@@ -75,7 +75,7 @@ public:
* @return
*/
TrackType
getTrackType
()
const
override
{
return
Track
Invalid
;
return
Track
Title
;
}
/**
...
...
src/Rtsp/Rtsp.cpp
查看文件 @
6a7c76be
...
...
@@ -49,78 +49,124 @@ string FindField(const char* buf, const char* start, const char *end ,int bufSiz
}
return
string
(
msg_start
,
msg_end
);
}
int
parserSDP
(
const
string
&
sdp
,
RtspTrack
Track
[
2
])
{
map
<
string
,
map
<
char
,
map
<
string
,
string
>
>
>
sdpAttr
;
string
sdpTrack
=
""
;
void
SdpAttr
::
load
(
const
string
&
sdp
)
{
_track_map
.
clear
();
string
key
;
SdpTrack
::
Ptr
track
=
std
::
make_shared
<
SdpTrack
>
();
auto
lines
=
split
(
sdp
,
"
\n
"
);
for
(
auto
&
line
:
lines
){
trim
(
line
);
if
(
line
.
size
()
<
2
){
continue
;
}
if
(
line
[
1
]
!=
'='
){
if
(
line
.
size
()
<
2
||
line
[
1
]
!=
'='
){
continue
;
}
char
opt
=
line
[
0
];
string
opt_val
=
line
.
substr
(
2
);
switch
(
opt
){
case
'o'
:
track
->
_o
=
opt_val
;
break
;
case
's'
:
track
->
_s
=
opt_val
;
break
;
case
'i'
:
track
->
_i
=
opt_val
;
break
;
case
'c'
:
case
't'
:{
sdpAttr
[
sdpTrack
][
opt
][
""
]
=
opt_val
;
}
track
->
_c
=
opt_val
;
break
;
case
't'
:
track
->
_t
=
opt_val
;
break
;
case
'b'
:
track
->
_b
=
opt_val
;
break
;
case
'm'
:{
sdpTrack
=
FindField
(
opt_val
.
data
(),
nullptr
,
" "
);
sdpAttr
[
sdpTrack
][
opt
][
""
]
=
opt_val
;
_track_map
[
key
]
=
track
;
track
=
std
::
make_shared
<
SdpTrack
>
();
key
=
FindField
(
opt_val
.
data
(),
nullptr
,
" "
);;
track
->
_m
=
opt_val
;
}
break
;
case
'a'
:{
string
attr
=
FindField
(
opt_val
.
data
(),
nullptr
,
":"
);
if
(
attr
.
empty
()){
sdpAttr
[
sdpTrack
][
opt
][
opt_val
]
=
opt_val
;
track
->
_attr
[
opt_val
]
=
""
;
}
else
{
sdpAttr
[
sdpTrack
][
opt
]
[
attr
]
=
FindField
(
opt_val
.
data
(),
":"
,
nullptr
);
track
->
_attr
[
attr
]
=
FindField
(
opt_val
.
data
(),
":"
,
nullptr
);
}
}
break
;
default
:
track
->
_other
[
opt
]
=
opt_val
;
break
;
}
}
_track_map
[
key
]
=
track
;
for
(
auto
&
pr
:
sdpAttr
)
{
TrackType
trackType
=
TrackInvalid
;
if
(
pr
.
first
==
"video"
)
{
trackType
=
TrackVideo
;
for
(
auto
&
pr
:
_track_map
)
{
auto
&
track
=
*
pr
.
second
;
if
(
pr
.
first
==
""
)
{
track
.
_type
=
TrackTitle
;
}
else
if
(
pr
.
first
==
"video"
)
{
track
.
_type
=
TrackVideo
;
}
else
if
(
pr
.
first
==
"audio"
)
{
trackType
=
TrackAudio
;
}
else
if
(
pr
.
first
==
""
)
{
//title
auto
range
=
pr
.
second
[
'a'
][
"range"
];
char
name
[
16
]
=
{
0
},
start
[
16
]
=
{
0
},
end
[
16
]
=
{
0
};
if
(
2
==
sscanf
(
range
.
data
(),
"%15[^=]=%15[^-]-%15s"
,
name
,
start
,
end
))
{
track
.
_type
=
TrackAudio
;
}
else
{
track
.
_type
=
TrackInvalid
;
}
auto
it
=
track
.
_attr
.
find
(
"range"
);
if
(
it
!=
track
.
_attr
.
end
())
{
char
name
[
16
]
=
{
0
},
start
[
16
]
=
{
0
},
end
[
16
]
=
{
0
};
int
ret
=
sscanf
(
it
->
second
.
data
(),
"%15[^=]=%15[^-]-%15s"
,
name
,
start
,
end
);
if
(
3
==
ret
||
2
==
ret
)
{
if
(
strcmp
(
start
,
"now"
)
==
0
)
{
strcpy
(
start
,
"0"
);
}
track
.
_start
=
atof
(
start
);
track
.
_end
=
atof
(
end
);
track
.
_duration
=
track
.
_end
-
track
.
_start
;
}
DebugL
<<
range
;
continue
;
}
else
{
continue
;
}
auto
rtpmap
=
pr
.
second
[
'a'
][
"rtpmap"
];
int
pt
,
samplerate
;
char
codec
[
16
]
=
{
0
};
if
(
3
==
sscanf
(
rtpmap
.
data
(),
"%d %15[^/]/%d"
,
&
pt
,
codec
,
&
samplerate
))
{
it
=
track
.
_attr
.
find
(
"rtpmap"
);
if
(
it
!=
track
.
_attr
.
end
()){
auto
rtpmap
=
it
->
second
;
int
pt
,
samplerate
;
char
codec
[
16
]
=
{
0
};
if
(
3
==
sscanf
(
rtpmap
.
data
(),
"%d %15[^/]/%d"
,
&
pt
,
codec
,
&
samplerate
))
{
track
.
_pt
=
pt
;
track
.
_codec
=
codec
;
track
.
_samplerate
=
samplerate
;
}
}
it
=
track
.
_attr
.
find
(
"fmtp"
);
if
(
it
!=
track
.
_attr
.
end
())
{
track
.
_fmtp
=
it
->
second
;
}
it
=
track
.
_attr
.
find
(
"control"
);
if
(
it
!=
track
.
_attr
.
end
())
{
track
.
_control
=
it
->
second
;
}
DebugL
<<
codec
;
}
}
SdpTrack
::
Ptr
SdpAttr
::
getTrack
(
TrackType
type
)
{
for
(
auto
&
pr
:
_track_map
){
if
(
pr
.
second
->
_type
==
type
){
return
pr
.
second
;
}
}
return
nullptr
;
}
int
parserSDP
(
const
string
&
sdp
,
RtspTrack
Track
[
2
])
{
int
track_cnt
=
0
;
string
::
size_type
pos_head
=
0
;
while
((
pos_head
=
sdp
.
find
(
"m="
,
pos_head
))
!=
string
::
npos
)
{
...
...
@@ -169,6 +215,7 @@ static onceToken s_token([](){
"a=recvonly"
;
RtspTrack
track
[
2
];
parserSDP
(
str
,
track
);
SdpAttr
attr
(
str
);
track
[
0
].
inited
=
true
;
});
bool
MakeNalu
(
uint8_t
in
,
NALU
&
nal
)
{
...
...
@@ -190,3 +237,5 @@ bool MakeFU(uint8_t in, FU &fu) {
}
return
true
;
}
src/Rtsp/Rtsp.h
查看文件 @
6a7c76be
...
...
@@ -38,6 +38,43 @@ using namespace std;
using
namespace
toolkit
;
using
namespace
mediakit
;
class
SdpTrack
{
public
:
typedef
std
::
shared_ptr
<
SdpTrack
>
Ptr
;
string
_m
;
string
_o
;
string
_s
;
string
_i
;
string
_c
;
string
_t
;
string
_b
;
float
_duration
=
0
;
float
_start
=
0
;
float
_end
=
0
;
map
<
char
,
string
>
_other
;
map
<
string
,
string
>
_attr
;
public
:
int
_pt
;
string
_codec
;
int
_samplerate
;
string
_fmtp
;
string
_control
;
TrackType
_type
;
};
class
SdpAttr
{
public
:
typedef
std
::
shared_ptr
<
SdpAttr
>
Ptr
;
SdpAttr
(
const
string
&
sdp
){
load
(
sdp
);};
~
SdpAttr
(){}
void
load
(
const
string
&
sdp
);
SdpTrack
::
Ptr
getTrack
(
TrackType
type
);
private
:
map
<
string
,
SdpTrack
::
Ptr
>
_track_map
;
};
class
RtspTrack
{
public
:
...
...
@@ -63,7 +100,6 @@ public:
string
FindField
(
const
char
*
buf
,
const
char
*
start
,
const
char
*
end
,
int
bufSize
=
0
);
int
parserSDP
(
const
string
&
sdp
,
RtspTrack
Track
[
2
]);
struct
StrCaseCompare
{
bool
operator
()(
const
string
&
__x
,
const
string
&
__y
)
const
...
...
src/RtspMuxer/RtspSdp.h
查看文件 @
6a7c76be
...
...
@@ -115,7 +115,7 @@ public:
* @return
*/
TrackType
getTrackType
()
const
override
{
return
Track
Invalid
;
return
Track
Title
;
}
/**
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论