OLD | NEW |
1 /* | 1 /* |
2 * libjingle | 2 * libjingle |
3 * Copyright 2012 Google Inc. | 3 * Copyright 2012 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, |
(...skipping 20 matching lines...) Expand all Loading... |
31 #include <list> | 31 #include <list> |
32 | 32 |
33 #include "talk/app/webrtc/mediastreaminterface.h" | 33 #include "talk/app/webrtc/mediastreaminterface.h" |
34 #include "talk/app/webrtc/notifier.h" | 34 #include "talk/app/webrtc/notifier.h" |
35 #include "talk/app/webrtc/videosourceinterface.h" | 35 #include "talk/app/webrtc/videosourceinterface.h" |
36 #include "talk/app/webrtc/videotrackrenderers.h" | 36 #include "talk/app/webrtc/videotrackrenderers.h" |
37 #include "talk/media/base/videocapturer.h" | 37 #include "talk/media/base/videocapturer.h" |
38 #include "talk/media/base/videocommon.h" | 38 #include "talk/media/base/videocommon.h" |
39 #include "webrtc/base/scoped_ptr.h" | 39 #include "webrtc/base/scoped_ptr.h" |
40 #include "webrtc/base/sigslot.h" | 40 #include "webrtc/base/sigslot.h" |
| 41 #include "webrtc/media/base/videosinkinterface.h" |
41 | 42 |
42 // VideoSource implements VideoSourceInterface. It owns a | 43 // VideoSource implements VideoSourceInterface. It owns a |
43 // cricket::VideoCapturer and make sure the camera is started at a resolution | 44 // cricket::VideoCapturer and make sure the camera is started at a resolution |
44 // that honors the constraints. | 45 // that honors the constraints. |
45 // The state is set depending on the result of starting the capturer. | 46 // The state is set depending on the result of starting the capturer. |
46 // If the constraint can't be met or the capturer fails to start, the state | 47 // If the constraint can't be met or the capturer fails to start, the state |
47 // transition to kEnded, otherwise it transitions to kLive. | 48 // transition to kEnded, otherwise it transitions to kLive. |
48 | 49 |
49 namespace cricket { | 50 namespace cricket { |
50 | 51 |
(...skipping 26 matching lines...) Expand all Loading... |
77 | 78 |
78 virtual cricket::VideoCapturer* GetVideoCapturer() { | 79 virtual cricket::VideoCapturer* GetVideoCapturer() { |
79 return video_capturer_.get(); | 80 return video_capturer_.get(); |
80 } | 81 } |
81 | 82 |
82 void Stop() override; | 83 void Stop() override; |
83 void Restart() override; | 84 void Restart() override; |
84 | 85 |
85 // |output| will be served video frames as long as the underlying capturer | 86 // |output| will be served video frames as long as the underlying capturer |
86 // is running video frames. | 87 // is running video frames. |
87 virtual void AddSink(cricket::VideoRenderer* output); | 88 virtual void AddSink(rtc::VideoSinkInterface<cricket::VideoFrame>* output); |
88 virtual void RemoveSink(cricket::VideoRenderer* output); | 89 virtual void RemoveSink(rtc::VideoSinkInterface<cricket::VideoFrame>* output); |
89 | 90 |
90 protected: | 91 protected: |
91 VideoSource(cricket::ChannelManager* channel_manager, | 92 VideoSource(cricket::ChannelManager* channel_manager, |
92 cricket::VideoCapturer* capturer, | 93 cricket::VideoCapturer* capturer, |
93 bool remote); | 94 bool remote); |
94 virtual ~VideoSource(); | 95 virtual ~VideoSource(); |
95 void Initialize(const webrtc::MediaConstraintsInterface* constraints); | 96 void Initialize(const webrtc::MediaConstraintsInterface* constraints); |
96 | 97 |
97 private: | 98 private: |
98 void OnStateChange(cricket::VideoCapturer* capturer, | 99 void OnStateChange(cricket::VideoCapturer* capturer, |
99 cricket::CaptureState capture_state); | 100 cricket::CaptureState capture_state); |
100 void SetState(SourceState new_state); | 101 void SetState(SourceState new_state); |
101 | 102 |
102 cricket::ChannelManager* channel_manager_; | 103 cricket::ChannelManager* channel_manager_; |
103 rtc::scoped_ptr<cricket::VideoCapturer> video_capturer_; | 104 rtc::scoped_ptr<cricket::VideoCapturer> video_capturer_; |
104 rtc::scoped_ptr<cricket::VideoRenderer> frame_input_; | 105 rtc::scoped_ptr<cricket::VideoRenderer> frame_input_; |
105 | 106 |
106 std::list<cricket::VideoRenderer*> sinks_; | 107 std::list<rtc::VideoSinkInterface<cricket::VideoFrame>*> sinks_; |
107 | 108 |
108 cricket::VideoFormat format_; | 109 cricket::VideoFormat format_; |
109 cricket::VideoOptions options_; | 110 cricket::VideoOptions options_; |
110 SourceState state_; | 111 SourceState state_; |
111 const bool remote_; | 112 const bool remote_; |
112 }; | 113 }; |
113 | 114 |
114 } // namespace webrtc | 115 } // namespace webrtc |
115 | 116 |
116 #endif // TALK_APP_WEBRTC_VIDEOSOURCE_H_ | 117 #endif // TALK_APP_WEBRTC_VIDEOSOURCE_H_ |
OLD | NEW |