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 #ifndef CONTENT_RENDERER_MEDIA_REMOTE_MEDIA_STREAM_IMPL_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_REMOTE_MEDIA_STREAM_IMPL_H_ |
6 #define CONTENT_RENDERER_MEDIA_REMOTE_MEDIA_STREAM_IMPL_H_ | 6 #define CONTENT_RENDERER_MEDIA_REMOTE_MEDIA_STREAM_IMPL_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
11 #include "base/memory/scoped_vector.h" | 11 #include "base/memory/scoped_ptr.h" |
12 #include "base/threading/non_thread_safe.h" | 12 #include "base/single_thread_task_runner.h" |
13 #include "content/common/content_export.h" | 13 #include "content/common/content_export.h" |
14 #include "third_party/libjingle/source/talk/app/webrtc/mediastreaminterface.h" | 14 #include "third_party/libjingle/source/talk/app/webrtc/mediastreaminterface.h" |
15 #include "third_party/WebKit/public/platform/WebMediaStream.h" | 15 #include "third_party/WebKit/public/platform/WebMediaStream.h" |
16 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" | 16 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" |
17 #include "third_party/WebKit/public/platform/WebMediaStreamTrack.h" | 17 #include "third_party/WebKit/public/platform/WebMediaStreamTrack.h" |
18 | 18 |
19 namespace content { | 19 namespace content { |
20 | 20 |
21 class RemoteMediaStreamTrackAdapter; | 21 class RemoteAudioTrackAdapter; |
22 class RemoteVideoTrackAdapter; | |
22 | 23 |
23 // RemoteMediaStreamImpl serves as a container and glue between remote webrtc | 24 // RemoteMediaStreamImpl serves as a container and glue between remote webrtc |
24 // MediaStreams and WebKit MediaStreams. For each remote MediaStream received | 25 // MediaStreams and WebKit MediaStreams. For each remote MediaStream received |
25 // on a PeerConnection a RemoteMediaStreamImpl instance is created and | 26 // on a PeerConnection a RemoteMediaStreamImpl instance is created and |
26 // owned by RtcPeerConnection. | 27 // owned by RtcPeerConnection. |
27 class CONTENT_EXPORT RemoteMediaStreamImpl | 28 class CONTENT_EXPORT RemoteMediaStreamImpl |
28 : NON_EXPORTED_BASE(public webrtc::ObserverInterface), | 29 : NON_EXPORTED_BASE(public webrtc::ObserverInterface) { |
29 NON_EXPORTED_BASE(public base::NonThreadSafe) { | |
30 public: | 30 public: |
31 explicit RemoteMediaStreamImpl( | 31 RemoteMediaStreamImpl( |
32 const scoped_refptr<base::SingleThreadTaskRunner>& main_thread, | |
32 webrtc::MediaStreamInterface* webrtc_stream); | 33 webrtc::MediaStreamInterface* webrtc_stream); |
33 ~RemoteMediaStreamImpl() override; | 34 ~RemoteMediaStreamImpl() override; |
34 | 35 |
35 const blink::WebMediaStream& webkit_stream() { return webkit_stream_; } | 36 const blink::WebMediaStream& webkit_stream() { return webkit_stream_; } |
37 const scoped_refptr<webrtc::MediaStreamInterface>& webrtc_stream() { | |
38 return webrtc_stream_; | |
39 } | |
36 | 40 |
37 private: | 41 private: |
42 typedef std::vector<scoped_refptr<RemoteAudioTrackAdapter>> | |
43 RemoteAudioTrackAdapters; | |
44 typedef std::vector<scoped_refptr<RemoteVideoTrackAdapter>> | |
45 RemoteVideoTrackAdapters; | |
46 | |
47 void InitializeOnWebKitThread(const std::string& label); | |
perkj_chrome
2014/10/30 12:42:35
I am a bit confused by the naming here.
I thought
tommi (sloooow) - chröme
2014/10/30 20:37:36
Changed to InitializeOnMainThread()
| |
48 | |
38 // webrtc::ObserverInterface implementation. | 49 // webrtc::ObserverInterface implementation. |
39 void OnChanged() override; | 50 void OnChanged() override; |
40 | 51 |
41 scoped_refptr<webrtc::MediaStreamInterface> webrtc_stream_; | 52 void OnChangedOnMainThread( |
42 ScopedVector<RemoteMediaStreamTrackAdapter> video_track_observers_; | 53 scoped_ptr<RemoteAudioTrackAdapters> audio_tracks, |
43 ScopedVector<RemoteMediaStreamTrackAdapter> audio_track_observers_; | 54 scoped_ptr<RemoteVideoTrackAdapters> video_tracks); |
55 | |
56 const scoped_refptr<base::SingleThreadTaskRunner> main_thread_; | |
57 const scoped_refptr<base::SingleThreadTaskRunner> signaling_thread_; | |
58 const scoped_refptr<webrtc::MediaStreamInterface> webrtc_stream_; | |
59 | |
60 RemoteVideoTrackAdapters video_track_observers_; | |
61 RemoteAudioTrackAdapters audio_track_observers_; | |
44 blink::WebMediaStream webkit_stream_; | 62 blink::WebMediaStream webkit_stream_; |
45 | 63 |
46 DISALLOW_COPY_AND_ASSIGN(RemoteMediaStreamImpl); | 64 DISALLOW_COPY_AND_ASSIGN(RemoteMediaStreamImpl); |
47 }; | 65 }; |
48 | 66 |
49 } // namespace content | 67 } // namespace content |
50 | 68 |
51 #endif // CONTENT_RENDERER_MEDIA_REMOTE_MEDIA_STREAM_IMPL_H_ | 69 #endif // CONTENT_RENDERER_MEDIA_REMOTE_MEDIA_STREAM_IMPL_H_ |
OLD | NEW |