| /* |
| * Copyright 2015 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef WEBRTC_API_ANDROIDVIDEOCAPTURER_H_ |
| #define WEBRTC_API_ANDROIDVIDEOCAPTURER_H_ |
| |
| #include <string> |
| #include <vector> |
| |
| #include "webrtc/base/thread_checker.h" |
| #include "webrtc/common_video/include/video_frame_buffer.h" |
| #include "webrtc/media/base/videocapturer.h" |
| |
| namespace webrtc { |
| |
| class AndroidVideoCapturer; |
| |
| class AndroidVideoCapturerDelegate : public rtc::RefCountInterface { |
| public: |
| virtual ~AndroidVideoCapturerDelegate() {} |
| // Start capturing. The implementation of the delegate must call |
| // AndroidVideoCapturer::OnCapturerStarted with the result of this request. |
| virtual void Start(int width, int height, int framerate, |
| AndroidVideoCapturer* capturer) = 0; |
| |
| // Stops capturing. |
| // The delegate may not call into AndroidVideoCapturer after this call. |
| virtual void Stop() = 0; |
| |
| virtual std::vector<cricket::VideoFormat> GetSupportedFormats() = 0; |
| }; |
| |
| // Android implementation of cricket::VideoCapturer for use with WebRtc |
| // PeerConnection. |
| class AndroidVideoCapturer : public cricket::VideoCapturer { |
| public: |
| explicit AndroidVideoCapturer( |
| const rtc::scoped_refptr<AndroidVideoCapturerDelegate>& delegate); |
| virtual ~AndroidVideoCapturer(); |
| |
| // Called from JNI when the capturer has been started. |
| void OnCapturerStarted(bool success); |
| |
| // Called from JNI when a new frame has been captured. |
| // Argument |buffer| is intentionally by value, for use with rtc::Bind. |
| void OnIncomingFrame( |
| const rtc::scoped_refptr<webrtc::VideoFrameBuffer>& buffer, |
| int rotation, |
| int64_t time_stamp); |
| |
| // Called from JNI to request a new video format. |
| void OnOutputFormatRequest(int width, int height, int fps); |
| |
| AndroidVideoCapturerDelegate* delegate() { return delegate_.get(); } |
| |
| // cricket::VideoCapturer implementation. |
| bool GetBestCaptureFormat(const cricket::VideoFormat& desired, |
| cricket::VideoFormat* best_format) override; |
| |
| private: |
| // cricket::VideoCapturer implementation. |
| // Video frames will be delivered using |
| // cricket::VideoCapturer::SignalFrameCaptured on the thread that calls Start. |
| cricket::CaptureState Start( |
| const cricket::VideoFormat& capture_format) override; |
| void Stop() override; |
| bool IsRunning() override; |
| bool IsScreencast() const override { return false; } |
| bool GetPreferredFourccs(std::vector<uint32_t>* fourccs) override; |
| |
| bool running_; |
| rtc::scoped_refptr<AndroidVideoCapturerDelegate> delegate_; |
| |
| rtc::ThreadChecker thread_checker_; |
| |
| class FrameFactory; |
| FrameFactory* frame_factory_; // Owned by cricket::VideoCapturer. |
| |
| cricket::CaptureState current_state_; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // WEBRTC_API_ANDROIDVIDEOCAPTURER_H_ |