ZLMediaKit/src/Player/PlayerBase.cpp

109 lines
3.0 KiB
C++
Raw Normal View History

2017-10-09 22:11:01 +08:00
/*
2020-04-04 20:30:09 +08:00
* Copyright (c) 2016 The ZLMediaKit project authors. All Rights Reserved.
2017-09-27 16:20:30 +08:00
*
* This file is part of ZLMediaKit(https://github.com/xiongziliang/ZLMediaKit).
*
2020-04-04 20:30:09 +08:00
* Use of this source code is governed by MIT license that can be found in the
* LICENSE file in the root of the source tree. All contributing project authors
* may be found in the AUTHORS file in the root of the source tree.
2017-04-01 16:35:56 +08:00
*/
2017-04-25 11:35:41 +08:00
#include <algorithm>
2017-04-01 16:35:56 +08:00
#include "PlayerBase.h"
2017-04-25 11:35:41 +08:00
#include "Rtsp/RtspPlayerImp.h"
#include "Rtmp/RtmpPlayerImp.h"
2018-10-24 17:17:55 +08:00
using namespace toolkit;
2017-04-01 16:35:56 +08:00
2018-10-24 17:17:55 +08:00
namespace mediakit {
2017-04-01 16:35:56 +08:00
PlayerBase::Ptr PlayerBase::createPlayer(const EventPoller::Ptr &poller,const string &strUrl) {
2020-03-20 11:51:24 +08:00
static auto releasePlayer = [](PlayerBase *ptr){
onceToken token(nullptr,[&](){
delete ptr;
});
ptr->teardown();
};
string prefix = FindField(strUrl.data(), NULL, "://");
2019-07-20 20:53:50 +08:00
2020-03-20 11:51:24 +08:00
if (strcasecmp("rtsps",prefix.data()) == 0) {
return PlayerBase::Ptr(new TcpClientWithSSL<RtspPlayerImp>(poller),releasePlayer);
}
2019-07-20 20:53:50 +08:00
2020-03-20 11:51:24 +08:00
if (strcasecmp("rtsp",prefix.data()) == 0) {
return PlayerBase::Ptr(new RtspPlayerImp(poller),releasePlayer);
}
2019-07-20 20:53:50 +08:00
2020-03-20 11:51:24 +08:00
if (strcasecmp("rtmps",prefix.data()) == 0) {
return PlayerBase::Ptr(new TcpClientWithSSL<RtmpPlayerImp>(poller),releasePlayer);
}
2019-07-20 20:53:50 +08:00
2020-03-20 11:51:24 +08:00
if (strcasecmp("rtmp",prefix.data()) == 0) {
return PlayerBase::Ptr(new RtmpPlayerImp(poller),releasePlayer);
}
2019-07-20 20:53:50 +08:00
2020-03-20 11:51:24 +08:00
return PlayerBase::Ptr(new RtspPlayerImp(poller),releasePlayer);
2017-04-01 16:35:56 +08:00
}
PlayerBase::PlayerBase() {
2020-03-20 11:51:24 +08:00
this->mINI::operator[](kTimeoutMS) = 10000;
this->mINI::operator[](kMediaTimeoutMS) = 5000;
this->mINI::operator[](kBeatIntervalMS) = 5000;
this->mINI::operator[](kMaxAnalysisMS) = 5000;
}
///////////////////////////Demuxer//////////////////////////////
2018-11-16 18:46:05 +08:00
bool Demuxer::isInited(int analysisMs) {
2020-03-20 11:51:24 +08:00
if(analysisMs && _ticker.createdTime() > analysisMs){
//analysisMs毫秒后强制初始化完毕
return true;
}
if (_videoTrack && !_videoTrack->ready()) {
//视频未准备好
return false;
}
if (_audioTrack && !_audioTrack->ready()) {
//音频未准备好
return false;
}
return true;
}
2018-11-16 18:46:05 +08:00
vector<Track::Ptr> Demuxer::getTracks(bool trackReady) const {
2020-03-20 11:51:24 +08:00
vector<Track::Ptr> ret;
if(_videoTrack){
if(trackReady){
if(_videoTrack->ready()){
ret.emplace_back(_videoTrack);
}
}else{
ret.emplace_back(_videoTrack);
}
}
if(_audioTrack){
if(trackReady){
if(_audioTrack->ready()){
ret.emplace_back(_audioTrack);
}
}else{
ret.emplace_back(_audioTrack);
}
}
return std::move(ret);
}
float Demuxer::getDuration() const {
2020-03-20 11:51:24 +08:00
return _fDuration;
}
void Demuxer::onAddTrack(const Track::Ptr &track){
2020-03-20 11:51:24 +08:00
if(_listener){
_listener->onAddTrack(track);
}
}
void Demuxer::setTrackListener(Demuxer::Listener *listener) {
2020-03-20 11:51:24 +08:00
_listener = listener;
}
2018-10-24 17:17:55 +08:00
} /* namespace mediakit */