mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2026-06-14 20:15:58 +08:00
AI automatically translates all comments in the code into English (#3917)
This commit is contained in:
@@ -94,7 +94,8 @@ void PlayerProxy::setTranslationInfo()
|
||||
|
||||
static int getMaxTrackSize(const std::string &url) {
|
||||
if (url.find(".m3u8") != std::string::npos || url.find(".ts") != std::string::npos) {
|
||||
// hls和ts协议才开放多track支持
|
||||
// hls和ts协议才开放多track支持 [AUTO-TRANSLATED:6c5f8f04]
|
||||
// Only hls and ts protocols support multiple tracks
|
||||
return 16;
|
||||
}
|
||||
return 2;
|
||||
@@ -116,11 +117,13 @@ void PlayerProxy::play(const string &strUrlTmp) {
|
||||
}
|
||||
|
||||
if (!err) {
|
||||
// 取消定时器,避免hls拉流索引文件因为网络波动失败重连成功后出现循环重试的情况
|
||||
// 取消定时器,避免hls拉流索引文件因为网络波动失败重连成功后出现循环重试的情况 [AUTO-TRANSLATED:91e5f0c8]
|
||||
// Cancel the timer to avoid the situation where the hls stream index file fails to reconnect due to network fluctuations and then retries in a loop after successful reconnection
|
||||
strongSelf->_timer.reset();
|
||||
strongSelf->_live_ticker.resetTime();
|
||||
strongSelf->_live_status = 0;
|
||||
// 播放成功
|
||||
// 播放成功 [AUTO-TRANSLATED:e43f9fb8]
|
||||
// Play successfully
|
||||
*piFailedCnt = 0; // 连续播放失败次数清0
|
||||
strongSelf->onPlaySuccess();
|
||||
strongSelf->setTranslationInfo();
|
||||
@@ -128,11 +131,13 @@ void PlayerProxy::play(const string &strUrlTmp) {
|
||||
|
||||
InfoL << "play " << strUrlTmp << " success";
|
||||
} else if (*piFailedCnt < strongSelf->_retry_count || strongSelf->_retry_count < 0) {
|
||||
// 播放失败,延时重试播放
|
||||
// 播放失败,延时重试播放 [AUTO-TRANSLATED:d7537c9c]
|
||||
// Play failed, retry playing with delay
|
||||
strongSelf->_on_disconnect();
|
||||
strongSelf->rePlay(strUrlTmp, (*piFailedCnt)++);
|
||||
} else {
|
||||
// 达到了最大重试次数,回调关闭
|
||||
// 达到了最大重试次数,回调关闭 [AUTO-TRANSLATED:610f31f3]
|
||||
// Reached the maximum number of retries, callback to close
|
||||
strongSelf->_on_close(err);
|
||||
}
|
||||
});
|
||||
@@ -142,7 +147,8 @@ void PlayerProxy::play(const string &strUrlTmp) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 注销直接拉流代理产生的流:#532
|
||||
// 注销直接拉流代理产生的流:#532 [AUTO-TRANSLATED:c6343a3b]
|
||||
// Unregister the stream generated by the direct stream proxy: #532
|
||||
strongSelf->setMediaSource(nullptr);
|
||||
|
||||
if (strongSelf->_muxer) {
|
||||
@@ -160,18 +166,21 @@ void PlayerProxy::play(const string &strUrlTmp) {
|
||||
}
|
||||
|
||||
if (*piFailedCnt == 0) {
|
||||
// 第一次重拉更新时长
|
||||
// 第一次重拉更新时长 [AUTO-TRANSLATED:3c414b08]
|
||||
// Update the duration for the first time
|
||||
strongSelf->_live_secs += strongSelf->_live_ticker.elapsedTime() / 1000;
|
||||
strongSelf->_live_ticker.resetTime();
|
||||
TraceL << " live secs " << strongSelf->_live_secs;
|
||||
}
|
||||
|
||||
// 播放异常中断,延时重试播放
|
||||
// 播放异常中断,延时重试播放 [AUTO-TRANSLATED:fee316b2]
|
||||
// Play interrupted abnormally, retry playing with delay
|
||||
if (*piFailedCnt < strongSelf->_retry_count || strongSelf->_retry_count < 0) {
|
||||
strongSelf->_repull_count++;
|
||||
strongSelf->rePlay(strUrlTmp, (*piFailedCnt)++);
|
||||
} else {
|
||||
// 达到了最大重试次数,回调关闭
|
||||
// 达到了最大重试次数,回调关闭 [AUTO-TRANSLATED:610f31f3]
|
||||
// Reached the maximum number of retries, callback to close
|
||||
strongSelf->_on_close(err);
|
||||
}
|
||||
});
|
||||
@@ -189,13 +198,15 @@ void PlayerProxy::play(const string &strUrlTmp) {
|
||||
void PlayerProxy::setDirectProxy() {
|
||||
MediaSource::Ptr mediaSource;
|
||||
if (dynamic_pointer_cast<RtspPlayer>(_delegate)) {
|
||||
// rtsp拉流
|
||||
// rtsp拉流 [AUTO-TRANSLATED:189cf691]
|
||||
// Rtsp stream
|
||||
GET_CONFIG(bool, directProxy, Rtsp::kDirectProxy);
|
||||
if (directProxy && _option.enable_rtsp) {
|
||||
mediaSource = std::make_shared<RtspMediaSource>(_tuple);
|
||||
}
|
||||
} else if (dynamic_pointer_cast<RtmpPlayer>(_delegate)) {
|
||||
// rtmp拉流
|
||||
// rtmp拉流 [AUTO-TRANSLATED:f70a142c]
|
||||
// Rtmp stream
|
||||
GET_CONFIG(bool, directProxy, Rtmp::kDirectProxy);
|
||||
if (directProxy && _option.enable_rtmp) {
|
||||
mediaSource = std::make_shared<RtmpMediaSource>(_tuple);
|
||||
@@ -208,7 +219,8 @@ void PlayerProxy::setDirectProxy() {
|
||||
|
||||
PlayerProxy::~PlayerProxy() {
|
||||
_timer.reset();
|
||||
// 避免析构时, 忘记回调api请求
|
||||
// 避免析构时, 忘记回调api请求 [AUTO-TRANSLATED:1ad9ad52]
|
||||
// Avoid forgetting to callback api request when destructing
|
||||
if (_on_play) {
|
||||
try {
|
||||
_on_play(SockException(Err_shutdown, "player proxy close"));
|
||||
@@ -225,7 +237,8 @@ void PlayerProxy::rePlay(const string &strUrl, int iFailedCnt) {
|
||||
_timer = std::make_shared<Timer>(
|
||||
iDelay / 1000.0f,
|
||||
[weakSelf, strUrl, iFailedCnt]() {
|
||||
// 播放失败次数越多,则延时越长
|
||||
// 播放失败次数越多,则延时越长 [AUTO-TRANSLATED:5af39264]
|
||||
// The more times the playback fails, the longer the delay
|
||||
auto strongPlayer = weakSelf.lock();
|
||||
if (!strongPlayer) {
|
||||
return false;
|
||||
@@ -239,7 +252,8 @@ void PlayerProxy::rePlay(const string &strUrl, int iFailedCnt) {
|
||||
}
|
||||
|
||||
bool PlayerProxy::close(MediaSource &sender) {
|
||||
// 通知其停止推流
|
||||
// 通知其停止推流 [AUTO-TRANSLATED:d69d10d8]
|
||||
// Notify it to stop pushing the stream
|
||||
weak_ptr<PlayerProxy> weakSelf = dynamic_pointer_cast<PlayerProxy>(shared_from_this());
|
||||
getPoller()->async_first([weakSelf]() {
|
||||
auto strongSelf = weakSelf.lock();
|
||||
@@ -286,7 +300,8 @@ TranslationInfo PlayerProxy::getTranslationInfo() {
|
||||
void PlayerProxy::onPlaySuccess() {
|
||||
GET_CONFIG(bool, reset_when_replay, General::kResetWhenRePlay);
|
||||
if (dynamic_pointer_cast<RtspMediaSource>(_media_src)) {
|
||||
// rtsp拉流代理
|
||||
// rtsp拉流代理 [AUTO-TRANSLATED:3935cf68]
|
||||
// Rtsp stream proxy
|
||||
if (reset_when_replay || !_muxer) {
|
||||
auto old = _option.enable_rtsp;
|
||||
_option.enable_rtsp = false;
|
||||
@@ -294,7 +309,8 @@ void PlayerProxy::onPlaySuccess() {
|
||||
_option.enable_rtsp = old;
|
||||
}
|
||||
} else if (dynamic_pointer_cast<RtmpMediaSource>(_media_src)) {
|
||||
// rtmp拉流代理
|
||||
// rtmp拉流代理 [AUTO-TRANSLATED:21173335]
|
||||
// Rtmp stream proxy
|
||||
if (reset_when_replay || !_muxer) {
|
||||
auto old = _option.enable_rtmp;
|
||||
_option.enable_rtmp = false;
|
||||
@@ -302,7 +318,8 @@ void PlayerProxy::onPlaySuccess() {
|
||||
_option.enable_rtmp = old;
|
||||
}
|
||||
} else {
|
||||
// 其他拉流代理
|
||||
// 其他拉流代理 [AUTO-TRANSLATED:e5f2e45d]
|
||||
// Other stream proxies
|
||||
if (reset_when_replay || !_muxer) {
|
||||
_muxer = std::make_shared<MultiMediaSourceMuxer>(_tuple, getDuration(), _option);
|
||||
}
|
||||
@@ -311,25 +328,31 @@ void PlayerProxy::onPlaySuccess() {
|
||||
|
||||
auto videoTrack = getTrack(TrackVideo, false);
|
||||
if (videoTrack) {
|
||||
// 添加视频
|
||||
// 添加视频 [AUTO-TRANSLATED:afc7e0f7]
|
||||
// Add video
|
||||
_muxer->addTrack(videoTrack);
|
||||
// 视频数据写入_mediaMuxer
|
||||
// 视频数据写入_mediaMuxer [AUTO-TRANSLATED:fc07e1c9]
|
||||
// Write video data to _mediaMuxer
|
||||
videoTrack->addDelegate(_muxer);
|
||||
}
|
||||
|
||||
auto audioTrack = getTrack(TrackAudio, false);
|
||||
if (audioTrack) {
|
||||
// 添加音频
|
||||
// 添加音频 [AUTO-TRANSLATED:e08e79ce]
|
||||
// Add audio
|
||||
_muxer->addTrack(audioTrack);
|
||||
// 音频数据写入_mediaMuxer
|
||||
// 音频数据写入_mediaMuxer [AUTO-TRANSLATED:69911524]
|
||||
// Write audio data to _mediaMuxer
|
||||
audioTrack->addDelegate(_muxer);
|
||||
}
|
||||
|
||||
// 添加完毕所有track,防止单track情况下最大等待3秒
|
||||
// 添加完毕所有track,防止单track情况下最大等待3秒 [AUTO-TRANSLATED:8908bc01]
|
||||
// After adding all tracks, prevent the maximum waiting time of 3 seconds in the case of a single track
|
||||
_muxer->addTrackCompleted();
|
||||
|
||||
if (_media_src) {
|
||||
// 让_muxer对象拦截一部分事件(比如说录像相关事件)
|
||||
// 让_muxer对象拦截一部分事件(比如说录像相关事件) [AUTO-TRANSLATED:7d27c400]
|
||||
// Let the _muxer object intercept some events (such as recording related events)
|
||||
_media_src->setListener(_muxer);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user