Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(631)

Side by Side Diff: content/browser/android/content_video_view.h

Issue 13669003: Refactoring ContentVideoViewContextDelegate.java (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_BROWSER_ANDROID_CONTENT_VIDEO_VIEW_H_ 5 #ifndef CONTENT_BROWSER_ANDROID_CONTENT_VIDEO_VIEW_H_
6 #define CONTENT_BROWSER_ANDROID_CONTENT_VIDEO_VIEW_H_ 6 #define CONTENT_BROWSER_ANDROID_CONTENT_VIDEO_VIEW_H_
7 7
8 #include <jni.h> 8 #include <jni.h>
9 9
10 #include "base/android/scoped_java_ref.h" 10 #include "base/android/scoped_java_ref.h"
11 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
13 #include "base/memory/scoped_ptr.h" 13 #include "base/memory/scoped_ptr.h"
14 #include "base/timer.h" 14 #include "base/timer.h"
15 15
16 namespace content { 16 namespace content {
17 17
18 class ContentViewCoreImpl;
18 class MediaPlayerManagerAndroid; 19 class MediaPlayerManagerAndroid;
19 20
20 // Native mirror of ContentVideoView.java. This class is responsible for 21 // Native mirror of ContentVideoView.java. This class is responsible for
21 // creating the Java video view and pass all the player status change to 22 // creating the Java video view and pass all the player status change to
22 // it. It accepts media control from Java class, and forwards it to 23 // it. It accepts media control from Java class, and forwards it to
23 // MediaPlayerManagerAndroid. 24 // MediaPlayerManagerAndroid.
24 class ContentVideoView { 25 class ContentVideoView {
25 public: 26 public:
26 // Construct a ContentVideoView object. The |manager| will handle all the 27 // Construct a ContentVideoView object. The |manager| will handle all the
27 // playback controls from the Java class. 28 // playback controls from the Java class.
28 explicit ContentVideoView(MediaPlayerManagerAndroid* manager); 29 explicit ContentVideoView(MediaPlayerManagerAndroid* manager);
29 ~ContentVideoView(); 30 ~ContentVideoView();
30 31
31 static bool RegisterContentVideoView(JNIEnv* env); 32 static bool RegisterContentVideoView(JNIEnv* env);
32 33
33 // Getter method called by the Java class to get the media information. 34 // Getter method called by the Java class to get the media information.
34 int GetVideoWidth(JNIEnv*, jobject obj) const; 35 int GetVideoWidth(JNIEnv*, jobject obj) const;
35 int GetVideoHeight(JNIEnv*, jobject obj) const; 36 int GetVideoHeight(JNIEnv*, jobject obj) const;
36 int GetDurationInMilliSeconds(JNIEnv*, jobject obj) const; 37 int GetDurationInMilliSeconds(JNIEnv*, jobject obj) const;
37 int GetCurrentPosition(JNIEnv*, jobject obj) const; 38 int GetCurrentPosition(JNIEnv*, jobject obj) const;
38 bool IsPlaying(JNIEnv*, jobject obj); 39 bool IsPlaying(JNIEnv*, jobject obj);
39 void UpdateMediaMetadata(JNIEnv*, jobject obj); 40 void UpdateMediaMetadata(JNIEnv*, jobject obj);
40 41
41 // Method to create and destroy the Java view. 42 // Method to create and destroy the Java view.
42 void DestroyContentVideoView(); 43 void DestroyContentVideoView();
43 void CreateContentVideoView(); 44 void CreateContentVideoView(
45 base::android::ScopedJavaLocalRef<jobject> content_video_view_client);
44 46
45 // Called when the Java fullscreen view is destroyed. If 47 // Called when the Java fullscreen view is destroyed. If
46 // |release_media_player| is true, |manager_| needs to release the player 48 // |release_media_player| is true, |manager_| needs to release the player
47 // as we are quitting the app. 49 // as we are quitting the app.
48 void ExitFullscreen(JNIEnv*, jobject, jboolean release_media_player); 50 void ExitFullscreen(JNIEnv*, jobject, jboolean release_media_player);
49 51
50 // Media control method called by the Java class. 52 // Media control method called by the Java class.
51 void SeekTo(JNIEnv*, jobject obj, jint msec); 53 void SeekTo(JNIEnv*, jobject obj, jint msec);
52 void Play(JNIEnv*, jobject obj); 54 void Play(JNIEnv*, jobject obj);
53 void Pause(JNIEnv*, jobject obj); 55 void Pause(JNIEnv*, jobject obj);
54 56
55 // Called by the Java class to pass the surface object to the player. 57 // Called by the Java class to pass the surface object to the player.
56 void SetSurface(JNIEnv*, jobject obj, jobject surface); 58 void SetSurface(JNIEnv*, jobject obj, jobject surface);
57 59
58 // Method called by |manager_| to inform the Java class about player status 60 // Method called by |manager_| to inform the Java class about player status
59 // change. 61 // change.
60 void UpdateMediaMetadata(); 62 void UpdateMediaMetadata();
61 void OnMediaPlayerError(int errorType); 63 void OnMediaPlayerError(int errorType);
62 void OnVideoSizeChanged(int width, int height); 64 void OnVideoSizeChanged(int width, int height);
63 void OnBufferingUpdate(int percent); 65 void OnBufferingUpdate(int percent);
64 void OnPlaybackComplete(); 66 void OnPlaybackComplete();
65 67
66 private: 68 private:
67 // Object that manages the fullscreen media player. It is responsible for 69 // Object that manages the fullscreen media player. It is responsible for
68 // handling all the playback controls. 70 // handling all the playback controls.
69 MediaPlayerManagerAndroid* manager_; 71 MediaPlayerManagerAndroid* manager_;
70 72
71 // Reference to the Java object. 73 // Reference to the Java object.
72 base::android::ScopedJavaGlobalRef<jobject> j_content_video_view_; 74 base::android::ScopedJavaGlobalRef<jobject> j_content_video_view_;
joth 2013/04/05 01:56:40 this is a problem: holding a strong ref to the jav
michaelbai 2013/04/05 21:06:56 Why WebView should be GCed? I think we need to bac
73 75
74 DISALLOW_COPY_AND_ASSIGN(ContentVideoView); 76 DISALLOW_COPY_AND_ASSIGN(ContentVideoView);
75 }; 77 };
76 78
77 } // namespace content 79 } // namespace content
78 80
79 #endif // CONTENT_BROWSER_ANDROID_CONTENT_VIDEO_VIEW_H_ 81 #endif // CONTENT_BROWSER_ANDROID_CONTENT_VIDEO_VIEW_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698