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
6364b147
Commit
6364b147
authored
Oct 28, 2018
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MP4、hls适配新代码
parent
83a0ee85
隐藏空白字符变更
内嵌
并排
正在显示
11 个修改的文件
包含
201 行增加
和
106 行删除
+201
-106
src/Common/MediaSink.cpp
+10
-0
src/Common/MediaSink.h
+10
-2
src/MediaFile/HLSMaker.cpp
+26
-2
src/MediaFile/HLSMaker.h
+24
-12
src/MediaFile/MediaRecorder.cpp
+5
-6
src/MediaFile/MediaRecorder.h
+0
-1
src/MediaFile/Mp4Maker.cpp
+74
-54
src/MediaFile/Mp4Maker.h
+28
-15
src/Player/Track.h
+22
-12
src/Rtmp/RtmpToRtspMediaSource.h
+1
-1
src/Rtsp/RtspToRtmpMediaSource.h
+1
-1
没有找到文件。
src/Common/MediaSink.cpp
查看文件 @
6364b147
...
...
@@ -83,5 +83,15 @@ bool MediaSink::isAllTrackReady() const {
return
_allTrackReady
;
}
Track
::
Ptr
MediaSink
::
getTrack
(
TrackType
type
)
const
{
lock_guard
<
mutex
>
lck
(
_mtx
);
for
(
auto
&
pr
:
_track_map
){
if
(
pr
.
second
->
getTrackType
()
==
type
){
return
pr
.
second
;
}
}
return
nullptr
;
}
}
//namespace mediakit
src/Common/MediaSink.h
查看文件 @
6364b147
...
...
@@ -58,7 +58,7 @@ public:
* 只会克隆sps pps这些信息 ,而不会克隆Delegate相关关系
* @param track
*/
void
addTrack
(
const
Track
::
Ptr
&
track
);
v
irtual
v
oid
addTrack
(
const
Track
::
Ptr
&
track
);
/**
...
...
@@ -66,6 +66,14 @@ public:
* @return
*/
bool
isAllTrackReady
()
const
;
/**
* 获取特定类型的Track
* @param type
* @return
*/
Track
::
Ptr
getTrack
(
TrackType
type
)
const
;
protected
:
/**
* 某track已经准备好,其ready()状态返回true,
...
...
@@ -85,7 +93,7 @@ protected:
*/
virtual
void
onTrackFrame
(
const
Frame
::
Ptr
&
frame
)
{};
private
:
mutex
_mtx
;
mut
able
mut
ex
_mtx
;
map
<
int
,
Track
::
Ptr
>
_track_map
;
map
<
int
,
function
<
void
()
>
>
_trackReadyCallback
;
bool
_allTrackReady
=
false
;
...
...
src/MediaFile/HLSMaker.cpp
查看文件 @
6364b147
...
...
@@ -131,12 +131,12 @@ bool HLSMaker::write_index_file(int iFirstSegment, unsigned int uiLastSegment, i
return
true
;
}
void
HLSMaker
::
inputH264
(
void
*
data
,
uint32_t
length
,
uint32_t
timeStamp
,
int
type
)
{
void
HLSMaker
::
inputH264
(
void
*
data
,
uint32_t
length
,
uint32_t
timeStamp
)
{
if
(
_ui32LastStamp
==
0
){
_ui32LastStamp
=
timeStamp
;
}
int
stampInc
=
timeStamp
-
_ui32LastStamp
;
auto
type
=
((
uint8_t
*
)
data
)[
4
]
&
0x1F
;
switch
(
type
)
{
case
7
:
//SPS
if
(
stampInc
>=
_ui32SegmentDuration
*
1000
)
{
...
...
@@ -182,5 +182,29 @@ bool HLSMaker::removets() {
return
true
;
}
void
HLSMaker
::
onTrackFrame
(
const
Frame
::
Ptr
&
frame
)
{
switch
(
frame
->
getCodecId
()){
case
CodecH264
:{
if
(
frame
->
prefixSize
()
==
4
){
inputH264
(
frame
->
data
(),
frame
->
size
(),
frame
->
stamp
());
}
else
{
WarnL
<<
"h264必须要有头4个字节的前缀"
;
}
}
break
;
case
CodecAAC
:{
if
(
frame
->
prefixSize
()
==
7
)
{
inputAAC
(
frame
->
data
(),
frame
->
size
(),
frame
->
stamp
());
}
else
{
WarnL
<<
"adts必须要有头7个字节的adts头"
;
}
}
break
;
default
:
break
;
}
}
}
/* namespace mediakit */
src/MediaFile/HLSMaker.h
查看文件 @
6364b147
...
...
@@ -27,18 +27,19 @@
#ifndef HLSMAKER_H_
#define HLSMAKER_H_
#include <deque>
#include "TSMaker.h"
#include "Common/config.h"
#include "Util/TimeTicker.h"
#include "Util/File.h"
#include "Util/util.h"
#include "Util/logger.h"
#include <deque>
#include "Common/config.h"
#include "Common/MediaSink.h"
using
namespace
toolkit
;
namespace
mediakit
{
class
HLSMaker
{
class
HLSMaker
:
public
MediaSink
{
public
:
HLSMaker
(
const
string
&
strM3u8File
,
uint32_t
ui32BufSize
=
64
*
1024
,
...
...
@@ -47,16 +48,28 @@ public:
virtual
~
HLSMaker
();
protected
:
/**
* 某Track输出frame,在onAllTrackReady触发后才会调用此方法
* @param frame
*/
void
onTrackFrame
(
const
Frame
::
Ptr
&
frame
)
override
;
private
:
//时间戳:参考频率1000
void
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
,
int
iType
);
void
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
);
//时间戳:参考频率1000
void
inputAAC
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
);
void
inputAAC
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
);
bool
write_index_file
(
int
iFirstSegment
,
unsigned
int
uiLastSegment
,
int
iEnd
);
bool
removets
();
private
:
TSMaker
_ts
;
string
_strM3u8File
;
...
...
@@ -69,8 +82,7 @@ private:
uint32_t
_ui32LastStamp
;
std
::
deque
<
int
>
_iDurations
;
bool
write_index_file
(
int
iFirstSegment
,
unsigned
int
uiLastSegment
,
int
iEnd
);
bool
removets
();
};
}
/* namespace mediakit */
...
...
src/MediaFile/MediaRecorder.cpp
查看文件 @
6364b147
...
...
@@ -37,7 +37,6 @@ namespace mediakit {
MediaRecorder
::
MediaRecorder
(
const
string
&
strVhost_tmp
,
const
string
&
strApp
,
const
string
&
strId
,
const
std
::
shared_ptr
<
PlayerBase
>
&
pPlayer
,
bool
enableHls
,
bool
enableMp4
)
{
...
...
@@ -63,7 +62,7 @@ MediaRecorder::MediaRecorder(const string &strVhost_tmp,
if
(
enableMp4
){
auto
mp4FilePath
=
recordPath
+
"/"
+
strVhost
+
"/"
+
recordAppName
+
"/"
+
strApp
+
"/"
+
strId
+
"/"
;
_mp4Maker
.
reset
(
new
Mp4Maker
(
mp4FilePath
,
strVhost
,
strApp
,
strId
,
pPlayer
));
_mp4Maker
.
reset
(
new
Mp4Maker
(
mp4FilePath
,
strVhost
,
strApp
,
strId
));
}
#endif //ENABLE_MP4V2
}
...
...
@@ -73,22 +72,22 @@ MediaRecorder::~MediaRecorder() {
void
MediaRecorder
::
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
,
int
iType
)
{
if
(
_hlsMaker
){
_hlsMaker
->
inputH264
(
pData
,
ui32Length
,
ui32TimeStamp
,
iType
);
//
_hlsMaker->inputH264(pData, ui32Length, ui32TimeStamp, iType);
}
#ifdef ENABLE_MP4V2
if
(
_mp4Maker
){
_mp4Maker
->
inputH264
(
pData
,
ui32Length
,
ui32TimeStamp
,
iType
);
//
_mp4Maker->inputH264(pData, ui32Length, ui32TimeStamp, iType);
}
#endif //ENABLE_MP4V2
}
void
MediaRecorder
::
inputAAC
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
)
{
if
(
_hlsMaker
){
_hlsMaker
->
inputAAC
(
pData
,
ui32Length
,
ui32TimeStamp
);
//
_hlsMaker->inputAAC(pData, ui32Length, ui32TimeStamp);
}
#ifdef ENABLE_MP4V2
if
(
_mp4Maker
){
_mp4Maker
->
inputAAC
(
pData
,
ui32Length
,
ui32TimeStamp
);
//
_mp4Maker->inputAAC(pData, ui32Length, ui32TimeStamp);
}
#endif //ENABLE_MP4V2
}
...
...
src/MediaFile/MediaRecorder.h
查看文件 @
6364b147
...
...
@@ -45,7 +45,6 @@ public:
MediaRecorder
(
const
string
&
strVhost
,
const
string
&
strApp
,
const
string
&
strId
,
const
std
::
shared_ptr
<
PlayerBase
>
&
pPlayer
,
bool
enableHls
=
true
,
bool
enableMp4
=
false
);
virtual
~
MediaRecorder
();
...
...
src/MediaFile/Mp4Maker.cpp
查看文件 @
6364b147
...
...
@@ -57,10 +57,8 @@ string timeStr(const char *fmt) {
Mp4Maker
::
Mp4Maker
(
const
string
&
strPath
,
const
string
&
strVhost
,
const
string
&
strApp
,
const
string
&
strStreamId
,
const
PlayerBase
::
Ptr
&
pPlayer
)
{
const
string
&
strStreamId
)
{
DebugL
<<
strPath
;
_pPlayer
=
pPlayer
;
_strPath
=
strPath
;
/////record 业务逻辑//////
...
...
@@ -74,7 +72,8 @@ Mp4Maker::~Mp4Maker() {
closeFile
();
}
void
Mp4Maker
::
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
,
int
iType
){
void
Mp4Maker
::
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
){
auto
iType
=
((
uint8_t
*
)
pData
)[
0
]
&
0x1F
;
switch
(
iType
)
{
case
1
:
//P
case
5
:
{
//IDR
...
...
@@ -84,16 +83,14 @@ void Mp4Maker::inputH264(void *pData, uint32_t ui32Length, uint32_t ui32TimeStam
if
(
iTimeInc
==
0
||
iTimeInc
==
500
){
WarnL
<<
"abnormal time stamp increment:"
<<
ui32TimeStamp
<<
" "
<<
_ui32LastVideoTime
;
}
_inputH264
((
char
*
)
_strLastVideo
.
data
(),
_strLastVideo
.
size
(),
iTimeInc
,
_iLastVideoType
);
inputH264_l
((
char
*
)
_strLastVideo
.
data
(),
_strLastVideo
.
size
(),
iTimeInc
);
}
//_strLastVideo.assign(("\x0\x0\x0\x2\x9\xf0"), 6);
uint32_t
*
p
=
(
uint32_t
*
)
pData
;
*
p
=
htonl
(
ui32Length
-
4
);
_strLastVideo
.
assign
((
char
*
)
pData
,
ui32Length
);
memcpy
(
pData
,
"
\x00\x00\x00\x01
"
,
4
);
uint32_t
prefixe
=
htonl
(
ui32Length
);
_strLastVideo
.
assign
((
char
*
)
&
prefixe
,
4
);
_strLastVideo
.
append
((
char
*
)
pData
,
ui32Length
);
_ui32LastVideoTime
=
ui32TimeStamp
;
_iLastVideoType
=
iType
;
}
break
;
default
:
...
...
@@ -107,16 +104,17 @@ void Mp4Maker::inputAAC(void *pData, uint32_t ui32Length, uint32_t ui32TimeStamp
if
(
iTimeInc
==
0
||
iTimeInc
==
500
){
WarnL
<<
"abnormal time stamp increment:"
<<
ui32TimeStamp
<<
" "
<<
_ui32LastAudioTime
;
}
_inputAAC
((
char
*
)
_strLastAudio
.
data
(),
_strLastAudio
.
size
(),
iTimeInc
);
inputAAC_l
((
char
*
)
_strLastAudio
.
data
(),
_strLastAudio
.
size
(),
iTimeInc
);
}
_strLastAudio
.
assign
((
char
*
)
pData
,
ui32Length
);
_ui32LastAudioTime
=
ui32TimeStamp
;
}
void
Mp4Maker
::
_inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32Duration
,
int
iType
)
{
void
Mp4Maker
::
inputH264_l
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32Duration
)
{
GET_CONFIG_AND_REGISTER
(
uint32_t
,
recordSec
,
Record
::
kFileSecond
);
if
(
iType
==
5
&&
(
_hMp4
==
MP4_INVALID_FILE_HANDLE
||
_ticker
.
elapsedTime
()
>
recordSec
*
1000
)){
auto
iType
=
((
uint8_t
*
)
pData
)[
0
]
&
0x1F
;
if
(
iType
==
5
&&
(
_hMp4
==
MP4_INVALID_FILE_HANDLE
||
_ticker
.
elapsedTime
()
>
recordSec
*
1000
)){
//在I帧率处新建MP4文件
//如果文件未创建或者文件超过10分钟则创建新文件
createFile
();
...
...
@@ -126,27 +124,21 @@ void Mp4Maker::_inputH264(void* pData, uint32_t ui32Length, uint32_t ui32Duratio
}
}
void
Mp4Maker
::
_inputAAC
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32Duration
)
{
void
Mp4Maker
::
inputAAC_l
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32Duration
)
{
GET_CONFIG_AND_REGISTER
(
uint32_t
,
recordSec
,
Record
::
kFileSecond
);
//todo(xzl) 修复此处
//
// if (!_pPlayer->containVideo() && (_hMp4 == MP4_INVALID_FILE_HANDLE || _ticker.elapsedTime() > recordSec * 1000)) {
// //在I帧率处新建MP4文件
// //如果文件未创建或者文件超过10分钟则创建新文件
// createFile();
// }
// if (_hAudio != MP4_INVALID_TRACK_ID) {
// auto duration = ui32Duration * _pPlayer->getAudioSampleRate() /1000.0;
// MP4WriteSample(_hMp4, _hAudio, (uint8_t*)pData + 7, ui32Length - 7,duration,0,false);
// }
if
(
!
_haveVideo
&&
(
_hMp4
==
MP4_INVALID_FILE_HANDLE
||
_ticker
.
elapsedTime
()
>
recordSec
*
1000
))
{
//在I帧率处新建MP4文件
//如果文件未创建或者文件超过10分钟则创建新文件
createFile
();
}
if
(
_hAudio
!=
MP4_INVALID_TRACK_ID
)
{
auto
duration
=
ui32Duration
*
_audioSampleRate
/
1000.0
;
MP4WriteSample
(
_hMp4
,
_hAudio
,
(
uint8_t
*
)
pData
,
ui32Length
,
duration
,
0
,
false
);
}
}
void
Mp4Maker
::
createFile
()
{
if
(
!
_pPlayer
->
isInited
()){
return
;
}
closeFile
();
auto
strDate
=
timeStr
(
"%Y-%m-%d"
);
...
...
@@ -184,30 +176,38 @@ void Mp4Maker::createFile() {
_strFile
=
strFile
;
_ticker
.
resetTime
();
//todo(xzl) 修复此处
// if(_pPlayer->containVideo()){
// auto &sps = _pPlayer->getSps();
// auto &pps = _pPlayer->getPps();
// _hVideo = MP4AddH264VideoTrack(_hMp4, 90000, MP4_INVALID_DURATION,
// _pPlayer->getVideoWidth(), _pPlayer->getVideoHeight(),
// sps[5], sps[6], sps[7], 3);
// if(_hVideo !=MP4_INVALID_TRACK_ID){
// MP4AddH264SequenceParameterSet(_hMp4, _hVideo, (uint8_t *)sps.data() + 4, sps.size() - 4);
// MP4AddH264PictureParameterSet(_hMp4, _hVideo, (uint8_t *)pps.data() + 4, pps.size() - 4);
// }else{
// WarnL << "添加视频通道失败:" << strFileTmp;
// }
// }
// if(_pPlayer->containAudio()){
// _hAudio = MP4AddAudioTrack(_hMp4, _pPlayer->getAudioSampleRate(), MP4_INVALID_DURATION, MP4_MPEG4_AUDIO_TYPE);
// if (_hAudio != MP4_INVALID_TRACK_ID) {
// auto &cfg = _pPlayer->getAudioCfg();
// MP4SetTrackESConfiguration(_hMp4, _hAudio,(uint8_t *)cfg.data(), cfg.size());
// }else{
// WarnL << "添加音频通道失败:" << strFileTmp;
// }
// }
auto
videoTrack
=
dynamic_pointer_cast
<
H264Track
>
(
getTrack
(
TrackVideo
));
if
(
videoTrack
){
auto
&
sps
=
videoTrack
->
getSps
();
auto
&
pps
=
videoTrack
->
getPps
();
_hVideo
=
MP4AddH264VideoTrack
(
_hMp4
,
90000
,
MP4_INVALID_DURATION
,
videoTrack
->
getVideoWidth
(),
videoTrack
->
getVideoHeight
(),
sps
[
1
],
sps
[
2
],
sps
[
3
],
3
);
if
(
_hVideo
!=
MP4_INVALID_TRACK_ID
){
MP4AddH264SequenceParameterSet
(
_hMp4
,
_hVideo
,
(
uint8_t
*
)
sps
.
data
(),
sps
.
size
());
MP4AddH264PictureParameterSet
(
_hMp4
,
_hVideo
,
(
uint8_t
*
)
pps
.
data
(),
pps
.
size
());
}
else
{
WarnL
<<
"添加视频通道失败:"
<<
strFileTmp
;
}
}
auto
audioTrack
=
dynamic_pointer_cast
<
AACTrack
>
(
getTrack
(
TrackAudio
));
if
(
audioTrack
){
_audioSampleRate
=
audioTrack
->
getAudioSampleRate
();
_hAudio
=
MP4AddAudioTrack
(
_hMp4
,
_audioSampleRate
,
MP4_INVALID_DURATION
,
MP4_MPEG4_AUDIO_TYPE
);
if
(
_hAudio
!=
MP4_INVALID_TRACK_ID
)
{
auto
&
cfg
=
audioTrack
->
getAacCfg
();
MP4SetTrackESConfiguration
(
_hMp4
,
_hAudio
,(
uint8_t
*
)
cfg
.
data
(),
cfg
.
size
());
}
else
{
WarnL
<<
"添加音频通道失败:"
<<
strFileTmp
;
}
}
}
void
Mp4Maker
::
closeFile
()
{
...
...
@@ -232,6 +232,26 @@ void Mp4Maker::closeFile() {
}
}
void
Mp4Maker
::
onTrackFrame
(
const
Frame
::
Ptr
&
frame
)
{
switch
(
frame
->
getCodecId
()){
case
CodecH264
:{
inputH264
(
frame
->
data
()
+
frame
->
prefixSize
(),
frame
->
size
()
-
frame
->
prefixSize
(),
frame
->
stamp
());
}
break
;
case
CodecAAC
:{
inputAAC
(
frame
->
data
()
+
frame
->
prefixSize
(),
frame
->
size
()
-
frame
->
prefixSize
(),
frame
->
stamp
());
}
break
;
default
:
break
;
}
}
void
Mp4Maker
::
onAllTrackReady
()
{
_haveVideo
=
getTrack
(
TrackVideo
).
operator
bool
();
}
}
/* namespace mediakit */
...
...
src/MediaFile/Mp4Maker.h
查看文件 @
6364b147
...
...
@@ -37,12 +37,14 @@
#include "Util/logger.h"
#include "Util/TimeTicker.h"
#include "Util/TimeTicker.h"
#include "Common/MediaSink.h"
#include "Player/Track.h"
using
namespace
toolkit
;
namespace
mediakit
{
class
Mp4Info
{
class
Mp4Info
{
public
:
time_t
ui64StartedTime
;
//GMT标准时间,单位秒
time_t
ui64TimeLen
;
//录像长度,单位秒
...
...
@@ -55,43 +57,54 @@ public:
string
strStreamId
;
//流ID
string
strVhost
;
//vhost
};
class
Mp4Maker
{
class
Mp4Maker
:
public
MediaSink
{
public
:
typedef
std
::
shared_ptr
<
Mp4Maker
>
Ptr
;
Mp4Maker
(
const
string
&
strPath
,
const
string
&
strVhost
,
const
string
&
strApp
,
const
string
&
strStreamId
,
const
PlayerBase
::
Ptr
&
pPlayer
);
const
string
&
strStreamId
);
virtual
~
Mp4Maker
();
private
:
/**
* 某Track输出frame,在onAllTrackReady触发后才会调用此方法
* @param frame
*/
void
onTrackFrame
(
const
Frame
::
Ptr
&
frame
)
override
;
/**
* 所有Track准备好了
*/
void
onAllTrackReady
()
override
;
private
:
void
createFile
();
void
closeFile
();
//时间戳:参考频率1000
void
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
,
int
iType
);
void
inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
);
//时间戳:参考频率1000
void
inputAAC
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui32TimeStamp
);
void
inputH264_l
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui64Duration
);
void
inputAAC_l
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui64Duration
);
private
:
MP4FileHandle
_hMp4
=
MP4_INVALID_FILE_HANDLE
;
MP4TrackId
_hVideo
=
MP4_INVALID_TRACK_ID
;
MP4TrackId
_hAudio
=
MP4_INVALID_TRACK_ID
;
PlayerBase
::
Ptr
_pPlayer
;
string
_strPath
;
string
_strFile
;
string
_strFileTmp
;
Ticker
_ticker
;
SmoothTicker
_mediaTicker
[
2
];
void
createFile
();
void
closeFile
();
void
_inputH264
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui64Duration
,
int
iType
);
void
_inputAAC
(
void
*
pData
,
uint32_t
ui32Length
,
uint32_t
ui64Duration
);
string
_strLastVideo
;
string
_strLastAudio
;
uint32_t
_ui32LastVideoTime
=
0
;
uint32_t
_ui32LastAudioTime
=
0
;
int
_iLastVideoType
=
0
;
Mp4Info
_info
;
bool
_haveVideo
=
false
;
int
_audioSampleRate
;
};
}
/* namespace mediakit */
...
...
src/Player/Track.h
查看文件 @
6364b147
...
...
@@ -238,21 +238,29 @@ public:
case
5
:{
//I
if
(
!
_sps
.
empty
()){
H264Frame
::
Ptr
insertFrame
=
std
::
make_shared
<
H264Frame
>
();
insertFrame
->
timeStamp
=
frame
->
stamp
();
insertFrame
->
type
=
7
;
insertFrame
->
buffer
=
_sps
;
insertFrame
->
iPrefixSize
=
0
;
VideoTrack
::
inputFrame
(
insertFrame
);
if
(
!
_spsFrame
){
H264Frame
::
Ptr
insertFrame
=
std
::
make_shared
<
H264Frame
>
();
insertFrame
->
timeStamp
=
frame
->
stamp
();
insertFrame
->
type
=
7
;
insertFrame
->
buffer
.
assign
(
"\x0\x0\x0\x1"
);
insertFrame
->
buffer
.
append
(
_sps
);
insertFrame
->
iPrefixSize
=
4
;
_spsFrame
=
insertFrame
;
}
VideoTrack
::
inputFrame
(
_spsFrame
);
}
if
(
!
_pps
.
empty
()){
H264Frame
::
Ptr
insertFrame
=
std
::
make_shared
<
H264Frame
>
();
insertFrame
->
timeStamp
=
frame
->
stamp
();
insertFrame
->
type
=
8
;
insertFrame
->
buffer
=
_pps
;
insertFrame
->
iPrefixSize
=
0
;
VideoTrack
::
inputFrame
(
insertFrame
);
if
(
!
_ppsFrame
){
H264Frame
::
Ptr
insertFrame
=
std
::
make_shared
<
H264Frame
>
();
insertFrame
->
timeStamp
=
frame
->
stamp
();
insertFrame
->
type
=
8
;
insertFrame
->
buffer
.
assign
(
"\x0\x0\x0\x1"
);
insertFrame
->
buffer
.
append
(
_pps
);
insertFrame
->
iPrefixSize
=
4
;
_ppsFrame
=
insertFrame
;
}
VideoTrack
::
inputFrame
(
_ppsFrame
);
}
VideoTrack
::
inputFrame
(
frame
);
}
...
...
@@ -282,6 +290,8 @@ private:
int
_width
=
0
;
int
_height
=
0
;
float
_fps
=
0
;
H264Frame
::
Ptr
_spsFrame
;
H264Frame
::
Ptr
_ppsFrame
;
};
/**
...
...
src/Rtmp/RtmpToRtspMediaSource.h
查看文件 @
6364b147
...
...
@@ -61,7 +61,7 @@ public:
void
onGetMetaData
(
const
AMFValue
&
_metadata
)
override
{
try
{
_pParser
.
reset
(
new
RtmpDemuxer
(
_metadata
));
_pRecorder
.
reset
(
new
MediaRecorder
(
getVhost
(),
getApp
(),
getId
(),
_
pParser
,
_
bEnableHls
,
_bEnableMp4
));
_pRecorder
.
reset
(
new
MediaRecorder
(
getVhost
(),
getApp
(),
getId
(),
_bEnableHls
,
_bEnableMp4
));
//todo(xzl) 修复此处
// _pParser->setOnAudioCB(std::bind(&RtmpToRtspMediaSource::onGetAAC, this, placeholders::_1));
...
...
src/Rtsp/RtspToRtmpMediaSource.h
查看文件 @
6364b147
...
...
@@ -52,7 +52,7 @@ public:
RtspMediaSource
::
onGetSDP
(
strSdp
);
try
{
_pParser
.
reset
(
new
RtspDemuxer
(
_sdpAttr
));
_pRecorder
.
reset
(
new
MediaRecorder
(
getVhost
(),
getApp
(),
getId
(),
_
pParser
,
_
bEnableHls
,
_bEnableMp4
));
_pRecorder
.
reset
(
new
MediaRecorder
(
getVhost
(),
getApp
(),
getId
(),
_bEnableHls
,
_bEnableMp4
));
//todo(xzl) 修复此处
// _pParser->setOnAudioCB( std::bind(&RtspToRtmpMediaSource::onGetAAC, this, placeholders::_1));
// _pParser->setOnVideoCB( std::bind(&RtspToRtmpMediaSource::onGetH264, this, placeholders::_1));
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论