2019-08-08 19:01:45 +08:00
|
|
|
|
/*
|
2023-12-09 16:23:51 +08:00
|
|
|
|
* Copyright (c) 2016-present The ZLMediaKit project authors. All Rights Reserved.
|
2019-06-11 09:25:54 +08:00
|
|
|
|
*
|
2023-12-09 16:23:51 +08:00
|
|
|
|
* This file is part of ZLMediaKit(https://github.com/ZLMediaKit/ZLMediaKit).
|
2019-06-11 09:25:54 +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.
|
2019-06-11 09:25:54 +08:00
|
|
|
|
*/
|
2019-06-06 18:28:33 +08:00
|
|
|
|
|
|
|
|
|
#ifndef FFMPEG_SOURCE_H
|
|
|
|
|
#define FFMPEG_SOURCE_H
|
|
|
|
|
|
|
|
|
|
#include <mutex>
|
|
|
|
|
#include <memory>
|
|
|
|
|
#include <functional>
|
|
|
|
|
#include "Process.h"
|
|
|
|
|
#include "Util/TimeTicker.h"
|
|
|
|
|
#include "Common/MediaSource.h"
|
|
|
|
|
|
2020-05-09 00:06:36 +08:00
|
|
|
|
namespace FFmpeg {
|
2022-02-02 20:34:50 +08:00
|
|
|
|
extern const std::string kSnap;
|
2023-07-26 16:40:10 +08:00
|
|
|
|
extern const std::string kBin;
|
2020-05-09 00:06:36 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class FFmpegSnap {
|
|
|
|
|
public:
|
2022-02-24 11:28:48 +08:00
|
|
|
|
using onSnap = std::function<void(bool success, const std::string &err_msg)>;
|
2024-09-19 14:53:50 +08:00
|
|
|
|
// / 创建截图 [AUTO-TRANSLATED:6d334c49]
|
|
|
|
|
// / Create a screenshot
|
|
|
|
|
// / \param play_url 播放url地址,只要FFmpeg支持即可 [AUTO-TRANSLATED:609d4de4]
|
|
|
|
|
// / \param play_url The playback URL address, as long as FFmpeg supports it
|
|
|
|
|
// / \param save_path 截图jpeg文件保存路径 [AUTO-TRANSLATED:0fc0ac0d]
|
|
|
|
|
// / \param save_path The path to save the screenshot JPEG file
|
|
|
|
|
// / \param timeout_sec 生成截图超时时间(防止阻塞太久) [AUTO-TRANSLATED:0dcc0095]
|
|
|
|
|
// / \param timeout_sec Timeout for generating the screenshot (to prevent blocking for too long)
|
|
|
|
|
// / \param cb 生成截图成功与否回调 [AUTO-TRANSLATED:5b4b93c9]
|
|
|
|
|
// / \param cb Callback for whether the screenshot was generated successfully
|
2022-02-24 11:28:48 +08:00
|
|
|
|
static void makeSnap(const std::string &play_url, const std::string &save_path, float timeout_sec, const onSnap &cb);
|
|
|
|
|
|
2020-05-09 00:06:36 +08:00
|
|
|
|
private:
|
|
|
|
|
FFmpegSnap() = delete;
|
|
|
|
|
~FFmpegSnap() = delete;
|
|
|
|
|
};
|
|
|
|
|
|
2022-02-02 20:34:50 +08:00
|
|
|
|
class FFmpegSource : public std::enable_shared_from_this<FFmpegSource> , public mediakit::MediaSourceEventInterceptor{
|
2019-06-06 18:28:33 +08:00
|
|
|
|
public:
|
2022-02-02 20:34:50 +08:00
|
|
|
|
using Ptr = std::shared_ptr<FFmpegSource>;
|
|
|
|
|
using onPlay = std::function<void(const toolkit::SockException &ex)>;
|
2019-06-06 18:28:33 +08:00
|
|
|
|
|
|
|
|
|
FFmpegSource();
|
2020-12-20 20:25:44 +08:00
|
|
|
|
~FFmpegSource();
|
|
|
|
|
|
2019-06-06 18:28:33 +08:00
|
|
|
|
/**
|
|
|
|
|
* 设置主动关闭回调
|
2024-09-19 14:53:50 +08:00
|
|
|
|
* Set the active close callback
|
|
|
|
|
|
|
|
|
|
* [AUTO-TRANSLATED:2134a5b3]
|
2019-06-06 18:28:33 +08:00
|
|
|
|
*/
|
2022-02-02 20:34:50 +08:00
|
|
|
|
void setOnClose(const std::function<void()> &cb);
|
2020-12-20 20:25:44 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 开始播放url
|
2021-01-23 09:42:15 +08:00
|
|
|
|
* @param ffmpeg_cmd_key FFmpeg拉流命令配置项key,用户可以在配置文件中同时设置多个命令参数模板
|
2020-12-20 20:25:44 +08:00
|
|
|
|
* @param src_url FFmpeg拉流地址
|
|
|
|
|
* @param dst_url FFmpeg推流地址
|
|
|
|
|
* @param timeout_ms 等待结果超时时间,单位毫秒
|
|
|
|
|
* @param cb 成功与否回调
|
2024-09-19 14:53:50 +08:00
|
|
|
|
* Start playing the URL
|
|
|
|
|
* @param ffmpeg_cmd_key FFmpeg stream command configuration item key, users can set multiple command parameter templates in the configuration file at the same time
|
|
|
|
|
* @param src_url FFmpeg stream address
|
|
|
|
|
* @param dst_url FFmpeg push stream address
|
|
|
|
|
* @param timeout_ms Timeout for waiting for the result, in milliseconds
|
|
|
|
|
* @param cb Success or failure callback
|
|
|
|
|
|
|
|
|
|
* [AUTO-TRANSLATED:2c35789e]
|
2020-12-20 20:25:44 +08:00
|
|
|
|
*/
|
2022-02-02 20:34:50 +08:00
|
|
|
|
void play(const std::string &ffmpeg_cmd_key, const std::string &src_url, const std::string &dst_url, int timeout_ms, const onPlay &cb);
|
2020-12-20 20:25:44 +08:00
|
|
|
|
|
2024-11-01 10:47:18 +08:00
|
|
|
|
const std::string& getSrcUrl() const { return _src_url; }
|
|
|
|
|
const std::string& getDstUrl() const { return _dst_url; }
|
|
|
|
|
const std::string& getCmd() const { return _cmd; }
|
|
|
|
|
const std::string& getCmdKey() const { return _ffmpeg_cmd_key; }
|
|
|
|
|
const mediakit::MediaInfo& getMediaInfo() const { return _media_info; }
|
|
|
|
|
|
2020-12-20 20:25:44 +08:00
|
|
|
|
/**
|
|
|
|
|
* 设置录制
|
|
|
|
|
* @param enable_hls 是否开启hls直播或录制
|
|
|
|
|
* @param enable_mp4 是否录制mp4
|
2024-09-19 14:53:50 +08:00
|
|
|
|
* Set recording
|
|
|
|
|
* @param enable_hls Whether to enable HLS live streaming or recording
|
|
|
|
|
* @param enable_mp4 Whether to record MP4
|
|
|
|
|
|
|
|
|
|
* [AUTO-TRANSLATED:9f28d5c2]
|
2020-12-20 20:25:44 +08:00
|
|
|
|
*/
|
2021-01-17 20:15:08 +08:00
|
|
|
|
void setupRecordFlag(bool enable_hls, bool enable_mp4);
|
2020-12-20 20:25:44 +08:00
|
|
|
|
|
2019-06-06 18:28:33 +08:00
|
|
|
|
private:
|
2022-02-02 20:34:50 +08:00
|
|
|
|
void findAsync(int maxWaitMS ,const std::function<void(const mediakit::MediaSource::Ptr &src)> &cb);
|
2019-06-06 18:28:33 +08:00
|
|
|
|
void startTimer(int timeout_ms);
|
2022-02-02 20:34:50 +08:00
|
|
|
|
void onGetMediaSource(const mediakit::MediaSource::Ptr &src);
|
2019-11-18 12:07:11 +08:00
|
|
|
|
|
2020-09-27 11:32:49 +08:00
|
|
|
|
///////MediaSourceEvent override///////
|
2024-09-19 14:53:50 +08:00
|
|
|
|
// 关闭 [AUTO-TRANSLATED:92392f02]
|
|
|
|
|
// Close
|
2022-09-18 20:36:47 +08:00
|
|
|
|
bool close(mediakit::MediaSource &sender) override;
|
2024-09-19 14:53:50 +08:00
|
|
|
|
// 获取媒体源类型 [AUTO-TRANSLATED:34290a69]
|
|
|
|
|
// Get the media source type
|
2022-02-02 20:34:50 +08:00
|
|
|
|
mediakit::MediaOriginType getOriginType(mediakit::MediaSource &sender) const override;
|
2024-09-19 14:53:50 +08:00
|
|
|
|
// 获取媒体源url或者文件路径 [AUTO-TRANSLATED:d6d885b8]
|
|
|
|
|
// Get the media source URL or file path
|
2022-02-02 20:34:50 +08:00
|
|
|
|
std::string getOriginUrl(mediakit::MediaSource &sender) const override;
|
2020-06-19 10:19:42 +08:00
|
|
|
|
|
2019-06-06 18:28:33 +08:00
|
|
|
|
private:
|
2020-12-20 20:25:44 +08:00
|
|
|
|
bool _enable_hls = false;
|
|
|
|
|
bool _enable_mp4 = false;
|
2019-06-06 18:28:33 +08:00
|
|
|
|
Process _process;
|
2022-02-02 20:34:50 +08:00
|
|
|
|
toolkit::Timer::Ptr _timer;
|
|
|
|
|
toolkit::EventPoller::Ptr _poller;
|
|
|
|
|
mediakit::MediaInfo _media_info;
|
|
|
|
|
std::string _src_url;
|
|
|
|
|
std::string _dst_url;
|
|
|
|
|
std::string _ffmpeg_cmd_key;
|
2024-11-01 10:47:18 +08:00
|
|
|
|
std::string _cmd;
|
2022-02-02 20:34:50 +08:00
|
|
|
|
std::function<void()> _onClose;
|
|
|
|
|
toolkit::Ticker _replay_ticker;
|
2019-06-06 18:28:33 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif //FFMPEG_SOURCE_H
|