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

Side by Side 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: . 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 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.
4
5 #include "chrome/browser/media/router/mojo/media_route_controller.h"
6
7 #include <utility>
8
9 #include "chrome/browser/media/router/media_route_status_observer.h"
10 #include "chrome/browser/media/router/media_router.h"
11 #include "chrome/browser/media/router/media_status.h"
12 #include "chrome/browser/media/router/mojo/media_router.mojom.h"
13 #include "mojo/public/cpp/bindings/interface_request.h"
14
15 namespace media_router {
16
17 MediaRouteController::MediaRouteController(MediaRoute::Id route_id,
18 mojom::MediaRouteProvider* provider,
19 base::Closure destroyer_callback)
20 : destroyer_callback_(destroyer_callback),
21 provider_(provider),
22 route_id_(route_id) {
23 provider_->CreateMediaRouteController(
imcheng 2017/03/06 23:11:41 A couple of questions. 1) Can the initialization
takumif 2017/03/08 04:24:02 Yes, both are possible. Doing so.
24 route_id_, mojo::MakeRequest<mojom::MediaController>(&media_controller_),
25 base::Bind(&MediaRouteController::OnControllerSet,
26 base::Unretained(this)));
27 }
28 MediaRouteController::~MediaRouteController() {}
29
30 void MediaRouteController::OnControllerSet(bool success) {
31 if (success) {
32 mojom::MediaStatusObserverPtr observer;
33 binding_ = base::MakeUnique<mojo::Binding<mojom::MediaStatusObserver>>(
34 this, mojo::MakeRequest<mojom::MediaStatusObserver>(&observer));
35 binding_->set_connection_error_handler(destroyer_callback_);
36 provider_->SetMediaRouteStatusObserver(route_id_, std::move(observer));
37 } else {
38 destroyer_callback_.Run();
39 // |this| gets destroyed here!
40 }
41 }
42
43 void MediaRouteController::Play() {
44 media_controller_->Play();
45 }
46
47 void MediaRouteController::Pause() {
48 media_controller_->Pause();
49 }
50
51 void MediaRouteController::Seek(uint32_t time) {
52 media_controller_->Seek(time);
53 }
54
55 void MediaRouteController::SetMute(bool mute) {
56 media_controller_->SetMute(mute);
57 }
58
59 void MediaRouteController::SetVolume(float volume) {
60 media_controller_->SetVolume(volume);
61 }
62
63 void MediaRouteController::AddObserver(MediaRouteStatusObserver* observer) {
64 observers_.insert(observer);
65 }
66
67 void MediaRouteController::RemoveObserver(MediaRouteStatusObserver* observer) {
68 observers_.erase(observer);
69 if (observers_.empty()) {
70 destroyer_callback_.Run();
71 // |this| gets destroyed here!
72 }
73 }
74
75 void MediaRouteController::OnMediaStatusUpdated(const MediaStatus& status) {
76 for (MediaRouteStatusObserver* observer : observers_)
77 observer->OnMediaRouteStatusUpdated(status);
78 }
79
80 } // namespace media_router
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698