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
b3fcb4c0
Commit
b3fcb4c0
authored
Dec 04, 2019
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
重写mp4录制驱动机制
parent
d5a81d71
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
8 个修改的文件
包含
101 行增加
和
43 行删除
+101
-43
src/Common/MediaSource.cpp
+42
-7
src/Common/MultiMediaSourceMuxer.h
+25
-26
src/Common/config.cpp
+1
-0
src/Common/config.h
+5
-1
src/Record/MP4Recorder.cpp
+2
-2
src/Record/MP4Recorder.h
+7
-5
src/Record/Recorder.cpp
+0
-0
src/Record/Recorder.h
+19
-2
没有找到文件。
src/Common/MediaSource.cpp
查看文件 @
b3fcb4c0
...
@@ -80,6 +80,19 @@ vector<Track::Ptr> MediaSource::getTracks(bool trackReady) const {
...
@@ -80,6 +80,19 @@ vector<Track::Ptr> MediaSource::getTracks(bool trackReady) const {
void
MediaSource
::
setTrackSource
(
const
std
::
weak_ptr
<
TrackSource
>
&
track_src
)
{
void
MediaSource
::
setTrackSource
(
const
std
::
weak_ptr
<
TrackSource
>
&
track_src
)
{
_track_source
=
track_src
;
_track_source
=
track_src
;
weak_ptr
<
MediaSource
>
weakPtr
=
shared_from_this
();
EventPollerPool
::
Instance
().
getPoller
()
->
async
([
weakPtr
,
this
](){
auto
strongPtr
=
weakPtr
.
lock
();
if
(
!
strongPtr
)
{
return
;
}
NoticeCenter
::
Instance
().
emitEvent
(
Broadcast
::
kBroadcastMediaResetTracks
,
_strSchema
,
_strVhost
,
_strApp
,
_strId
,
*
this
);
},
false
);
}
}
void
MediaSource
::
setListener
(
const
std
::
weak_ptr
<
MediaSourceEvent
>
&
listener
){
void
MediaSource
::
setListener
(
const
std
::
weak_ptr
<
MediaSourceEvent
>
&
listener
){
...
@@ -293,13 +306,20 @@ void MediaSource::regist() {
...
@@ -293,13 +306,20 @@ void MediaSource::regist() {
g_mapMediaSrc
[
_strSchema
][
_strVhost
][
_strApp
][
_strId
]
=
shared_from_this
();
g_mapMediaSrc
[
_strSchema
][
_strVhost
][
_strApp
][
_strId
]
=
shared_from_this
();
}
}
InfoL
<<
_strSchema
<<
" "
<<
_strVhost
<<
" "
<<
_strApp
<<
" "
<<
_strId
;
InfoL
<<
_strSchema
<<
" "
<<
_strVhost
<<
" "
<<
_strApp
<<
" "
<<
_strId
;
NoticeCenter
::
Instance
().
emitEvent
(
Broadcast
::
kBroadcastMediaChanged
,
weak_ptr
<
MediaSource
>
weakPtr
=
shared_from_this
();
true
,
EventPollerPool
::
Instance
().
getPoller
()
->
async
([
weakPtr
,
this
](){
_strSchema
,
auto
strongPtr
=
weakPtr
.
lock
();
_strVhost
,
if
(
!
strongPtr
)
{
_strApp
,
return
;
_strId
,
}
*
this
);
NoticeCenter
::
Instance
().
emitEvent
(
Broadcast
::
kBroadcastMediaChanged
,
true
,
_strSchema
,
_strVhost
,
_strApp
,
_strId
,
*
this
);
},
false
);
}
}
bool
MediaSource
::
unregist
()
{
bool
MediaSource
::
unregist
()
{
//反注册该源
//反注册该源
...
@@ -328,6 +348,21 @@ void MediaSource::unregisted(){
...
@@ -328,6 +348,21 @@ void MediaSource::unregisted(){
_strApp
,
_strApp
,
_strId
,
_strId
,
*
this
);
*
this
);
weak_ptr
<
MediaSource
>
weakPtr
=
shared_from_this
();
EventPollerPool
::
Instance
().
getPoller
()
->
async
([
weakPtr
,
this
](){
auto
strongPtr
=
weakPtr
.
lock
();
if
(
!
strongPtr
)
{
return
;
}
NoticeCenter
::
Instance
().
emitEvent
(
Broadcast
::
kBroadcastMediaChanged
,
true
,
_strSchema
,
_strVhost
,
_strApp
,
_strId
,
*
this
);
},
false
);
}
}
...
...
src/Common/MultiMediaSourceMuxer.h
查看文件 @
b3fcb4c0
...
@@ -49,14 +49,32 @@ public:
...
@@ -49,14 +49,32 @@ public:
if
(
bEanbleRtsp
)
{
if
(
bEanbleRtsp
)
{
_rtsp
=
std
::
make_shared
<
RtspMediaSourceMuxer
>
(
vhost
,
strApp
,
strId
,
std
::
make_shared
<
TitleSdp
>
(
dur_sec
));
_rtsp
=
std
::
make_shared
<
RtspMediaSourceMuxer
>
(
vhost
,
strApp
,
strId
,
std
::
make_shared
<
TitleSdp
>
(
dur_sec
));
}
}
if
(
bEanbleHls
){
_hls
.
reset
(
Recorder
::
createHlsRecorder
(
vhost
,
strApp
,
strId
));
_recordFunc
=
[
bEanbleHls
,
bEnableMp4
,
vhost
,
strApp
,
strId
](
bool
start
){
}
if
(
bEanbleHls
){
if
(
bEnableMp4
){
if
(
start
){
_mp4
.
reset
(
Recorder
::
createMP4Recorder
(
vhost
,
strApp
,
strId
));
Recorder
::
startRecord
(
Recorder
::
type_hls
,
vhost
,
strApp
,
strId
,
true
,
false
);
}
else
{
Recorder
::
stopRecord
(
Recorder
::
type_hls
,
vhost
,
strApp
,
strId
);
}
}
if
(
bEnableMp4
){
if
(
start
){
Recorder
::
startRecord
(
Recorder
::
type_mp4
,
vhost
,
strApp
,
strId
,
true
,
false
);
}
else
{
Recorder
::
stopRecord
(
Recorder
::
type_mp4
,
vhost
,
strApp
,
strId
);
}
}
};
_recordFunc
(
true
);
}
virtual
~
MultiMediaSourceMuxer
(){
if
(
_recordFunc
){
_recordFunc
(
false
);
}
}
}
}
virtual
~
MultiMediaSourceMuxer
(){}
/**
/**
* 重置音视频媒体
* 重置音视频媒体
...
@@ -68,12 +86,6 @@ public:
...
@@ -68,12 +86,6 @@ public:
if
(
_rtsp
){
if
(
_rtsp
){
_rtsp
->
resetTracks
();
_rtsp
->
resetTracks
();
}
}
if
(
_hls
){
_hls
->
resetTracks
();
}
if
(
_mp4
){
_mp4
->
resetTracks
();
}
}
}
/**
/**
...
@@ -115,12 +127,6 @@ protected:
...
@@ -115,12 +127,6 @@ protected:
if
(
_rtsp
){
if
(
_rtsp
){
_rtsp
->
addTrack
(
track
);
_rtsp
->
addTrack
(
track
);
}
}
if
(
_hls
){
_hls
->
addTrack
(
track
);
}
if
(
_mp4
){
_mp4
->
addTrack
(
track
);
}
}
}
/**
/**
...
@@ -134,12 +140,6 @@ protected:
...
@@ -134,12 +140,6 @@ protected:
if
(
_rtsp
)
{
if
(
_rtsp
)
{
_rtsp
->
inputFrame
(
frame
);
_rtsp
->
inputFrame
(
frame
);
}
}
if
(
_hls
){
_hls
->
inputFrame
(
frame
);
}
if
(
_mp4
){
_mp4
->
inputFrame
(
frame
);
}
}
}
/**
/**
...
@@ -158,8 +158,7 @@ protected:
...
@@ -158,8 +158,7 @@ protected:
private
:
private
:
RtmpMediaSourceMuxer
::
Ptr
_rtmp
;
RtmpMediaSourceMuxer
::
Ptr
_rtmp
;
RtspMediaSourceMuxer
::
Ptr
_rtsp
;
RtspMediaSourceMuxer
::
Ptr
_rtsp
;
MediaSinkInterface
::
Ptr
_hls
;
function
<
void
(
bool
)
>
_recordFunc
;
MediaSinkInterface
::
Ptr
_mp4
;
};
};
...
...
src/Common/config.cpp
查看文件 @
b3fcb4c0
...
@@ -55,6 +55,7 @@ bool loadIniConfig(const char *ini_path){
...
@@ -55,6 +55,7 @@ bool loadIniConfig(const char *ini_path){
////////////广播名称///////////
////////////广播名称///////////
namespace
Broadcast
{
namespace
Broadcast
{
const
string
kBroadcastMediaChanged
=
"kBroadcastMediaChanged"
;
const
string
kBroadcastMediaChanged
=
"kBroadcastMediaChanged"
;
const
string
kBroadcastMediaResetTracks
=
"kBroadcastMediaResetTracks"
;
const
string
kBroadcastRecordMP4
=
"kBroadcastRecordMP4"
;
const
string
kBroadcastRecordMP4
=
"kBroadcastRecordMP4"
;
const
string
kBroadcastHttpRequest
=
"kBroadcastHttpRequest"
;
const
string
kBroadcastHttpRequest
=
"kBroadcastHttpRequest"
;
const
string
kBroadcastHttpAccess
=
"kBroadcastHttpAccess"
;
const
string
kBroadcastHttpAccess
=
"kBroadcastHttpAccess"
;
...
...
src/Common/config.h
查看文件 @
b3fcb4c0
...
@@ -71,9 +71,13 @@ namespace Broadcast {
...
@@ -71,9 +71,13 @@ namespace Broadcast {
extern
const
string
kBroadcastMediaChanged
;
extern
const
string
kBroadcastMediaChanged
;
#define BroadcastMediaChangedArgs const bool &bRegist, const string &schema,const string &vhost,const string &app,const string &stream,MediaSource &sender
#define BroadcastMediaChangedArgs const bool &bRegist, const string &schema,const string &vhost,const string &app,const string &stream,MediaSource &sender
//MediaSource重置Track事件
extern
const
string
kBroadcastMediaResetTracks
;
#define BroadcastMediaResetTracksArgs const string &schema,const string &vhost,const string &app,const string &stream,MediaSource &sender
//录制mp4文件成功后广播
//录制mp4文件成功后广播
extern
const
string
kBroadcastRecordMP4
;
extern
const
string
kBroadcastRecordMP4
;
#define BroadcastRecordMP4Args const M
p
4Info &info
#define BroadcastRecordMP4Args const M
P
4Info &info
//收到http api请求广播
//收到http api请求广播
extern
const
string
kBroadcastHttpRequest
;
extern
const
string
kBroadcastHttpRequest
;
...
...
src/Record/MP4Recorder.cpp
查看文件 @
b3fcb4c0
...
@@ -107,7 +107,7 @@ void MP4Recorder::asyncClose() {
...
@@ -107,7 +107,7 @@ void MP4Recorder::asyncClose() {
auto
info
=
_info
;
auto
info
=
_info
;
WorkThreadPool
::
Instance
().
getExecutor
()
->
async
([
muxer
,
strFileTmp
,
strFile
,
info
]()
{
WorkThreadPool
::
Instance
().
getExecutor
()
->
async
([
muxer
,
strFileTmp
,
strFile
,
info
]()
{
//获取文件录制时间,放在关闭mp4之前是为了忽略关闭mp4执行时间
//获取文件录制时间,放在关闭mp4之前是为了忽略关闭mp4执行时间
const_cast
<
M
p
4Info
&>
(
info
).
ui64TimeLen
=
::
time
(
NULL
)
-
info
.
ui64StartedTime
;
const_cast
<
M
P
4Info
&>
(
info
).
ui64TimeLen
=
::
time
(
NULL
)
-
info
.
ui64StartedTime
;
//关闭mp4非常耗时,所以要放在后台线程执行
//关闭mp4非常耗时,所以要放在后台线程执行
const_cast
<
MP4MuxerFile
::
Ptr
&>
(
muxer
).
reset
();
const_cast
<
MP4MuxerFile
::
Ptr
&>
(
muxer
).
reset
();
//临时文件名改成正式文件名,防止mp4未完成时被访问
//临时文件名改成正式文件名,防止mp4未完成时被访问
...
@@ -115,7 +115,7 @@ void MP4Recorder::asyncClose() {
...
@@ -115,7 +115,7 @@ void MP4Recorder::asyncClose() {
//获取文件大小
//获取文件大小
struct
stat
fileData
;
struct
stat
fileData
;
stat
(
strFile
.
data
(),
&
fileData
);
stat
(
strFile
.
data
(),
&
fileData
);
const_cast
<
M
p
4Info
&>
(
info
).
ui64FileSize
=
fileData
.
st_size
;
const_cast
<
M
P
4Info
&>
(
info
).
ui64FileSize
=
fileData
.
st_size
;
/////record 业务逻辑//////
/////record 业务逻辑//////
NoticeCenter
::
Instance
().
emitEvent
(
Broadcast
::
kBroadcastRecordMP4
,
info
);
NoticeCenter
::
Instance
().
emitEvent
(
Broadcast
::
kBroadcastRecordMP4
,
info
);
});
});
...
...
src/Record/MP4Recorder.h
查看文件 @
b3fcb4c0
...
@@ -42,7 +42,7 @@ using namespace toolkit;
...
@@ -42,7 +42,7 @@ using namespace toolkit;
namespace
mediakit
{
namespace
mediakit
{
class
M
p
4Info
{
class
M
P
4Info
{
public
:
public
:
time_t
ui64StartedTime
;
//GMT标准时间,单位秒
time_t
ui64StartedTime
;
//GMT标准时间,单位秒
time_t
ui64TimeLen
;
//录像长度,单位秒
time_t
ui64TimeLen
;
//录像长度,单位秒
...
@@ -55,13 +55,15 @@ public:
...
@@ -55,13 +55,15 @@ public:
string
strStreamId
;
//流ID
string
strStreamId
;
//流ID
string
strVhost
;
//vhost
string
strVhost
;
//vhost
};
};
class
MP4Recorder
:
public
MediaSinkInterface
{
class
MP4Recorder
:
public
MediaSinkInterface
{
public
:
public
:
typedef
std
::
shared_ptr
<
MP4Recorder
>
Ptr
;
typedef
std
::
shared_ptr
<
MP4Recorder
>
Ptr
;
MP4Recorder
(
const
string
&
strPath
,
MP4Recorder
(
const
string
&
strPath
,
const
string
&
strVhost
,
const
string
&
strVhost
,
const
string
&
strApp
,
const
string
&
strApp
,
const
string
&
strStreamId
);
const
string
&
strStreamId
);
virtual
~
MP4Recorder
();
virtual
~
MP4Recorder
();
/**
/**
...
@@ -87,7 +89,7 @@ private:
...
@@ -87,7 +89,7 @@ private:
string
_strFile
;
string
_strFile
;
string
_strFileTmp
;
string
_strFileTmp
;
Ticker
_createFileTicker
;
Ticker
_createFileTicker
;
M
p
4Info
_info
;
M
P
4Info
_info
;
bool
_haveVideo
=
false
;
bool
_haveVideo
=
false
;
MP4MuxerFile
::
Ptr
_muxer
;
MP4MuxerFile
::
Ptr
_muxer
;
list
<
Track
::
Ptr
>
_tracks
;
list
<
Track
::
Ptr
>
_tracks
;
...
...
src/Record/Recorder.cpp
查看文件 @
b3fcb4c0
差异被折叠。
点击展开。
src/Record/Recorder.h
查看文件 @
b3fcb4c0
...
@@ -37,8 +37,25 @@ class MediaSinkInterface;
...
@@ -37,8 +37,25 @@ class MediaSinkInterface;
class
Recorder
{
class
Recorder
{
public
:
public
:
static
MediaSinkInterface
*
createHlsRecorder
(
const
string
&
strVhost
,
const
string
&
strApp
,
const
string
&
strId
);
typedef
enum
{
static
MediaSinkInterface
*
createMP4Recorder
(
const
string
&
strVhost
,
const
string
&
strApp
,
const
string
&
strId
);
// 未录制
status_not_record
=
0
,
// 等待MediaSource注册,注册成功后立即开始录制
status_wait_record
=
1
,
// MediaSource已注册,并且正在录制
status_recording
=
2
,
}
status
;
typedef
enum
{
// 录制hls
type_hls
=
0
,
// 录制MP4
type_mp4
=
1
}
type
;
static
status
getRecordStatus
(
type
type
,
const
string
&
vhost
,
const
string
&
app
,
const
string
&
stream_id
);
static
int
startRecord
(
type
type
,
const
string
&
vhost
,
const
string
&
app
,
const
string
&
stream_id
,
bool
waitForRecord
,
bool
continueRecord
);
static
void
stopRecord
(
type
type
,
const
string
&
vhost
,
const
string
&
app
,
const
string
&
stream_id
);
private
:
private
:
Recorder
()
=
delete
;
Recorder
()
=
delete
;
~
Recorder
()
=
delete
;
~
Recorder
()
=
delete
;
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论