blob: f325c6dd69cf82ca1805ad151d1746db6d16d76d [file] [log] [blame]
/*
* Copyright (C) 2015-2017 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#if ENABLE(VIDEO_TRACK) && ENABLE(MEDIA_STREAM)
#include "AudioTrackPrivate.h"
#include "MediaStreamTrackPrivate.h"
namespace WebCore {
class AudioMediaStreamTrackRenderer;
class AudioTrackPrivateMediaStream final : public AudioTrackPrivate, private MediaStreamTrackPrivate::Observer {
WTF_MAKE_NONCOPYABLE(AudioTrackPrivateMediaStream)
public:
static RefPtr<AudioTrackPrivateMediaStream> create(MediaStreamTrackPrivate& streamTrack)
{
return adoptRef(*new AudioTrackPrivateMediaStream(streamTrack));
}
~AudioTrackPrivateMediaStream();
void setTrackIndex(int index) { m_index = index; }
MediaStreamTrackPrivate& streamTrack() { return m_streamTrack.get(); }
MediaTime timelineOffset() const { return m_timelineOffset; }
void setTimelineOffset(const MediaTime& offset) { m_timelineOffset = offset; }
void clear();
void play();
void pause();
bool isPlaying() { return m_isPlaying; }
void setVolume(float);
float volume() const;
void setMuted(bool muted) { m_muted = muted; }
bool muted() const { return m_muted; }
#if !RELEASE_LOG_DISABLED
void setLogger(const Logger&, const void*) final;
const char* logClassName() const final { return "AudioTrackPrivateMediaStream"; }
#endif
protected:
explicit AudioTrackPrivateMediaStream(MediaStreamTrackPrivate&);
// AudioTrackPrivate
Kind kind() const final { return Kind::Main; }
AtomString id() const final { return m_id; }
AtomString label() const final { return m_label; }
int trackIndex() const final { return m_index; }
// MediaStreamTrackPrivate::Observer
void audioSamplesAvailable(MediaStreamTrackPrivate&, const MediaTime&, const PlatformAudioData&, const AudioStreamDescription&, size_t) final;
void trackEnded(MediaStreamTrackPrivate&) final;
void trackMutedChanged(MediaStreamTrackPrivate&) final;
void trackEnabledChanged(MediaStreamTrackPrivate&) final;
void trackSettingsChanged(MediaStreamTrackPrivate&) final { }
void playInternal();
void updateRendererMutedState();
// Main thread writable members
bool m_isPlaying { false };
bool m_autoPlay { false };
bool m_muted { false };
bool m_isCleared { false };
Ref<MediaStreamTrackPrivate> m_streamTrack;
AtomString m_id;
AtomString m_label;
int m_index { 0 };
MediaTime m_timelineOffset;
// Audio thread members
std::unique_ptr<AudioMediaStreamTrackRenderer> m_renderer;
bool m_hasStartedAutoplay { false };
};
}
#endif // ENABLE(VIDEO_TRACK) && ENABLE(MEDIA_STREAM)