OLD | NEW |
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 #include "media/base/android/media_player_bridge.h" | 5 #include "media/base/android/media_player_bridge.h" |
6 | 6 |
7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
8 #include "base/android/jni_string.h" | 8 #include "base/android/jni_string.h" |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 337 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
348 const int duration_ms = | 348 const int duration_ms = |
349 Java_MediaPlayerBridge_getDuration(env, j_media_player_bridge_.obj()); | 349 Java_MediaPlayerBridge_getDuration(env, j_media_player_bridge_.obj()); |
350 return duration_ms < 0 ? media::kInfiniteDuration() | 350 return duration_ms < 0 ? media::kInfiniteDuration() |
351 : base::TimeDelta::FromMilliseconds(duration_ms); | 351 : base::TimeDelta::FromMilliseconds(duration_ms); |
352 } | 352 } |
353 | 353 |
354 void MediaPlayerBridge::Release() { | 354 void MediaPlayerBridge::Release() { |
355 if (j_media_player_bridge_.is_null()) | 355 if (j_media_player_bridge_.is_null()) |
356 return; | 356 return; |
357 | 357 |
| 358 SetAudible(false); |
| 359 |
358 time_update_timer_.Stop(); | 360 time_update_timer_.Stop(); |
359 if (prepared_) { | 361 if (prepared_) { |
360 pending_seek_ = GetCurrentTime(); | 362 pending_seek_ = GetCurrentTime(); |
361 should_seek_on_prepare_ = true; | 363 should_seek_on_prepare_ = true; |
362 } | 364 } |
363 | 365 |
364 prepared_ = false; | 366 prepared_ = false; |
365 pending_play_ = false; | 367 pending_play_ = false; |
366 SetVideoSurface(gfx::ScopedJavaSurface()); | 368 SetVideoSurface(gfx::ScopedJavaSurface()); |
367 JNIEnv* env = base::android::AttachCurrentThread(); | 369 JNIEnv* env = base::android::AttachCurrentThread(); |
368 Java_MediaPlayerBridge_release(env, j_media_player_bridge_.obj()); | 370 Java_MediaPlayerBridge_release(env, j_media_player_bridge_.obj()); |
369 j_media_player_bridge_.Reset(); | 371 j_media_player_bridge_.Reset(); |
370 DetachListener(); | 372 DetachListener(); |
371 } | 373 } |
372 | 374 |
373 void MediaPlayerBridge::SetVolume(double volume) { | 375 void MediaPlayerBridge::SetVolume(double volume) { |
374 if (j_media_player_bridge_.is_null()) { | 376 volume_ = volume; |
375 volume_ = volume; | 377 |
| 378 if (j_media_player_bridge_.is_null()) |
376 return; | 379 return; |
377 } | |
378 | 380 |
379 JNIEnv* env = base::android::AttachCurrentThread(); | 381 JNIEnv* env = base::android::AttachCurrentThread(); |
380 CHECK(env); | 382 CHECK(env); |
| 383 |
| 384 // Update the audible state if we are playing. |
| 385 jboolean is_playing = Java_MediaPlayerBridge_isPlaying( |
| 386 env, j_media_player_bridge_.obj()); |
| 387 if (is_playing) |
| 388 SetAudible(volume_ > 0); |
| 389 |
381 Java_MediaPlayerBridge_setVolume( | 390 Java_MediaPlayerBridge_setVolume( |
382 env, j_media_player_bridge_.obj(), volume); | 391 env, j_media_player_bridge_.obj(), volume_); |
383 } | 392 } |
384 | 393 |
385 void MediaPlayerBridge::OnVideoSizeChanged(int width, int height) { | 394 void MediaPlayerBridge::OnVideoSizeChanged(int width, int height) { |
386 width_ = width; | 395 width_ = width; |
387 height_ = height; | 396 height_ = height; |
388 MediaPlayerAndroid::OnVideoSizeChanged(width, height); | 397 MediaPlayerAndroid::OnVideoSizeChanged(width, height); |
389 } | 398 } |
390 | 399 |
391 void MediaPlayerBridge::OnPlaybackComplete() { | 400 void MediaPlayerBridge::OnPlaybackComplete() { |
| 401 SetAudible(false); |
392 time_update_timer_.Stop(); | 402 time_update_timer_.Stop(); |
393 MediaPlayerAndroid::OnPlaybackComplete(); | 403 MediaPlayerAndroid::OnPlaybackComplete(); |
394 } | 404 } |
395 | 405 |
396 void MediaPlayerBridge::OnMediaInterrupted() { | 406 void MediaPlayerBridge::OnMediaInterrupted() { |
| 407 SetAudible(false); |
397 time_update_timer_.Stop(); | 408 time_update_timer_.Stop(); |
398 MediaPlayerAndroid::OnMediaInterrupted(); | 409 MediaPlayerAndroid::OnMediaInterrupted(); |
399 } | 410 } |
400 | 411 |
401 void MediaPlayerBridge::OnMediaPrepared() { | 412 void MediaPlayerBridge::OnMediaPrepared() { |
402 if (j_media_player_bridge_.is_null()) | 413 if (j_media_player_bridge_.is_null()) |
403 return; | 414 return; |
404 | 415 |
405 prepared_ = true; | 416 prepared_ = true; |
406 duration_ = GetDuration(); | 417 duration_ = GetDuration(); |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
446 | 457 |
447 void MediaPlayerBridge::StartInternal() { | 458 void MediaPlayerBridge::StartInternal() { |
448 JNIEnv* env = base::android::AttachCurrentThread(); | 459 JNIEnv* env = base::android::AttachCurrentThread(); |
449 Java_MediaPlayerBridge_start(env, j_media_player_bridge_.obj()); | 460 Java_MediaPlayerBridge_start(env, j_media_player_bridge_.obj()); |
450 if (!time_update_timer_.IsRunning()) { | 461 if (!time_update_timer_.IsRunning()) { |
451 time_update_timer_.Start( | 462 time_update_timer_.Start( |
452 FROM_HERE, | 463 FROM_HERE, |
453 base::TimeDelta::FromMilliseconds(kTimeUpdateInterval), | 464 base::TimeDelta::FromMilliseconds(kTimeUpdateInterval), |
454 this, &MediaPlayerBridge::OnTimeUpdateTimerFired); | 465 this, &MediaPlayerBridge::OnTimeUpdateTimerFired); |
455 } | 466 } |
| 467 |
| 468 SetAudible(volume_ > 0); |
456 } | 469 } |
457 | 470 |
458 void MediaPlayerBridge::PauseInternal() { | 471 void MediaPlayerBridge::PauseInternal() { |
| 472 SetAudible(false); |
| 473 |
459 JNIEnv* env = base::android::AttachCurrentThread(); | 474 JNIEnv* env = base::android::AttachCurrentThread(); |
460 Java_MediaPlayerBridge_pause(env, j_media_player_bridge_.obj()); | 475 Java_MediaPlayerBridge_pause(env, j_media_player_bridge_.obj()); |
461 time_update_timer_.Stop(); | 476 time_update_timer_.Stop(); |
462 } | 477 } |
463 | 478 |
464 void MediaPlayerBridge::PendingSeekInternal(const base::TimeDelta& time) { | 479 void MediaPlayerBridge::PendingSeekInternal(const base::TimeDelta& time) { |
465 SeekInternal(time); | 480 SeekInternal(time); |
466 } | 481 } |
467 | 482 |
468 void MediaPlayerBridge::SeekInternal(base::TimeDelta time) { | 483 void MediaPlayerBridge::SeekInternal(base::TimeDelta time) { |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
510 | 525 |
511 GURL MediaPlayerBridge::GetUrl() { | 526 GURL MediaPlayerBridge::GetUrl() { |
512 return url_; | 527 return url_; |
513 } | 528 } |
514 | 529 |
515 GURL MediaPlayerBridge::GetFirstPartyForCookies() { | 530 GURL MediaPlayerBridge::GetFirstPartyForCookies() { |
516 return first_party_for_cookies_; | 531 return first_party_for_cookies_; |
517 } | 532 } |
518 | 533 |
519 } // namespace media | 534 } // namespace media |
OLD | NEW |