Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * libjingle | 2 * libjingle |
| 3 * Copyright 2004 Google Inc. | 3 * Copyright 2016 Google Inc. |
| 4 * | 4 * |
| 5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
| 6 * modification, are permitted provided that the following conditions are met: | 6 * modification, are permitted provided that the following conditions are met: |
| 7 * | 7 * |
| 8 * 1. Redistributions of source code must retain the above copyright notice, | 8 * 1. Redistributions of source code must retain the above copyright notice, |
| 9 * this list of conditions and the following disclaimer. | 9 * this list of conditions and the following disclaimer. |
| 10 * 2. Redistributions in binary form must reproduce the above copyright notice, | 10 * 2. Redistributions in binary form must reproduce the above copyright notice, |
| 11 * this list of conditions and the following disclaimer in the documentation | 11 * this list of conditions and the following disclaimer in the documentation |
| 12 * and/or other materials provided with the distribution. | 12 * and/or other materials provided with the distribution. |
| 13 * 3. The name of the author may not be used to endorse or promote products | 13 * 3. The name of the author may not be used to endorse or promote products |
| 14 * derived from this software without specific prior written permission. | 14 * derived from this software without specific prior written permission. |
| 15 * | 15 * |
| 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED | 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED |
| 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
| 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO | 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |
| 19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| 21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; | 21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; |
| 22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | 22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
| 23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR | 23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR |
| 24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF | 24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF |
| 25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 26 */ | 26 */ |
| 27 | 27 |
| 28 #ifndef TALK_MEDIA_BASE_VIDEORENDERER_H_ | 28 #ifndef TALK_MEDIA_BASE_VIDEOSOURCEBASE_H_ |
| 29 #define TALK_MEDIA_BASE_VIDEORENDERER_H_ | 29 #define TALK_MEDIA_BASE_VIDEOSOURCEBASE_H_ |
| 30 | 30 |
| 31 #include <unordered_set> | |
| 32 | |
| 33 #include "talk/media/base/videoframe.h" | |
| 31 #include "webrtc/media/base/videosinkinterface.h" | 34 #include "webrtc/media/base/videosinkinterface.h" |
| 35 #include "webrtc/media/base/videosourceinterface.h" | |
| 32 | 36 |
| 33 namespace cricket { | 37 namespace rtc { |
| 34 | 38 |
| 35 class VideoFrame; | 39 class VideoSourceBase : public VideoSourceInterface<cricket::VideoFrame> { |
|
pthatcher1
2016/02/03 15:38:36
Can we call this thing something more explicit, li
perkj_webrtc
2016/02/08 14:32:01
Done.
| |
| 40 public: | |
| 41 void AddSink(VideoSinkInterface<cricket::VideoFrame>* sink, | |
| 42 const VideoSinkCapabilities& capabilities) override; | |
|
pthatcher1
2016/02/03 15:38:36
Why does AddSink take the capabilities instead of
perkj_webrtc
2016/02/08 14:32:01
Acknowledged.
| |
| 43 void RemoveSink(VideoSinkInterface<cricket::VideoFrame>* sink) override; | |
| 36 | 44 |
| 37 // Abstract interface for rendering VideoFrames. | 45 // TODO(perkj): Make DeliverFrameToSinks protected when the hack in |
| 38 class VideoRenderer : public rtc::VideoSinkInterface<VideoFrame> { | 46 // FrameInputWrapper->DeliverFrameToSinks (videosource.cc) has been removed. |
| 39 public: | 47 void DeliverFrameToSinks(const cricket::VideoFrame& frame); |
|
nisse-webrtc
2016/02/03 09:16:34
Is there any obvious drawback to rename this OnFra
pthatcher1
2016/02/03 15:38:36
Yes, I was thinking the same thing. I think that
perkj_webrtc
2016/02/08 14:32:01
Done.
| |
| 40 virtual ~VideoRenderer() {} | 48 |
| 41 // Called when a new frame is available for display. | 49 protected: |
| 42 virtual bool RenderFrame(const VideoFrame *frame) = 0; | 50 bool HasSinks() const { return !sinks_.empty(); } |
| 43 // Intended to replace RenderFrame. | 51 |
| 44 void OnFrame(const cricket::VideoFrame& frame) override { | 52 virtual void OnSinkCapabilitiesChanged( |
| 45 // Unused return value | 53 const VideoSinkCapabilities& capabilities) = 0; |
| 46 RenderFrame(&frame); | 54 |
| 47 } | 55 private: |
| 56 CriticalSection sink_lock_; | |
|
nisse-webrtc
2016/02/03 09:16:34
I guess this makes sense, if used as a base class.
pthatcher1
2016/02/03 15:38:36
As mentioned earlier, I'd like to see us try makin
perkj_webrtc
2016/02/08 14:32:01
Done.
| |
| 57 VideoSinkCapabilities capabilities_; | |
| 58 std::unordered_set<VideoSinkInterface<cricket::VideoFrame>*> sinks_; | |
|
nisse-webrtc
2016/02/03 09:16:34
I think Tommi objected to using std::set earlier,
pthatcher1
2016/02/03 15:38:36
Throughout our code base, we almost alway use std:
perkj_webrtc
2016/02/08 14:32:01
Done.
| |
| 48 }; | 59 }; |
| 49 | 60 |
| 50 } // namespace cricket | 61 } // namespace rtc |
| 51 | 62 |
| 52 #endif // TALK_MEDIA_BASE_VIDEORENDERER_H_ | 63 #endif // TALK_MEDIA_BASE_VIDEOSOURCEBASE_H_ |
| OLD | NEW |