Home | History | Annotate | Download | only in android
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #ifndef MEDIA_BASE_ANDROID_MEDIA_PLAYER_MANAGER_H_
      6 #define MEDIA_BASE_ANDROID_MEDIA_PLAYER_MANAGER_H_
      7 
      8 #include <string>
      9 #include <vector>
     10 
     11 #include "base/basictypes.h"
     12 #include "base/time/time.h"
     13 #include "media/base/android/demuxer_stream_player_params.h"
     14 #include "media/base/media_export.h"
     15 #include "media/base/media_keys.h"
     16 
     17 namespace media {
     18 
     19 class MediaDrmBridge;
     20 class MediaPlayerAndroid;
     21 class MediaResourceGetter;
     22 
     23 // This class is responsible for managing active MediaPlayerAndroid objects.
     24 class MEDIA_EXPORT MediaPlayerManager {
     25  public:
     26   virtual ~MediaPlayerManager() {}
     27 
     28   // Called by a MediaPlayerAndroid object when it is going to decode
     29   // media streams. This helps the manager object maintain an array
     30   // of active MediaPlayerAndroid objects and release the resources
     31   // when needed.
     32   virtual void RequestMediaResources(int player_id) = 0;
     33 
     34   // Called when a MediaPlayerAndroid object releases all its decoding
     35   // resources.
     36   virtual void ReleaseMediaResources(int player_id) = 0;
     37 
     38   // Return a pointer to the MediaResourceGetter object.
     39   virtual MediaResourceGetter* GetMediaResourceGetter() = 0;
     40 
     41   // Called when time update messages need to be sent. Args: player ID,
     42   // current time.
     43   virtual void OnTimeUpdate(int player_id, base::TimeDelta current_time) = 0;
     44 
     45   // Called when media metadata changed. Args: player ID, duration of the
     46   // media, width, height, whether the metadata is successfully extracted.
     47   virtual void OnMediaMetadataChanged(
     48       int player_id,
     49       base::TimeDelta duration,
     50       int width,
     51       int height,
     52       bool success) = 0;
     53 
     54   // Called when playback completed. Args: player ID.
     55   virtual void OnPlaybackComplete(int player_id) = 0;
     56 
     57   // Called when media download was interrupted. Args: player ID.
     58   virtual void OnMediaInterrupted(int player_id) = 0;
     59 
     60   // Called when buffering has changed. Args: player ID, percentage
     61   // of the media.
     62   virtual void OnBufferingUpdate(int player_id, int percentage) = 0;
     63 
     64   // Called when seek completed. Args: player ID, current time.
     65   virtual void OnSeekComplete(
     66       int player_id,
     67       const base::TimeDelta& current_time) = 0;
     68 
     69   // Called when error happens. Args: player ID, error type.
     70   virtual void OnError(int player_id, int error) = 0;
     71 
     72   // Called when video size has changed. Args: player ID, width, height.
     73   virtual void OnVideoSizeChanged(int player_id, int width, int height) = 0;
     74 
     75   // Returns the player that's in the fullscreen mode currently.
     76   virtual MediaPlayerAndroid* GetFullscreenPlayer() = 0;
     77 
     78   // Returns the player with the specified id.
     79   virtual MediaPlayerAndroid* GetPlayer(int player_id) = 0;
     80 
     81   // Release all the players managed by this object.
     82   virtual void DestroyAllMediaPlayers() = 0;
     83 
     84   // Get the MediaDrmBridge object for the given media key Id.
     85   virtual media::MediaDrmBridge* GetDrmBridge(int media_keys_id) = 0;
     86 
     87   // Called by the player to get a hardware protected surface.
     88   virtual void OnProtectedSurfaceRequested(int player_id) = 0;
     89 
     90   // The following five methods are related to EME.
     91   // TODO(xhwang): These methods needs to be decoupled from MediaPlayerManager
     92   // to support the W3C Working Draft version of the EME spec.
     93   // http://crbug.com/315312
     94 
     95   // Called when MediaDrmBridge determines a SessionId.
     96   virtual void OnSessionCreated(int media_keys_id,
     97                                 uint32 session_id,
     98                                 const std::string& web_session_id) = 0;
     99 
    100   // Called when MediaDrmBridge wants to send a Message event.
    101   virtual void OnSessionMessage(int media_keys_id,
    102                                 uint32 session_id,
    103                                 const std::vector<uint8>& message,
    104                                 const std::string& destination_url) = 0;
    105 
    106   // Called when MediaDrmBridge wants to send a Ready event.
    107   virtual void OnSessionReady(int media_keys_id, uint32 session_id) = 0;
    108 
    109   // Called when MediaDrmBridge wants to send a Closed event.
    110   virtual void OnSessionClosed(int media_keys_id, uint32 session_id) = 0;
    111 
    112   // Called when MediaDrmBridge wants to send an Error event.
    113   virtual void OnSessionError(int media_keys_id,
    114                               uint32 session_id,
    115                               media::MediaKeys::KeyError error_code,
    116                               int system_code) = 0;
    117 };
    118 
    119 }  // namespace media
    120 
    121 #endif  // MEDIA_BASE_ANDROID_MEDIA_PLAYER_MANAGER_H_
    122