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
c4aaaa11
Commit
c4aaaa11
authored
Oct 12, 2019
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
优化hls生成
parent
7f203ce9
隐藏空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
78 行增加
和
57 行删除
+78
-57
src/Common/MediaSink.cpp
+11
-10
src/MediaFile/HlsMaker.cpp
+34
-30
src/MediaFile/HlsMaker.h
+22
-9
src/MediaFile/HlsMakerImp.cpp
+6
-5
src/MediaFile/HlsMakerImp.h
+5
-3
没有找到文件。
src/Common/MediaSink.cpp
查看文件 @
c4aaaa11
...
...
@@ -35,16 +35,6 @@ void MediaSink::addTrack(const Track::Ptr &track_in) {
//克隆Track,只拷贝其数据,不拷贝其数据转发关系
auto
track
=
track_in
->
clone
();
weak_ptr
<
MediaSink
>
weakSelf
=
shared_from_this
();
track
->
addDelegate
(
std
::
make_shared
<
FrameWriterInterfaceHelper
>
([
weakSelf
](
const
Frame
::
Ptr
&
frame
){
auto
strongSelf
=
weakSelf
.
lock
();
if
(
!
strongSelf
){
return
;
}
if
(
!
strongSelf
->
_anyTrackUnReady
){
strongSelf
->
onTrackFrame
(
frame
);
}
}));
auto
codec_id
=
track
->
getCodecId
();
_track_map
[
codec_id
]
=
track
;
auto
lam
=
[
this
,
track
](){
...
...
@@ -58,6 +48,17 @@ void MediaSink::addTrack(const Track::Ptr &track_in) {
_trackReadyCallback
[
codec_id
]
=
lam
;
_ticker
.
resetTime
();
}
weak_ptr
<
MediaSink
>
weakSelf
=
shared_from_this
();
track
->
addDelegate
(
std
::
make_shared
<
FrameWriterInterfaceHelper
>
([
weakSelf
](
const
Frame
::
Ptr
&
frame
){
auto
strongSelf
=
weakSelf
.
lock
();
if
(
!
strongSelf
){
return
;
}
if
(
!
strongSelf
->
_anyTrackUnReady
){
strongSelf
->
onTrackFrame
(
frame
);
}
}));
}
void
MediaSink
::
resetTracks
()
{
...
...
src/MediaFile/HlsMaker.cpp
查看文件 @
c4aaaa11
...
...
@@ -43,11 +43,6 @@ void HlsMaker::makeIndexFile(bool eof) {
char
file_content
[
1024
];
int
maxSegmentDuration
=
0
;
//停止写之后将最后的片段也写进m3u8文件中
if
(
eof
&&
_stampInc
>
0
)
{
_seg_dur_list
.
push_back
(
std
::
make_tuple
(
_stampInc
,
_last_file_name
));
}
for
(
auto
&
tp
:
_seg_dur_list
)
{
int
dur
=
std
::
get
<
0
>
(
tp
);
if
(
dur
>
maxSegmentDuration
)
{
...
...
@@ -83,18 +78,16 @@ void HlsMaker::makeIndexFile(bool eof) {
void
HlsMaker
::
inputData
(
void
*
data
,
uint32_t
len
,
uint32_t
timestamp
)
{
//分片数据中断结束
if
(
data
&&
len
)
{
addNewFile
(
timestamp
);
onWriteFile
((
char
*
)
data
,
len
);
addNewSegment
(
timestamp
);
onWriteSegment
((
char
*
)
data
,
len
);
//记录上次写入数据时间
_ticker_last_data
.
resetTime
();
}
else
{
_noData
=
true
;
_stampInc
=
_ticker
.
elapsedTime
();
_seg_dur_list
.
push_back
(
std
::
make_tuple
(
_stampInc
,
_last_file_name
));
delOldFile
();
makeIndexFile
();
flushLastSegment
(
true
);
}
}
void
HlsMaker
::
delOld
File
()
{
void
HlsMaker
::
delOld
Segment
()
{
if
(
_seg_number
==
0
){
//如果设置为保留0个切片,则认为是保存为点播
return
;
...
...
@@ -106,28 +99,38 @@ void HlsMaker::delOldFile() {
//但是实际保存的切片个数比m3u8所述多两个,这样做的目的是防止播放器在切片删除前能下载完毕
if
(
_file_index
>=
_seg_number
+
4
)
{
onDel
File
(
_file_index
-
_seg_number
-
4
);
onDel
Segment
(
_file_index
-
_seg_number
-
4
);
}
}
void
HlsMaker
::
addNewFile
(
uint32_t
)
{
//上次分片数据中断结束,重置时间避免中途的等待
if
(
_noData
)
{
_ticker
.
resetTime
();
_last_file_name
=
onOpenFile
(
_file_index
++
);
_noData
=
false
;
void
HlsMaker
::
addNewSegment
(
uint32_t
)
{
if
(
!
_last_file_name
.
empty
()
&&
_ticker
.
elapsedTime
()
<
_seg_duration
*
1000
){
//存在上个切片,并且未到分片时间
return
;
}
_stampInc
=
_ticker
.
elapsedTime
();
if
(
_file_index
==
0
||
_stampInc
>=
_seg_duration
*
1000
)
{
_ticker
.
resetTime
();
auto
file_name
=
onOpenFile
(
_file_index
);
if
(
_file_index
++
>
0
)
{
_seg_dur_list
.
push_back
(
std
::
make_tuple
(
_stampInc
,
_last_file_name
));
delOldFile
();
makeIndexFile
();
}
_last_file_name
=
file_name
;
//关闭并保存上一个切片
flushLastSegment
();
//新增切片
_last_file_name
=
onOpenSegment
(
_file_index
++
);
//重置切片计时器
_ticker
.
resetTime
();
}
void
HlsMaker
::
flushLastSegment
(
bool
eof
){
if
(
_last_file_name
.
empty
()){
//不存在上个切片
return
;
}
//文件创建到最后一次数据写入的时间即为切片长度
auto
seg_dur
=
_ticker
.
elapsedTime
()
-
_ticker_last_data
.
elapsedTime
();
if
(
seg_dur
<=
0
){
seg_dur
=
100
;
}
_seg_dur_list
.
push_back
(
std
::
make_tuple
(
seg_dur
,
_last_file_name
));
delOldSegment
();
makeIndexFile
(
eof
);
_last_file_name
.
clear
();
}
}
//
namespace
mediakit
\ No newline at end of file
src/MediaFile/HlsMaker.h
查看文件 @
c4aaaa11
...
...
@@ -60,20 +60,20 @@ protected:
* @param index
* @return
*/
virtual
string
onOpen
File
(
int
index
)
=
0
;
virtual
string
onOpen
Segment
(
int
index
)
=
0
;
/**
* 删除ts切片文件回调
* @param index
*/
virtual
void
onDel
File
(
int
index
)
=
0
;
virtual
void
onDel
Segment
(
int
index
)
=
0
;
/**
* 写ts切片文件回调
* @param data
* @param len
*/
virtual
void
onWrite
File
(
const
char
*
data
,
int
len
)
=
0
;
virtual
void
onWrite
Segment
(
const
char
*
data
,
int
len
)
=
0
;
/**
* 写m3u8文件回调
...
...
@@ -83,20 +83,33 @@ protected:
virtual
void
onWriteHls
(
const
char
*
data
,
int
len
)
=
0
;
/**
* 关闭上个ts切片并且写入m3u8索引
* @param eof
*/
void
flushLastSegment
(
bool
eof
=
false
);
private
:
/**
* 生成m3u8文件
* @param eof true代表点播
*/
void
makeIndexFile
(
bool
eof
=
false
);
void
delOldFile
();
void
addNewFile
(
uint32_t
timestamp
);
protected
:
uint32_t
_seg_number
=
0
;
/**
* 删除旧的ts切片
*/
void
delOldSegment
();
/**
* 添加新的ts切片
* @param timestamp
*/
void
addNewSegment
(
uint32_t
timestamp
);
private
:
bool
_noData
=
false
;
int
_stampInc
=
0
;
uint32_t
_seg_number
=
0
;
float
_seg_duration
=
0
;
uint64_t
_file_index
=
0
;
Ticker
_ticker
;
Ticker
_ticker_last_data
;
string
_last_file_name
;
std
::
deque
<
tuple
<
int
,
string
>
>
_seg_dur_list
;
};
...
...
src/MediaFile/HlsMakerImp.cpp
查看文件 @
c4aaaa11
...
...
@@ -40,6 +40,7 @@ HlsMakerImp::HlsMakerImp(const string &m3u8_file,
_path_hls
=
m3u8_file
;
_params
=
params
;
_buf_size
=
bufSize
;
_is_vod
=
seg_number
==
0
;
_file_buf
.
reset
(
new
char
[
bufSize
],[](
char
*
ptr
){
delete
[]
ptr
;
});
...
...
@@ -47,14 +48,14 @@ HlsMakerImp::HlsMakerImp(const string &m3u8_file,
HlsMakerImp
::~
HlsMakerImp
()
{
//录制完了
makeIndexFile
(
true
);
if
(
_seg_number
){
flushLastSegment
(
true
);
if
(
!
_is_vod
){
//hls直播才删除文件
File
::
delete_file
(
_path_prefix
.
data
());
}
}
string
HlsMakerImp
::
onOpen
File
(
int
index
)
{
string
HlsMakerImp
::
onOpen
Segment
(
int
index
)
{
auto
full_path
=
fullPath
(
index
);
_file
=
makeFile
(
full_path
,
true
);
if
(
!
_file
){
...
...
@@ -67,12 +68,12 @@ string HlsMakerImp::onOpenFile(int index) {
return
StrPrinter
<<
index
<<
".ts"
<<
"?"
<<
_params
;
}
void
HlsMakerImp
::
onDel
File
(
int
index
)
{
void
HlsMakerImp
::
onDel
Segment
(
int
index
)
{
//WarnL << index;
File
::
delete_file
(
fullPath
(
index
).
data
());
}
void
HlsMakerImp
::
onWrite
File
(
const
char
*
data
,
int
len
)
{
void
HlsMakerImp
::
onWrite
Segment
(
const
char
*
data
,
int
len
)
{
if
(
_file
)
{
fwrite
(
data
,
len
,
1
,
_file
.
get
());
}
...
...
src/MediaFile/HlsMakerImp.h
查看文件 @
c4aaaa11
...
...
@@ -44,9 +44,9 @@ public:
uint32_t
seg_number
=
3
);
virtual
~
HlsMakerImp
();
protected
:
string
onOpen
File
(
int
index
)
override
;
void
onDel
File
(
int
index
)
override
;
void
onWrite
File
(
const
char
*
data
,
int
len
)
override
;
string
onOpen
Segment
(
int
index
)
override
;
void
onDel
Segment
(
int
index
)
override
;
void
onWrite
Segment
(
const
char
*
data
,
int
len
)
override
;
void
onWriteHls
(
const
char
*
data
,
int
len
)
override
;
private
:
string
fullPath
(
int
index
);
...
...
@@ -58,6 +58,8 @@ private:
string
_path_hls
;
string
_params
;
int
_buf_size
;
//是否为点播
bool
_is_vod
;
};
}
//namespace mediakit
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论