mirror of
https://github.com/obsproject/obs-studio.git
synced 2026-01-03 03:48:16 -05:00
150 lines
4.8 KiB
C++
150 lines
4.8 KiB
C++
#pragma once
|
|
|
|
#include <utility/MultitrackVideoOutput.hpp>
|
|
#include <utility/WHIPSimulcastEncoders.hpp>
|
|
|
|
#include <obs.hpp>
|
|
#include <util/dstr.hpp>
|
|
|
|
#include <future>
|
|
|
|
#define RTMP_PROTOCOL "rtmp"
|
|
#define SRT_PROTOCOL "srt"
|
|
#define RIST_PROTOCOL "rist"
|
|
|
|
class OBSBasic;
|
|
|
|
using SetupStreamingContinuation_t = std::function<void(bool)>;
|
|
|
|
struct BasicOutputHandler {
|
|
OBSOutputAutoRelease fileOutput;
|
|
OBSOutputAutoRelease streamOutput;
|
|
OBSOutputAutoRelease replayBuffer;
|
|
OBSOutputAutoRelease virtualCam;
|
|
bool streamingActive = false;
|
|
bool recordingActive = false;
|
|
bool delayActive = false;
|
|
bool replayBufferActive = false;
|
|
bool virtualCamActive = false;
|
|
OBSBasic *main;
|
|
|
|
std::unique_ptr<MultitrackVideoOutput> multitrackVideo;
|
|
bool multitrackVideoActive = false;
|
|
|
|
OBSOutputAutoRelease StreamingOutput() const
|
|
{
|
|
return (multitrackVideo && multitrackVideoActive)
|
|
? multitrackVideo->StreamingOutput()
|
|
: OBSOutputAutoRelease{obs_output_get_ref(streamOutput)};
|
|
}
|
|
|
|
obs_view_t *virtualCamView = nullptr;
|
|
video_t *virtualCamVideo = nullptr;
|
|
obs_scene_t *vCamSourceScene = nullptr;
|
|
obs_sceneitem_t *vCamSourceSceneItem = nullptr;
|
|
|
|
std::unique_ptr<WHIPSimulcastEncoders> whipSimulcastEncoders;
|
|
|
|
std::string outputType;
|
|
std::string lastError;
|
|
|
|
std::string lastRecordingPath;
|
|
|
|
OBSSignal startRecording;
|
|
OBSSignal stopRecording;
|
|
OBSSignal startReplayBuffer;
|
|
OBSSignal stopReplayBuffer;
|
|
OBSSignal startStreaming;
|
|
OBSSignal stopStreaming;
|
|
OBSSignal startVirtualCam;
|
|
OBSSignal stopVirtualCam;
|
|
OBSSignal deactivateVirtualCam;
|
|
OBSSignal streamDelayStarting;
|
|
OBSSignal streamStopping;
|
|
OBSSignal recordStopping;
|
|
OBSSignal recordFileChanged;
|
|
OBSSignal replayBufferStopping;
|
|
OBSSignal replayBufferSaved;
|
|
|
|
BasicOutputHandler(OBSBasic *main_);
|
|
|
|
virtual ~BasicOutputHandler() {};
|
|
|
|
virtual std::shared_future<void> SetupStreaming(obs_service_t *service,
|
|
SetupStreamingContinuation_t continuation) = 0;
|
|
virtual bool StartStreaming(obs_service_t *service) = 0;
|
|
virtual bool StartRecording() = 0;
|
|
virtual bool StartReplayBuffer() { return false; }
|
|
virtual bool StartVirtualCam();
|
|
virtual void StopStreaming(bool force = false) = 0;
|
|
virtual void StopRecording(bool force = false) = 0;
|
|
virtual void StopReplayBuffer(bool force = false) { (void)force; }
|
|
virtual void StopVirtualCam();
|
|
virtual bool StreamingActive() const = 0;
|
|
virtual bool RecordingActive() const = 0;
|
|
virtual bool ReplayBufferActive() const { return false; }
|
|
virtual bool VirtualCamActive() const;
|
|
|
|
virtual void Update() = 0;
|
|
virtual void SetupOutputs() = 0;
|
|
|
|
virtual void UpdateVirtualCamOutputSource();
|
|
virtual void DestroyVirtualCamView();
|
|
virtual void DestroyVirtualCameraScene();
|
|
|
|
inline bool Active() const
|
|
{
|
|
return streamingActive || recordingActive || delayActive || replayBufferActive || virtualCamActive ||
|
|
multitrackVideoActive;
|
|
}
|
|
|
|
protected:
|
|
void SetupAutoRemux(const char *&container);
|
|
std::string GetRecordingFilename(const char *path, const char *container, bool noSpace, bool overwrite,
|
|
const char *format, bool ffmpeg);
|
|
|
|
std::shared_future<void> SetupMultitrackVideo(obs_service_t *service, std::string audio_encoder_id,
|
|
size_t main_audio_mixer, std::optional<size_t> vod_track_mixer,
|
|
std::function<void(std::optional<bool>)> continuation);
|
|
OBSDataAutoRelease GenerateMultitrackVideoStreamDumpConfig();
|
|
};
|
|
|
|
BasicOutputHandler *CreateSimpleOutputHandler(OBSBasic *main);
|
|
BasicOutputHandler *CreateAdvancedOutputHandler(OBSBasic *main);
|
|
|
|
void OBSStreamStarting(void *data, calldata_t *params);
|
|
void OBSStreamStopping(void *data, calldata_t *params);
|
|
void OBSStartStreaming(void *data, calldata_t *params);
|
|
void OBSStopStreaming(void *data, calldata_t *params);
|
|
void OBSStartRecording(void *data, calldata_t *params);
|
|
void OBSStopRecording(void *data, calldata_t *params);
|
|
void OBSRecordStopping(void *data, calldata_t *params);
|
|
void OBSRecordFileChanged(void *data, calldata_t *params);
|
|
void OBSStartReplayBuffer(void *data, calldata_t *params);
|
|
void OBSStopReplayBuffer(void *data, calldata_t *params);
|
|
void OBSReplayBufferStopping(void *data, calldata_t *params);
|
|
void OBSReplayBufferSaved(void *data, calldata_t *params);
|
|
|
|
inline bool can_use_output(const char *prot, const char *output, const char *prot_test1,
|
|
const char *prot_test2 = nullptr)
|
|
{
|
|
return (strcmp(prot, prot_test1) == 0 || (prot_test2 && strcmp(prot, prot_test2) == 0)) &&
|
|
(obs_get_output_flags(output) & OBS_OUTPUT_SERVICE) != 0;
|
|
}
|
|
|
|
const char *GetStreamOutputType(const obs_service_t *service);
|
|
|
|
inline bool ServiceSupportsVodTrack(const char *service)
|
|
{
|
|
static const char *vodTrackServices[] = {"Twitch"};
|
|
|
|
for (const char *vodTrackService : vodTrackServices) {
|
|
if (astrcmpi(vodTrackService, service) == 0)
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
void clear_archive_encoder(obs_output_t *output, const char *expected_name);
|