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

Unified Diff: chrome/browser/media/router/mojo/media_route_controller.cc

Issue 2727123002: [Media Router] Custom Controls 1 - Add MediaStatus, MediaRouteController, and mojo interfaces (Closed)
Patch Set: Address Mark, Devlin, Derek, and Daniel's comments Created 3 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/media/router/mojo/media_route_controller.cc
diff --git a/chrome/browser/media/router/mojo/media_route_controller.cc b/chrome/browser/media/router/mojo/media_route_controller.cc
new file mode 100644
index 0000000000000000000000000000000000000000..caba52ff22df98ccb898199bfd8f0fada6b57d15
--- /dev/null
+++ b/chrome/browser/media/router/mojo/media_route_controller.cc
@@ -0,0 +1,67 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/media/router/mojo/media_route_controller.h"
+
+#include <utility>
+
+#include "base/time/time.h"
+#include "chrome/browser/media/router/media_route_status_observer.h"
+#include "chrome/browser/media/router/media_router.h"
+#include "chrome/browser/media/router/media_status.h"
+#include "chrome/browser/media/router/mojo/media_router.mojom.h"
+#include "mojo/public/cpp/bindings/interface_request.h"
+
+namespace media_router {
+
+MediaRouteController::MediaRouteController(
+ mojom::MediaControllerPtr media_controller,
+ base::Closure destroyer_callback)
+ : destroyer_callback_(destroyer_callback),
+ media_controller_(std::move(media_controller)),
+ binding_(this) {}
+MediaRouteController::~MediaRouteController() {}
+
+void MediaRouteController::Play() {
+ media_controller_->Play();
+}
+
+void MediaRouteController::Pause() {
+ media_controller_->Pause();
+}
+
+void MediaRouteController::Seek(base::TimeDelta time) {
+ media_controller_->Seek(time);
+}
+
+void MediaRouteController::SetMute(bool mute) {
+ media_controller_->SetMute(mute);
+}
+
+void MediaRouteController::SetVolume(float volume) {
+ media_controller_->SetVolume(volume);
+}
+
+void MediaRouteController::AddObserver(MediaRouteStatusObserver* observer) {
+ observers_.AddObserver(observer);
+}
+
+void MediaRouteController::RemoveObserver(MediaRouteStatusObserver* observer) {
+ observers_.RemoveObserver(observer);
+ if (!observers_.might_have_observers()) {
+ destroyer_callback_.Run();
+ // |this| gets destroyed here!
+ }
imcheng 2017/03/11 03:07:52 1) If the associated MediaRoute is terminated, how
+}
+
+void MediaRouteController::OnMediaStatusUpdated(const MediaStatus& status) {
+ for (MediaRouteStatusObserver& observer : observers_)
+ observer.OnMediaStatusUpdated(status);
+}
+
+mojom::MediaStatusObserverPtr MediaRouteController::GetObserverPtr() {
+ return binding_.CreateInterfacePtrAndBind();
+}
+
+} // namespace media_router

Powered by Google App Engine
This is Rietveld 408576698