blob: b15c7be413c1bc1091fc92e19a0dae50de24d6a7 [file] [log] [blame]
/*
* Copyright (C) 2021, 2022 Igalia S.L
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* aint with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#pragma once
#if USE(GSTREAMER_TRANSCODER)
#include "GRefPtrGStreamer.h"
#include "MediaRecorderPrivate.h"
#include "SharedBuffer.h"
#include <gst/transcoder/gsttranscoder.h>
#include <wtf/CompletionHandler.h>
#include <wtf/Condition.h>
#include <wtf/Forward.h>
#include <wtf/Lock.h>
#include <wtf/WeakPtr.h>
namespace WebCore {
class ContentType;
class MediaStreamTrackPrivate;
struct MediaRecorderPrivateOptions;
class MediaRecorderPrivateGStreamer final : public MediaRecorderPrivate, public CanMakeWeakPtr<MediaRecorderPrivateGStreamer> {
WTF_MAKE_FAST_ALLOCATED;
public:
static std::unique_ptr<MediaRecorderPrivateGStreamer> create(MediaStreamPrivate&, const MediaRecorderPrivateOptions&);
explicit MediaRecorderPrivateGStreamer(MediaStreamPrivate&, const MediaRecorderPrivateOptions&);
~MediaRecorderPrivateGStreamer();
static bool isTypeSupported(const ContentType&);
protected:
bool preparePipeline();
private:
void videoFrameAvailable(VideoFrame&, VideoFrameTimeMetadata) final { };
void audioSamplesAvailable(const WTF::MediaTime&, const PlatformAudioData&, const AudioStreamDescription&, size_t) final { };
void fetchData(FetchDataCallback&&) final;
void startRecording(StartRecordingCallback&&) final;
void stopRecording(CompletionHandler<void()>&&) final;
void pauseRecording(CompletionHandler<void()>&&) final;
void resumeRecording(CompletionHandler<void()>&&) final;
const String& mimeType() const final;
void setSource(GstElement*);
void setSink(GstElement*);
void configureVideoEncoder(GstElement*);
GRefPtr<GstEncodingContainerProfile> containerProfile();
MediaStreamPrivate& stream() const { return m_stream; }
void processSample(GRefPtr<GstSample>&&);
void notifyPosition(GstClockTime position) { m_position = GST_TIME_AS_SECONDS(position); }
void notifyEOS();
GRefPtr<GstEncodingProfile> m_audioEncodingProfile;
GRefPtr<GstEncodingProfile> m_videoEncodingProfile;
GRefPtr<GstTranscoder> m_transcoder;
GRefPtr<GstTranscoderSignalAdapter> m_signalAdapter;
GRefPtr<GstElement> m_pipeline;
GRefPtr<GstElement> m_src;
GRefPtr<GstElement> m_sink;
Condition m_eosCondition;
Lock m_eosLock;
bool m_eos WTF_GUARDED_BY_LOCK(m_eosLock);
double m_position { 0 };
Lock m_dataLock;
SharedBufferBuilder m_data WTF_GUARDED_BY_LOCK(m_dataLock);
MediaStreamPrivate& m_stream;
const MediaRecorderPrivateOptions& m_options;
};
} // namespace WebCore
#endif // USE(GSTREAMER_TRANSCODER)