/* * Copyright (C) 2007, 2008, 2009, 2010 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 COMPUTER, INC. ``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 COMPUTER, INC. OR * 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. */ #ifndef MediaPlayer_h #define MediaPlayer_h #if ENABLE(VIDEO) #if ENABLE(PLUGIN_PROXY_FOR_VIDEO) #include "MediaPlayerProxy.h" #endif #include "IntRect.h" #include "StringHash.h" #include <wtf/HashSet.h> #include <wtf/OwnPtr.h> #include <wtf/Noncopyable.h> #include <wtf/PassOwnPtr.h> #ifdef __OBJC__ @class QTMovie; #else class QTMovie; #endif namespace WebCore { // Structure that will hold every native // types supported by the current media player. // We have to do that has multiple media players // backend can live at runtime. typedef struct PlatformMedia { QTMovie* qtMovie; } PlatformMedia; static const PlatformMedia NoPlatformMedia = { 0 }; class ContentType; class FrameView; class GraphicsContext; class IntRect; class IntSize; class MediaPlayer; class MediaPlayerPrivateInterface; class String; class TimeRanges; #if USE(ACCELERATED_COMPOSITING) class GraphicsLayer; #endif class MediaPlayerClient { public: virtual ~MediaPlayerClient() { } // the network state has changed virtual void mediaPlayerNetworkStateChanged(MediaPlayer*) { } // the ready state has changed virtual void mediaPlayerReadyStateChanged(MediaPlayer*) { } // the volume state has changed virtual void mediaPlayerVolumeChanged(MediaPlayer*) { } // the mute state has changed virtual void mediaPlayerMuteChanged(MediaPlayer*) { } // time has jumped, eg. not as a result of normal playback virtual void mediaPlayerTimeChanged(MediaPlayer*) { } // the media file duration has changed, or is now known virtual void mediaPlayerDurationChanged(MediaPlayer*) { } // the playback rate has changed virtual void mediaPlayerRateChanged(MediaPlayer*) { } // The MediaPlayer has found potentially problematic media content. // This is used internally to trigger swapping from a <video> // element to an <embed> in standalone documents virtual void mediaPlayerSawUnsupportedTracks(MediaPlayer*) { } // Presentation-related methods // a new frame of video is available virtual void mediaPlayerRepaint(MediaPlayer*) { } // the movie size has changed virtual void mediaPlayerSizeChanged(MediaPlayer*) { } #if USE(ACCELERATED_COMPOSITING) // whether the rendering system can accelerate the display of this MediaPlayer. virtual bool mediaPlayerRenderingCanBeAccelerated(MediaPlayer*) { return false; } // return the GraphicsLayer that will host the presentation for this MediaPlayer. virtual GraphicsLayer* mediaPlayerGraphicsLayer(MediaPlayer*) { return 0; } #endif }; class MediaPlayer : public Noncopyable { public: static PassOwnPtr<MediaPlayer> create(MediaPlayerClient* client) { return new MediaPlayer(client); } virtual ~MediaPlayer(); // media engine support enum SupportsType { IsNotSupported, IsSupported, MayBeSupported }; static MediaPlayer::SupportsType supportsType(ContentType contentType); static void getSupportedTypes(HashSet<String>&); static bool isAvailable(); bool supportsFullscreen() const; bool supportsSave() const; PlatformMedia platformMedia() const; IntSize naturalSize(); bool hasVideo() const; bool hasAudio() const; #if PLATFORM(ANDROID) enum MediaElementType { Video, Audio }; void setMediaElementType(MediaElementType type) { m_mediaElementType = type; } MediaElementType mediaElementType() { return m_mediaElementType; } #endif void setFrameView(FrameView* frameView) { m_frameView = frameView; } FrameView* frameView() { return m_frameView; } bool inMediaDocument(); IntSize size() const { return m_size; } void setSize(const IntSize& size); void load(const String& url, const ContentType& contentType); void cancelLoad(); bool visible() const; void setVisible(bool); void prepareToPlay(); void play(); void pause(); bool paused() const; bool seeking() const; float duration() const; float currentTime() const; void seek(float time); float startTime() const; float rate() const; void setRate(float); bool preservesPitch() const; void setPreservesPitch(bool); PassRefPtr<TimeRanges> buffered(); float maxTimeSeekable(); unsigned bytesLoaded(); float volume() const; void setVolume(float); bool supportsMuting() const; bool muted() const; void setMuted(bool); bool hasClosedCaptions() const; void setClosedCaptionsVisible(bool closedCaptionsVisible); bool autobuffer() const; void setAutobuffer(bool); void paint(GraphicsContext*, const IntRect&); void paintCurrentFrameInContext(GraphicsContext*, const IntRect&); enum NetworkState { Empty, Idle, Loading, Loaded, FormatError, NetworkError, DecodeError }; NetworkState networkState(); enum ReadyState { HaveNothing, HaveMetadata, HaveCurrentData, HaveFutureData, HaveEnoughData }; ReadyState readyState(); enum MovieLoadType { Unknown, Download, StoredStream, LiveStream }; MovieLoadType movieLoadType() const; void networkStateChanged(); void readyStateChanged(); void volumeChanged(float); void muteChanged(bool); void timeChanged(); void sizeChanged(); void rateChanged(); void durationChanged(); void repaint(); MediaPlayerClient* mediaPlayerClient() const { return m_mediaPlayerClient; } bool hasAvailableVideoFrame() const; bool canLoadPoster() const; void setPoster(const String&); #if ENABLE(PLUGIN_PROXY_FOR_VIDEO) void deliverNotification(MediaPlayerProxyNotificationType notification); void setMediaPlayerProxy(WebMediaPlayerProxy* proxy); #endif #if USE(ACCELERATED_COMPOSITING) // whether accelerated rendering is supported by the media engine for the current media. bool supportsAcceleratedRendering() const; // called when the rendering system flips the into or out of accelerated rendering mode. void acceleratedRenderingStateChanged(); #endif bool hasSingleSecurityOrigin() const; private: MediaPlayer(MediaPlayerClient*); static void initializeMediaEngines(); MediaPlayerClient* m_mediaPlayerClient; OwnPtr<MediaPlayerPrivateInterface*> m_private; void* m_currentMediaEngine; FrameView* m_frameView; IntSize m_size; bool m_visible; float m_rate; float m_volume; bool m_muted; bool m_preservesPitch; bool m_autobuffer; #if PLATFORM(ANDROID) MediaElementType m_mediaElementType; #endif #if ENABLE(PLUGIN_PROXY_FOR_VIDEO) WebMediaPlayerProxy* m_playerProxy; // not owned or used, passed to m_private #endif }; typedef MediaPlayerPrivateInterface* (*CreateMediaEnginePlayer)(MediaPlayer*); typedef void (*MediaEngineSupportedTypes)(HashSet<String>& types); typedef MediaPlayer::SupportsType (*MediaEngineSupportsType)(const String& type, const String& codecs); typedef void (*MediaEngineRegistrar)(CreateMediaEnginePlayer, MediaEngineSupportedTypes, MediaEngineSupportsType); } #endif // ENABLE(VIDEO) #endif