blob: ea66d09bbfbcaedac7652afa55b03b0e6fec1ef3 [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COBALT_MEDIA_PLAYER_WEB_MEDIA_PLAYER_H_
#define COBALT_MEDIA_PLAYER_WEB_MEDIA_PLAYER_H_
// The temporary home for WebMediaPlayer and WebMediaPlayerClient. They are the
// interface between the HTMLMediaElement and the media stack.
#include <memory>
#include <string>
#include <vector>
#include "base/callback.h"
#include "base/compiler_specific.h"
#include "base/logging.h"
#include "base/memory/ref_counted.h"
#include "base/memory/weak_ptr.h"
#include "base/time/time.h"
#include "cobalt/math/rect.h"
#include "cobalt/math/size.h"
#include "cobalt/media/base/ranges.h"
#include "cobalt/media/base/video_frame_provider.h"
#include "cobalt/media/filters/chunk_demuxer.h"
#include "cobalt/media/player/buffered_data_source.h"
#include "url/gurl.h"
namespace cobalt {
namespace media {
class DrmSystem;
class WebMediaPlayer {
public:
// Return true if the punch through box should be rendered. Return false if
// no punch through box should be rendered.
typedef base::Callback<bool(const math::Rect&)> SetBoundsCB;
enum NetworkState {
kNetworkStateEmpty,
kNetworkStateIdle,
kNetworkStateLoading,
kNetworkStateLoaded,
kNetworkStateFormatError,
kNetworkStateNetworkError,
kNetworkStateDecodeError,
kNetworkStateCapabilityChangedError,
};
enum ReadyState {
kReadyStateHaveNothing,
kReadyStateHaveMetadata,
kReadyStateHaveCurrentData,
kReadyStateHaveFutureData,
kReadyStateHaveEnoughData,
};
enum AddIdStatus {
kAddIdStatusOk,
kAddIdStatusNotSupported,
kAddIdStatusReachedIdLimit
};
enum EndOfStreamStatus {
kEndOfStreamStatusNoError,
kEndOfStreamStatusNetworkError,
kEndOfStreamStatusDecodeError,
};
// Represents synchronous exceptions that can be thrown from the Encrypted
// Media methods. This is different from the asynchronous MediaKeyError.
enum MediaKeyException {
kMediaKeyExceptionNoError,
kMediaKeyExceptionInvalidPlayerState,
kMediaKeyExceptionKeySystemNotSupported,
};
enum CORSMode {
kCORSModeUnspecified,
kCORSModeAnonymous,
kCORSModeUseCredentials,
};
struct PlayerStatistics {
uint64_t audio_bytes_decoded = 0;
uint64_t video_bytes_decoded = 0;
uint32_t video_frames_decoded = 0;
uint32_t video_frames_dropped = 0;
};
virtual ~WebMediaPlayer() {}
#if SB_HAS(PLAYER_WITH_URL)
virtual void LoadUrl(const GURL& url) = 0;
#endif // SB_HAS(PLAYER_WITH_URL)
virtual void LoadMediaSource() = 0;
virtual void LoadProgressive(
const GURL& url, std::unique_ptr<BufferedDataSource> data_source) = 0;
virtual void CancelLoad() = 0;
// Playback controls.
virtual void Play() = 0;
virtual void Pause() = 0;
virtual bool SupportsFullscreen() const = 0;
virtual bool SupportsSave() const = 0;
virtual void Seek(float seconds) = 0;
virtual void SetEndTime(float seconds) = 0;
virtual void SetRate(float rate) = 0;
virtual void SetVolume(float volume) = 0;
virtual void SetVisible(bool visible) = 0;
virtual const Ranges<base::TimeDelta>& GetBufferedTimeRanges() = 0;
virtual float GetMaxTimeSeekable() const = 0;
// Suspend/Resume
virtual void Suspend() = 0;
// TODO: This is temporary for supporting background media playback.
// Need to be removed with media refactor.
virtual void Resume(SbWindow window) = 0;
// True if the loaded media has a playable video/audio track.
virtual bool HasVideo() const = 0;
virtual bool HasAudio() const = 0;
// Dimension of the video.
virtual math::Size GetNaturalSize() const = 0;
// Getters of playback state.
virtual bool IsPaused() const = 0;
virtual bool IsSeeking() const = 0;
virtual float GetDuration() const = 0;
#if SB_HAS(PLAYER_WITH_URL)
virtual base::Time GetStartDate() const = 0;
#endif // SB_HAS(PLAYER_WITH_URL)
virtual float GetCurrentTime() const = 0;
virtual float GetPlaybackRate() const = 0;
// Get rate of loading the resource.
virtual int GetDataRate() const = 0;
// Internal states of loading and network.
virtual NetworkState GetNetworkState() const = 0;
virtual ReadyState GetReadyState() const = 0;
virtual bool DidLoadingProgress() const = 0;
virtual bool HasSingleSecurityOrigin() const = 0;
virtual bool DidPassCORSAccessCheck() const = 0;
virtual float MediaTimeForTimeValue(float timeValue) const = 0;
virtual PlayerStatistics GetStatistics() const = 0;
virtual scoped_refptr<VideoFrameProvider> GetVideoFrameProvider() {
return NULL;
}
virtual AddIdStatus SourceAddId(const std::string& id,
const std::string& type,
const std::vector<std::string>& codecs) {
return kAddIdStatusNotSupported;
}
virtual bool SourceRemoveId(const std::string& id) { return false; }
virtual Ranges<base::TimeDelta> SourceBuffered(const std::string& id) {
return Ranges<base::TimeDelta>();
}
virtual bool SourceAppend(const std::string& id, const unsigned char* data,
unsigned length) {
return false;
}
virtual bool SourceAbort(const std::string& id) { return false; }
virtual double SourceGetDuration() const { return 0.0; }
virtual void SourceSetDuration(double duration) {}
virtual void SourceEndOfStream(EndOfStreamStatus status) {}
virtual bool SourceSetTimestampOffset(const std::string& id, double offset) {
return false;
}
virtual SetBoundsCB GetSetBoundsCB() { return SetBoundsCB(); }
// Instruct WebMediaPlayer to enter/exit fullscreen.
virtual void EnterFullscreen() {}
virtual void ExitFullscreen() {}
// Returns true if the player can enter fullscreen.
virtual bool CanEnterFullscreen() const { return false; }
// Returns the address and size of a chunk of memory to be included in a
// debug report. May not be supported on all platforms. The returned address
// should remain valid as long as the WebMediaPlayer instance is alive.
virtual bool GetDebugReportDataAddress(void** out_address, size_t* out_size) {
return false;
}
// Sets the DRM system which must be initialized with the data passed
// in |WebMediaPlayerClient::EncryptedMediaInitData|.
//
// |drm_system| must not be NULL. The method can only be called once.
virtual void SetDrmSystem(
const scoped_refptr<media::DrmSystem>& drm_system) = 0;
};
// TODO: Add prefix "On" to all methods that handle events, such
// as |NetworkStateChanged|, |SourceOpened|, |EncryptedMediaInitData|.
class WebMediaPlayerClient {
public:
virtual void NetworkStateChanged() = 0;
virtual void NetworkError(const std::string&) = 0;
virtual void ReadyStateChanged() = 0;
virtual void TimeChanged(bool eos_played) = 0;
virtual void DurationChanged() = 0;
virtual void OutputModeChanged() = 0;
virtual void ContentSizeChanged() = 0;
virtual void PlaybackStateChanged() = 0;
// TODO: Revisit the necessity of the following function.
virtual void SetOpaque(bool opaque) {}
virtual void SawUnsupportedTracks() = 0;
virtual float Volume() const = 0;
virtual void SourceOpened(ChunkDemuxer* chunk_demuxer) = 0;
virtual std::string SourceURL() const = 0;
virtual std::string MaxVideoCapabilities() const = 0;
// Clients should implement this in order to indicate a preference for whether
// a video should be decoded to a texture or through a punch out system. If
// the preferred output mode is not supported, the player will fallback to
// one that is. This can be used to indicate that, say, for spherical video
// playback, we would like a decode-to-texture output mode.
virtual bool PreferDecodeToTexture() { return false; }
// Notifies the client that a video is encrypted. Client is supposed to call
// |WebMediaPlayer::SetDrmSystem| as soon as possible to avoid stalling
// playback.
virtual void EncryptedMediaInitDataEncountered(EmeInitDataType init_data_type,
const unsigned char* init_data,
unsigned init_data_length) = 0;
// TODO: Revisit the necessity of the following functions.
virtual void CloseHelperPlugin() { NOTREACHED(); }
virtual void DisableAcceleratedCompositing() {}
protected:
~WebMediaPlayerClient() {}
};
} // namespace media
} // namespace cobalt
#endif // COBALT_MEDIA_PLAYER_WEB_MEDIA_PLAYER_H_