ZLMediaKit/tests/test_player.cpp

78 lines
1.9 KiB
C++
Raw Normal View History

2017-05-08 18:03:43 +08:00
#include <signal.h>
#include <unistd.h>
#include "Util/logger.h"
#include <iostream>
#include "Poller/EventPoller.h"
#include "Rtsp/UDPServer.h"
2017-08-03 13:55:46 +08:00
#include "Player/MediaPlayer.h"
2017-05-08 18:03:43 +08:00
#include "Util/onceToken.h"
#include "H264Decoder.h"
#include "YuvDisplayer.h"
#include "Network/sockutil.h"
using namespace std;
using namespace ZL::Screen;
using namespace ZL::Codec;
using namespace ZL::Util;
using namespace ZL::Thread;
using namespace ZL::Network;
using namespace ZL::Rtsp;
2017-08-03 13:55:46 +08:00
using namespace ZL::Player;
2017-05-08 18:03:43 +08:00
void programExit(int arg) {
EventPoller::Instance().shutdown();
}
int main(int argc, char *argv[]){
Logger::Instance().add(std::make_shared<ConsoleChannel>("stdout", LTrace));
//Logger::Instance().setWriter(std::make_shared<AsyncLogWriter>());
signal(SIGINT, programExit);
2017-08-03 13:55:46 +08:00
if(argc != 3){
FatalL << "\r\n测试方法:./test_player rtxp_url rtp_type\r\n"
<< "例如:./test_player rtsp://admin:123456@127.0.0.1/live/0 0\r\n"
2017-05-08 18:03:43 +08:00
<<endl;
Logger::Destory();
return 0;
}
MediaPlayer::Ptr player(new MediaPlayer());
player->setOnPlayResult([](const SockException &ex) {
InfoL << "OnPlayResult:" << ex.what();
});
player->setOnShutdown([](const SockException &ex) {
ErrorL << "OnShutdown:" << ex.what();
});
2017-08-03 13:55:46 +08:00
(*player)[RtspPlayer::kRtpType] = atoi(argv[2]);
player->play(argv[1]);
2017-05-08 18:03:43 +08:00
H264Decoder decoder;
YuvDisplayer displayer;
ThreadPool pool(1);
player->setOnVideoCB([&](const H264Frame &frame){
pool.async([&,frame]() {
AVFrame *pFrame = nullptr;
bool flag = decoder.inputVideo((unsigned char *)frame.data.data(), frame.data.size() ,frame.timeStamp, &pFrame);
if(flag) {
//DebugL << pFrame->pkt_pts;
displayer.displayYUV(pFrame);
}
});
});
EventPoller::Instance().runLoop();
static onceToken token(nullptr, []() {
UDPServer::Destory();
AsyncTaskThread::Destory();
EventPoller::Destory();
Logger::Destory();
});
return 0;
}