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

Side by Side Diff: chrome/browser/media/android/router/media_router_android.h

Issue 1291203003: [Presentation API, Android] Implement routes observers (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@close-route
Patch Set: Created 5 years, 4 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
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ 5 #ifndef CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_
6 #define CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ 6 #define CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_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"
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
45 const std::string& message, 45 const std::string& message,
46 const SendRouteMessageCallback& callback) override; 46 const SendRouteMessageCallback& callback) override;
47 void SendRouteBinaryMessage( 47 void SendRouteBinaryMessage(
48 const MediaRoute::Id& route_id, 48 const MediaRoute::Id& route_id,
49 scoped_ptr<std::vector<uint8>> data, 49 scoped_ptr<std::vector<uint8>> data,
50 const SendRouteMessageCallback& callback) override; 50 const SendRouteMessageCallback& callback) override;
51 void ClearIssue(const Issue::Id& issue_id) override; 51 void ClearIssue(const Issue::Id& issue_id) override;
52 52
53 // JNI functions. 53 // JNI functions.
54 void OnSinksReceived( 54 void OnSinksReceived(
55 JNIEnv* env, jobject obj, jstring source_urn, jint count); 55 JNIEnv* env, jobject obj, jstring jsource_urn, jint jcount);
56 void OnRouteCreated( 56 void OnRouteCreated(
57 JNIEnv* env, 57 JNIEnv* env,
58 jobject obj, 58 jobject obj,
59 jstring media_route_id, 59 jstring jmedia_route_id,
60 jint jcreate_route_request_id, 60 jint jcreate_route_request_id,
61 jboolean jis_local); 61 jboolean jis_local);
62 void OnRouteCreationError( 62 void OnRouteCreationError(
63 JNIEnv* env, 63 JNIEnv* env,
64 jobject obj, 64 jobject obj,
65 jstring error_text, 65 jstring jerror_text,
66 jint jcreate_route_request_id); 66 jint jcreate_route_request_id);
67 void OnRouteClosed(JNIEnv* env, jobject obj, jstring jmedia_route_id);
67 68
68 private: 69 private:
69 friend class MediaRouterFactory; 70 friend class MediaRouterFactory;
70 71
71 explicit MediaRouterAndroid(content::BrowserContext*); 72 explicit MediaRouterAndroid(content::BrowserContext*);
72 73
74 void UpdateRoutesObservers();
75
73 // MediaRouter implementation. 76 // MediaRouter implementation.
74 void RegisterMediaSinksObserver(MediaSinksObserver* observer) override; 77 void RegisterMediaSinksObserver(MediaSinksObserver* observer) override;
75 void UnregisterMediaSinksObserver(MediaSinksObserver* observer) override; 78 void UnregisterMediaSinksObserver(MediaSinksObserver* observer) override;
76 void RegisterMediaRoutesObserver(MediaRoutesObserver* observer) override; 79 void RegisterMediaRoutesObserver(MediaRoutesObserver* observer) override;
77 void UnregisterMediaRoutesObserver(MediaRoutesObserver* observer) override; 80 void UnregisterMediaRoutesObserver(MediaRoutesObserver* observer) override;
78 void RegisterIssuesObserver(IssuesObserver* observer) override; 81 void RegisterIssuesObserver(IssuesObserver* observer) override;
79 void UnregisterIssuesObserver(IssuesObserver* observer) override; 82 void UnregisterIssuesObserver(IssuesObserver* observer) override;
80 void RegisterPresentationSessionMessagesObserver( 83 void RegisterPresentationSessionMessagesObserver(
81 PresentationSessionMessagesObserver* observer) override; 84 PresentationSessionMessagesObserver* observer) override;
82 void UnregisterPresentationSessionMessagesObserver( 85 void UnregisterPresentationSessionMessagesObserver(
83 PresentationSessionMessagesObserver* observer) override; 86 PresentationSessionMessagesObserver* observer) override;
84 87
85 base::android::ScopedJavaGlobalRef<jobject> java_media_router_; 88 base::android::ScopedJavaGlobalRef<jobject> java_media_router_;
86 89
87 using MediaSinkObservers = base::ScopedPtrHashMap< 90 using MediaSinkObservers = base::ScopedPtrHashMap<
88 MediaSource::Id, 91 MediaSource::Id,
89 scoped_ptr<base::ObserverList<MediaSinksObserver>>>; 92 scoped_ptr<base::ObserverList<MediaSinksObserver>>>;
90 MediaSinkObservers sinks_observers_; 93 MediaSinkObservers sinks_observers_;
91 94
95 base::ObserverList<MediaRoutesObserver> routes_observers_;
96
92 struct CreateMediaRouteRequest { 97 struct CreateMediaRouteRequest {
93 CreateMediaRouteRequest( 98 CreateMediaRouteRequest(
94 const MediaSource& source, 99 const MediaSource& source,
95 const MediaSink& sink, 100 const MediaSink& sink,
96 const std::string& presentation_id, 101 const std::string& presentation_id,
97 const std::vector<MediaRouteResponseCallback>& callbacks); 102 const std::vector<MediaRouteResponseCallback>& callbacks);
98 ~CreateMediaRouteRequest(); 103 ~CreateMediaRouteRequest();
99 104
100 MediaSource media_source; 105 MediaSource media_source;
101 MediaSink media_sink; 106 MediaSink media_sink;
102 std::string presentation_id; 107 std::string presentation_id;
103 std::vector<MediaRouteResponseCallback> callbacks; 108 std::vector<MediaRouteResponseCallback> callbacks;
104 }; 109 };
105 110
106 using CreateMediaRouteRequests = 111 using CreateMediaRouteRequests =
107 IDMap<CreateMediaRouteRequest, IDMapOwnPointer>; 112 IDMap<CreateMediaRouteRequest, IDMapOwnPointer>;
108 CreateMediaRouteRequests create_route_requests_; 113 CreateMediaRouteRequests create_route_requests_;
109 114
115 using MediaRoutes = base::ScopedPtrHashMap<
116 MediaRoute::Id, scoped_ptr<MediaRoute>>;
117 MediaRoutes active_routes_;
mlamouri (slow - plz ping) 2015/08/18 22:39:37 FWIW, I'm not sure if it is really helping to have
whywhat 2015/08/19 00:26:43 Agreed. I don't think a map is needed in the futur
118
110 DISALLOW_COPY_AND_ASSIGN(MediaRouterAndroid); 119 DISALLOW_COPY_AND_ASSIGN(MediaRouterAndroid);
111 }; 120 };
112 121
113 } // namespace media_router 122 } // namespace media_router
114 123
115 #endif // CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ 124 #endif // CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698