Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_RENDERER_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ |
| 6 #define CONTENT_RENDERER_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ | 6 #define CONTENT_RENDERER_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ |
| 7 | 7 |
| 8 #include <jni.h> | 8 #include <jni.h> |
| 9 #include <string> | 9 #include <string> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 22 #include "content/renderer/media/android/stream_texture_factory.h" | 22 #include "content/renderer/media/android/stream_texture_factory.h" |
| 23 #include "content/renderer/media/crypto/proxy_decryptor.h" | 23 #include "content/renderer/media/crypto/proxy_decryptor.h" |
| 24 #include "gpu/command_buffer/common/mailbox.h" | 24 #include "gpu/command_buffer/common/mailbox.h" |
| 25 #include "media/base/android/media_player_android.h" | 25 #include "media/base/android/media_player_android.h" |
| 26 #include "media/base/demuxer_stream.h" | 26 #include "media/base/demuxer_stream.h" |
| 27 #include "media/base/media_keys.h" | 27 #include "media/base/media_keys.h" |
| 28 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" | 28 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" |
| 29 #include "third_party/WebKit/public/platform/WebMediaPlayer.h" | 29 #include "third_party/WebKit/public/platform/WebMediaPlayer.h" |
| 30 #include "third_party/WebKit/public/platform/WebSize.h" | 30 #include "third_party/WebKit/public/platform/WebSize.h" |
| 31 #include "third_party/WebKit/public/platform/WebURL.h" | 31 #include "third_party/WebKit/public/platform/WebURL.h" |
| 32 #include "third_party/skia/include/core/SkBitmap.h" | |
| 33 #include "third_party/skia/include/gpu/GrContext.h" | |
| 34 #include "third_party/skia/include/gpu/SkGrPixelRef.h" | |
| 32 #include "ui/gfx/rect_f.h" | 35 #include "ui/gfx/rect_f.h" |
| 33 | 36 |
| 34 namespace base { | 37 namespace base { |
| 35 class MessageLoopProxy; | 38 class MessageLoopProxy; |
| 36 } | 39 } |
| 37 | 40 |
| 38 namespace blink { | 41 namespace blink { |
| 39 class WebContentDecryptionModule; | 42 class WebContentDecryptionModule; |
| 40 class WebFrame; | 43 class WebFrame; |
| 41 class WebURL; | 44 class WebURL; |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 95 virtual void seek(double seconds); | 98 virtual void seek(double seconds); |
| 96 virtual bool supportsSave() const; | 99 virtual bool supportsSave() const; |
| 97 virtual void setRate(double rate); | 100 virtual void setRate(double rate); |
| 98 virtual void setVolume(double volume); | 101 virtual void setVolume(double volume); |
| 99 virtual blink::WebTimeRanges buffered() const; | 102 virtual blink::WebTimeRanges buffered() const; |
| 100 virtual double maxTimeSeekable() const; | 103 virtual double maxTimeSeekable() const; |
| 101 | 104 |
| 102 // Poster image, as defined in the <video> element. | 105 // Poster image, as defined in the <video> element. |
| 103 virtual void setPoster(const blink::WebURL& poster) OVERRIDE; | 106 virtual void setPoster(const blink::WebURL& poster) OVERRIDE; |
| 104 | 107 |
| 108 // FIXME: This path "only works" on Android. It is a workaround for the proble m that Skia could not handle Android's GL_TEXTURE_EXTERNAL_OES | |
| 109 // texture internally. It should be removed and replaced by the normal paint p ath. | |
| 110 // https://code.google.com/p/skia/issues/detail?id=1189 | |
| 105 // Methods for painting. | 111 // Methods for painting. |
| 106 virtual void paint(blink::WebCanvas* canvas, | 112 virtual void paint(blink::WebCanvas* canvas, |
| 107 const blink::WebRect& rect, | 113 const blink::WebRect& rect, |
| 108 unsigned char alpha); | 114 unsigned char alpha); |
| 109 | 115 |
| 110 virtual bool copyVideoTextureToPlatformTexture( | 116 virtual bool copyVideoTextureToPlatformTexture( |
| 111 blink::WebGraphicsContext3D* web_graphics_context, | 117 blink::WebGraphicsContext3D* web_graphics_context, |
| 112 unsigned int texture, | 118 unsigned int texture, |
| 113 unsigned int level, | 119 unsigned int level, |
| 114 unsigned int internal_format, | 120 unsigned int internal_format, |
| (...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 269 const std::string& session_id); | 275 const std::string& session_id); |
| 270 MediaKeyException CancelKeyRequestInternal(const std::string& key_system, | 276 MediaKeyException CancelKeyRequestInternal(const std::string& key_system, |
| 271 const std::string& session_id); | 277 const std::string& session_id); |
| 272 | 278 |
| 273 // Requests that this object notifies when a decryptor is ready through the | 279 // Requests that this object notifies when a decryptor is ready through the |
| 274 // |decryptor_ready_cb| provided. | 280 // |decryptor_ready_cb| provided. |
| 275 // If |decryptor_ready_cb| is null, the existing callback will be fired with | 281 // If |decryptor_ready_cb| is null, the existing callback will be fired with |
| 276 // NULL immediately and reset. | 282 // NULL immediately and reset. |
| 277 void SetDecryptorReadyCB(const media::DecryptorReadyCB& decryptor_ready_cb); | 283 void SetDecryptorReadyCB(const media::DecryptorReadyCB& decryptor_ready_cb); |
| 278 | 284 |
| 285 bool ensureTextureBackedSkBitmap(GrContext* gr, SkBitmap& bitmap, const blink: :WebSize& size, GrSurfaceOrigin origin, GrPixelConfig config); | |
|
qinmin
2014/07/25 17:01:10
s/ensure/Ensure/
Srirama
2014/07/25 18:06:29
Done.
| |
| 286 | |
| 279 blink::WebFrame* const frame_; | 287 blink::WebFrame* const frame_; |
| 280 | 288 |
| 281 blink::WebMediaPlayerClient* const client_; | 289 blink::WebMediaPlayerClient* const client_; |
| 282 | 290 |
| 283 // |delegate_| is used to notify the browser process of the player status, so | 291 // |delegate_| is used to notify the browser process of the player status, so |
| 284 // that the browser process can control screen locks. | 292 // that the browser process can control screen locks. |
| 285 // TODO(qinmin): Currently android mediaplayer takes care of the screen | 293 // TODO(qinmin): Currently android mediaplayer takes care of the screen |
| 286 // lock. So this is only used for media source. Will apply this to regular | 294 // lock. So this is only used for media source. Will apply this to regular |
| 287 // media tag once http://crbug.com/247892 is fixed. | 295 // media tag once http://crbug.com/247892 is fixed. |
| 288 base::WeakPtr<WebMediaPlayerDelegate> delegate_; | 296 base::WeakPtr<WebMediaPlayerDelegate> delegate_; |
| (...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 435 // Non-owned pointer to the CDM. Updated via calls to | 443 // Non-owned pointer to the CDM. Updated via calls to |
| 436 // setContentDecryptionModule(). | 444 // setContentDecryptionModule(). |
| 437 WebContentDecryptionModuleImpl* web_cdm_; | 445 WebContentDecryptionModuleImpl* web_cdm_; |
| 438 | 446 |
| 439 // This is only Used by Clear Key key system implementation, where a renderer | 447 // This is only Used by Clear Key key system implementation, where a renderer |
| 440 // side CDM will be used. This is similar to WebMediaPlayerImpl. For other key | 448 // side CDM will be used. This is similar to WebMediaPlayerImpl. For other key |
| 441 // systems, a browser side CDM will be used and we set CDM by calling | 449 // systems, a browser side CDM will be used and we set CDM by calling |
| 442 // player_manager_->SetCdm() directly. | 450 // player_manager_->SetCdm() directly. |
| 443 media::DecryptorReadyCB decryptor_ready_cb_; | 451 media::DecryptorReadyCB decryptor_ready_cb_; |
| 444 | 452 |
| 453 SkBitmap m_bitmap; | |
|
qinmin
2014/07/25 17:01:10
chromium doesn't use this naming scheme, use bitma
Srirama
2014/07/25 18:06:29
Done. Changed name to bitmap_ and regarding whethe
| |
| 454 | |
| 445 // NOTE: Weak pointers must be invalidated before all other member variables. | 455 // NOTE: Weak pointers must be invalidated before all other member variables. |
| 446 base::WeakPtrFactory<WebMediaPlayerAndroid> weak_factory_; | 456 base::WeakPtrFactory<WebMediaPlayerAndroid> weak_factory_; |
| 447 | 457 |
| 448 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerAndroid); | 458 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerAndroid); |
| 449 }; | 459 }; |
| 450 | 460 |
| 451 } // namespace content | 461 } // namespace content |
| 452 | 462 |
| 453 #endif // CONTENT_RENDERER_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ | 463 #endif // CONTENT_RENDERER_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ |
| OLD | NEW |