Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / media / base / android / media_player_manager.h
blobe9edd884e461b4dccc818a87189abf6581e814b6
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.
5 #ifndef MEDIA_BASE_ANDROID_MEDIA_PLAYER_MANAGER_H_
6 #define MEDIA_BASE_ANDROID_MEDIA_PLAYER_MANAGER_H_
8 #include "base/basictypes.h"
9 #include "base/time/time.h"
10 #include "media/base/android/demuxer_stream_player_params.h"
11 #include "media/base/media_export.h"
13 namespace media {
15 class MediaPlayerAndroid;
16 class MediaResourceGetter;
17 class MediaUrlInterceptor;
19 // This class is responsible for managing active MediaPlayerAndroid objects.
20 class MEDIA_EXPORT MediaPlayerManager {
21 public:
22 virtual ~MediaPlayerManager() {}
24 // Returns a pointer to the MediaResourceGetter object.
25 virtual MediaResourceGetter* GetMediaResourceGetter() = 0;
27 // Returns a pointer to the MediaUrlInterceptor object or null.
28 virtual MediaUrlInterceptor* GetMediaUrlInterceptor() = 0;
30 // Called when time update messages need to be sent. Args: player ID,
31 // current timestamp, current time ticks.
32 virtual void OnTimeUpdate(int player_id,
33 base::TimeDelta current_timestamp,
34 base::TimeTicks current_time_ticks) = 0;
36 // Called when media metadata changed. Args: player ID, duration of the
37 // media, width, height, whether the metadata is successfully extracted.
38 virtual void OnMediaMetadataChanged(
39 int player_id,
40 base::TimeDelta duration,
41 int width,
42 int height,
43 bool success) = 0;
45 // Called when playback completed. Args: player ID.
46 virtual void OnPlaybackComplete(int player_id) = 0;
48 // Called when media download was interrupted. Args: player ID.
49 virtual void OnMediaInterrupted(int player_id) = 0;
51 // Called when buffering has changed. Args: player ID, percentage
52 // of the media.
53 virtual void OnBufferingUpdate(int player_id, int percentage) = 0;
55 // Called when seek completed. Args: player ID, current time.
56 virtual void OnSeekComplete(
57 int player_id,
58 const base::TimeDelta& current_time) = 0;
60 // Called when error happens. Args: player ID, error type.
61 virtual void OnError(int player_id, int error) = 0;
63 // Called when video size has changed. Args: player ID, width, height.
64 virtual void OnVideoSizeChanged(int player_id, int width, int height) = 0;
66 // Called when the player pauses as a new key is required to decrypt
67 // encrypted content.
68 virtual void OnWaitingForDecryptionKey(int player_id) = 0;
70 // Returns the player that's in the fullscreen mode currently.
71 virtual MediaPlayerAndroid* GetFullscreenPlayer() = 0;
73 // Returns the player with the specified id.
74 virtual MediaPlayerAndroid* GetPlayer(int player_id) = 0;
76 // Called by the player to request the playback for given duration. The
77 // manager should use this opportunity to check if the current context is
78 // appropriate for a media to play.
79 // Returns whether the request was granted.
80 virtual bool RequestPlay(int player_id, base::TimeDelta duration) = 0;
83 } // namespace media
85 #endif // MEDIA_BASE_ANDROID_MEDIA_PLAYER_MANAGER_H_