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
37658735
Commit
37658735
authored
Nov 17, 2022
by
cqm
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
处理转码和静音发生器冲突问题:
由于静音发生器产生的音频时间戳不连续,会导致转码出一大堆警告日志,并占用cpu 这变采用opus静音发生器来伪造rtc静音,而不是用转码:
parent
607d8ba0
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
30 行增加
和
16 行删除
+30
-16
src/Common/MultiMediaSourceMuxer.cpp
+29
-15
src/Common/MultiMediaSourceMuxer.h
+1
-1
没有找到文件。
src/Common/MultiMediaSourceMuxer.cpp
查看文件 @
37658735
...
...
@@ -139,10 +139,10 @@ MultiMediaSourceMuxer::MultiMediaSourceMuxer(const MediaTuple& tuple, float dur_
}
if
(
option
.
audio_transcode
)
{
#if defined(ENABLE_FFMPEG)
_audio_transcode
=
option
.
audio_transcode
;
InfoL
<<
"enable audio_transcode"
;
#else
InfoL
<<
"without ffmpeg disable audio_transcode"
;
_option
.
audio_transcode
=
false
;
#endif
}
...
...
@@ -410,7 +410,7 @@ bool MultiMediaSourceMuxer::onTrackReady(const Track::Ptr &track) {
auto
rtmp
=
_rtmp
;
auto
rtc
=
_rtc
;
#if defined(ENABLE_FFMPEG)
if
(
_audio_transcode
)
{
if
(
_
option
.
audio_transcode
)
{
if
(
track
->
getCodecId
()
==
CodecAAC
)
{
if
(
rtmp
)
{
rtmp
->
addTrack
(
track
);
...
...
@@ -418,24 +418,34 @@ bool MultiMediaSourceMuxer::onTrackReady(const Track::Ptr &track) {
}
_audio_dec
=
nullptr
;
_audio_enc
=
nullptr
;
_opus_mute_maker
=
nullptr
;
if
(
rtc
)
{
Track
::
Ptr
newTrack
(
new
OpusTrack
());
GET_CONFIG
(
int
,
bitrate
,
General
::
kOpusBitrate
);
newTrack
->
setBitRate
(
bitrate
);
rtc
->
addTrack
(
newTrack
);
rtc
=
nullptr
;
// aac to opus
_audio_dec
.
reset
(
new
FFmpegDecoder
(
track
));
_audio_enc
.
reset
(
new
FFmpegEncoder
(
newTrack
));
_audio_dec
->
setOnDecode
([
this
](
const
FFmpegFrame
::
Ptr
&
frame
)
{
_audio_enc
->
inputFrame
(
frame
,
false
);
});
_audio_enc
->
setOnEncode
([
this
](
const
Frame
::
Ptr
&
frame
)
{
// fill data to _rtc
if
(
_rtc
&&
_rtc
->
isEnabled
())
_rtc
->
inputFrame
(
frame
);
});
if
(
!
hasMuteAudio
())
{
// aac to opus
_audio_dec
.
reset
(
new
FFmpegDecoder
(
track
));
_audio_enc
.
reset
(
new
FFmpegEncoder
(
newTrack
));
_audio_dec
->
setOnDecode
([
this
](
const
FFmpegFrame
::
Ptr
&
frame
)
{
_audio_enc
->
inputFrame
(
frame
,
false
);
});
_audio_enc
->
setOnEncode
([
this
](
const
Frame
::
Ptr
&
frame
)
{
// fill data to _rtc
if
(
_rtc
&&
_rtc
->
isEnabled
())
_rtc
->
inputFrame
(
frame
);
});
}
else
{
_opus_mute_maker
=
std
::
make_shared
<
MuteAudioMaker
>
(
CodecOpus
);
_opus_mute_maker
->
addDelegate
([
this
](
const
Frame
::
Ptr
&
frame
)
{
if
(
_rtc
&&
_rtc
->
isEnabled
())
_rtc
->
inputFrame
(
frame
);
return
true
;
});
}
}
}
else
if
(
track
->
getTrackType
()
==
TrackAudio
)
{
...
...
@@ -445,6 +455,7 @@ bool MultiMediaSourceMuxer::onTrackReady(const Track::Ptr &track) {
}
_audio_dec
=
nullptr
;
_audio_enc
=
nullptr
;
_opus_mute_maker
=
nullptr
;
if
(
rtmp
)
{
Track
::
Ptr
newTrack
(
new
AACTrack
(
44100
,
std
::
dynamic_pointer_cast
<
AudioTrack
>
(
track
)
->
getAudioChannel
()));
GET_CONFIG
(
int
,
bitrate
,
General
::
kAacBitrate
);
...
...
@@ -571,6 +582,7 @@ void MultiMediaSourceMuxer::resetTracks() {
#if defined(ENABLE_FFMPEG)
_audio_dec
=
nullptr
;
_audio_dec
=
nullptr
;
_opus_mute_maker
=
nullptr
;
#endif
if
(
_fmp4
)
{
_fmp4
->
resetTracks
();
...
...
@@ -601,7 +613,7 @@ bool MultiMediaSourceMuxer::onTrackFrame(const Frame::Ptr &frame_in) {
if
(
_rtmp
&&
_rtmp
->
isEnabled
())
rtmp
=
_rtmp
;
#if defined(ENABLE_FFMPEG)
if
(
_audio_transcode
)
{
if
(
_
option
.
audio_transcode
)
{
if
(
frame
->
getCodecId
()
==
CodecAAC
)
{
if
(
rtc
)
{
if
(
_audio_dec
&&
rtc
->
readerCount
())
...
...
@@ -615,6 +627,8 @@ bool MultiMediaSourceMuxer::onTrackFrame(const Frame::Ptr &frame_in) {
_audio_dec
->
inputFrame
(
frame
,
true
,
false
,
false
);
rtmp
=
nullptr
;
}
}
else
if
(
_opus_mute_maker
&&
rtc
)
{
_opus_mute_maker
->
inputFrame
(
frame
);
}
}
#endif
...
...
src/Common/MultiMediaSourceMuxer.h
查看文件 @
37658735
...
...
@@ -179,7 +179,7 @@ private:
std
::
shared_ptr
<
TSMediaSourceMuxer
>
_ts
;
std
::
shared_ptr
<
RtspMediaSourceMuxer
>
_rtc
;
#if defined(ENABLE_FFMPEG)
bool
_audio_transcode
=
false
;
MuteAudioMaker
::
Ptr
_opus_mute_maker
;
std
::
shared_ptr
<
FFmpegDecoder
>
_audio_dec
;
std
::
shared_ptr
<
FFmpegEncoder
>
_audio_enc
;
#endif
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论