Files
ZLMediaKit/src/Common/Device.h

191 lines
6.3 KiB
C++
Raw Normal View History

2017-10-09 22:11:01 +08:00
/*
2023-12-09 16:23:51 +08:00
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
2017-09-27 16:20:30 +08:00
*
2023-12-09 16:23:51 +08:00
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
2017-09-27 16:20:30 +08:00
*
2023-12-09 16:23:51 +08:00
* Use of this source code is governed by MIT-like license that can be found in the
2020-04-04 20:30:09 +08:00
* 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
*/
#ifndef DEVICE_DEVICE_H_
#define DEVICE_DEVICE_H_
2017-04-25 11:35:41 +08:00
#include <memory>
2017-04-01 16:35:56 +08:00
#include <string>
#include <functional>
2018-03-02 15:00:04 +08:00
#include "Util/TimeTicker.h"
2018-10-26 16:09:48 +08:00
#include "Common/MultiMediaSourceMuxer.h"
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
class H264Encoder;
class AACEncoder;
2017-04-01 16:35:56 +08:00
class VideoInfo {
public:
2020-04-18 18:46:20 +08:00
CodecId codecId = CodecH264;
2020-03-20 11:51:24 +08:00
int iWidth;
int iHeight;
float iFrameRate;
2022-05-25 15:11:26 +08:00
int iBitRate = 2 * 1024 * 1024;
2017-04-01 16:35:56 +08:00
};
2020-04-18 23:56:27 +08:00
2017-04-01 16:35:56 +08:00
class AudioInfo {
public:
2020-04-18 18:46:20 +08:00
CodecId codecId = CodecAAC;
int iChannel;
int iSampleBit;
int iSampleRate;
2017-04-01 16:35:56 +08:00
};
2018-10-29 11:48:24 +08:00
/**
2020-04-18 23:56:27 +08:00
* MultiMediaSourceMuxer类的包装便使
* Wrapper class for MultiMediaSourceMuxer, making it easier for beginners to use.
* [AUTO-TRANSLATED:101887bd]
2018-10-29 11:48:24 +08:00
*/
class DevChannel : public MultiMediaSourceMuxer{
2017-04-01 16:35:56 +08:00
public:
using Ptr = std::shared_ptr<DevChannel>;
2018-10-29 11:48:24 +08:00
// fDuration<=0为直播否则为点播 [AUTO-TRANSLATED:e3b6029a]
// fDuration<=0 for live streaming, otherwise for on-demand
2023-05-25 16:23:24 +08:00
DevChannel(const MediaTuple& tuple, float duration = 0, const ProtocolOption &option = ProtocolOption())
: MultiMediaSourceMuxer(tuple, duration, option) {}
2017-04-01 16:35:56 +08:00
2020-03-20 11:51:24 +08:00
/**
2020-04-18 23:56:27 +08:00
* Track
* MultiMediaSourceMuxer::addTrack(VideoTrack::Ptr );
2020-04-18 18:46:20 +08:00
* @param info
* Initialize the video Track
* Equivalent to MultiMediaSourceMuxer::addTrack(VideoTrack::Ptr );
* @param info Video related information
* [AUTO-TRANSLATED:6845d52d]
2020-03-20 11:51:24 +08:00
*/
2021-09-27 14:34:26 +08:00
bool initVideo(const VideoInfo &info);
2018-10-29 11:48:24 +08:00
/**
2020-04-18 23:56:27 +08:00
* Track
* MultiMediaSourceMuxer::addTrack(AudioTrack::Ptr );
2020-04-18 18:46:20 +08:00
* @param info
* Initialize the audio Track
* Equivalent to MultiMediaSourceMuxer::addTrack(AudioTrack::Ptr );
* @param info Audio related information
* [AUTO-TRANSLATED:5be9d272]
2018-10-29 11:48:24 +08:00
*/
2021-09-27 14:34:26 +08:00
bool initAudio(const AudioInfo &info);
2020-03-20 11:51:24 +08:00
/**
* 264
2020-04-18 23:56:27 +08:00
* @param data 264
* @param len
2020-03-20 11:51:24 +08:00
* @param dts 0
* @param pts 0dts
* Input 264 frame
* @param data 264 single frame data pointer
* @param len Data pointer length
* @param dts Decode timestamp, in milliseconds; If it is 0, the timestamp will be generated automatically internally
* @param pts Play timestamp, in milliseconds; If it is 0, it will be assigned to dts internally
* [AUTO-TRANSLATED:bda112e9]
2020-03-20 11:51:24 +08:00
*/
2022-08-08 17:13:39 +08:00
bool inputH264(const char *data, int len, uint64_t dts, uint64_t pts = 0);
2020-03-20 11:51:24 +08:00
/**
* 265
2020-04-18 23:56:27 +08:00
* @param data 265
* @param len
2020-03-20 11:51:24 +08:00
* @param dts 0
* @param pts 0dts
* Input 265 frame
* @param data 265 single frame data pointer
* @param len Data pointer length
* @param dts Decode timestamp, in milliseconds; If it is 0, the timestamp will be generated automatically internally
* @param pts Play timestamp, in milliseconds; If it is 0, it will be assigned to dts internally
* [AUTO-TRANSLATED:1fc1c892]
2020-03-20 11:51:24 +08:00
*/
2022-08-08 17:13:39 +08:00
bool inputH265(const char *data, int len, uint64_t dts, uint64_t pts = 0);
2020-03-20 11:51:24 +08:00
/**
2020-04-18 23:56:27 +08:00
* aac帧
* @param data_without_adts adts头的aac帧
* @param len
* @param dts
* @param adts_header adts头
* Input aac frame
* @param data_without_adts aac frame without adts header
* @param len Frame data length
* @param dts Timestamp, in milliseconds
* @param adts_header adts header
* [AUTO-TRANSLATED:6eca0279]
2020-03-20 11:51:24 +08:00
*/
2022-08-08 17:13:39 +08:00
bool inputAAC(const char *data_without_adts, int len, uint64_t dts, const char *adts_header);
/**
2020-08-01 10:22:12 +08:00
* OPUS/G711音频帧
2020-04-18 23:56:27 +08:00
* @param data
* @param len
* @param dts
* Input OPUS/G711 audio frame
* @param data Audio frame
* @param len Frame data length
* @param dts Timestamp, in milliseconds
* [AUTO-TRANSLATED:5f13cdf6]
*/
2022-08-08 17:13:39 +08:00
bool inputAudio(const char *data, int len, uint64_t dts);
2020-04-18 23:56:27 +08:00
2020-03-20 11:51:24 +08:00
/**
* yuv420p视频帧inputH264方法
2022-05-25 15:11:26 +08:00
* @param yuv yuv420p数据指针
* @param linesize yuv420p数据linesize
* @param cts
* Input yuv420p video frame, encoding will be completed internally and inputH264 method will be called
* @param yuv yuv420p data pointer
* @param linesize yuv420p data linesize
* @param cts Capture timestamp, in milliseconds
* [AUTO-TRANSLATED:1b945575]
2020-03-20 11:51:24 +08:00
*/
2022-08-08 17:13:39 +08:00
bool inputYUV(char *yuv[3], int linesize[3], uint64_t cts);
2018-10-29 11:48:24 +08:00
/**
* pcm数据inputAAC方法
2022-05-25 15:11:26 +08:00
* @param data pcm数据指针int16整形
* @param len pcm数据长度
* @param cts
* Input pcm data, encoding will be completed internally and inputAAC method will be called
* @param data pcm data pointer, int16 integer
* @param len pcm data length
* @param cts Capture timestamp, in milliseconds
* [AUTO-TRANSLATED:b99a9e82]
2018-10-29 11:48:24 +08:00
*/
2022-08-08 17:13:39 +08:00
bool inputPCM(char *data, int len, uint64_t cts);
// // 重载基类方法,确保线程安全 //// [AUTO-TRANSLATED:86e2df12]
// // Override base class methods to ensure thread safety ////
2023-03-11 11:02:20 +08:00
bool inputFrame(const Frame::Ptr &frame) override;
bool addTrack(const Track::Ptr & track) override;
void addTrackCompleted() override;
2020-09-27 11:32:49 +08:00
private:
MediaOriginType getOriginType(MediaSource &sender) const override;
2017-04-01 16:35:56 +08:00
private:
2020-03-20 11:51:24 +08:00
std::shared_ptr<H264Encoder> _pH264Enc;
std::shared_ptr<AACEncoder> _pAacEnc;
2018-10-29 11:48:24 +08:00
std::shared_ptr<VideoInfo> _video;
std::shared_ptr<AudioInfo> _audio;
toolkit::SmoothTicker _aTicker[2];
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
#endif /* DEVICE_DEVICE_H_ */