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

Side by Side Diff: remoting/protocol/webrtc_dummy_video_encoder.h

Issue 2329653002: Add WebrtcVideoEncoder interface (Closed)
Patch Set: Created 4 years, 3 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 REMOTING_PROTOCOL_WEBRTC_VIDEO_ENCODER_FACTORY_H_ 5 #ifndef REMOTING_PROTOCOL_DUMMY_WEBRTC_VIDEO_ENCODER_H_
6 #define REMOTING_PROTOCOL_WEBRTC_VIDEO_ENCODER_FACTORY_H_ 6 #define REMOTING_PROTOCOL_DUMMY_WEBRTC_VIDEO_ENCODER_H_
7 7
8 #include <memory> 8 #include <memory>
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/callback.h" 11 #include "base/callback.h"
12 #include "base/synchronization/lock.h" 12 #include "base/synchronization/lock.h"
13 #include "remoting/proto/video.pb.h" 13 #include "remoting/codec/webrtc_video_encoder.h"
14 #include "third_party/webrtc/media/engine/webrtcvideoencoderfactory.h" 14 #include "third_party/webrtc/media/engine/webrtcvideoencoderfactory.h"
15 #include "third_party/webrtc/modules/video_coding/include/video_codec_interface. h" 15 #include "third_party/webrtc/modules/video_coding/include/video_codec_interface. h"
16 16
17 namespace remoting { 17 namespace remoting {
18 namespace protocol {
18 19
19 using TargetBitrateCallback = base::Callback<void(int)>; 20 using TargetBitrateCallback = base::Callback<void(int)>;
20 21
21 // This is the interface between the Webrtc engine and the external encoder 22 // This is the interface between the Webrtc engine and the external encoder
22 // provided by remoting. Webrtc provides feedback on network bandwidth, latency 23 // provided by remoting. Webrtc provides feedback on network bandwidth, latency
23 // & RTT and in turn remoting passes encoded frames as they get encoded 24 // & RTT and in turn remoting passes encoded frames as they get encoded
24 // through the capture pipeline. 25 // through the capture pipeline.
Irfan 2016/09/12 21:34:24 Perhaps add comment on why these classes are "dumm
Sergey Ulanov 2016/09/12 22:50:02 Done.
25 class WebrtcVideoEncoder : public webrtc::VideoEncoder { 26 class WebrtcDummyVideoEncoder : public webrtc::VideoEncoder {
26 public: 27 public:
27 enum State { kUninitialized = 0, kInitialized }; 28 enum State { kUninitialized = 0, kInitialized };
28 explicit WebrtcVideoEncoder(webrtc::VideoCodecType codec); 29 explicit WebrtcDummyVideoEncoder(webrtc::VideoCodecType codec);
29 ~WebrtcVideoEncoder() override; 30 ~WebrtcDummyVideoEncoder() override;
30 31
31 // webrtc::VideoEncoder overrides 32 // webrtc::VideoEncoder overrides
32 int32_t InitEncode(const webrtc::VideoCodec* codec_settings, 33 int32_t InitEncode(const webrtc::VideoCodec* codec_settings,
33 int32_t number_of_cores, 34 int32_t number_of_cores,
34 size_t max_payload_size) override; 35 size_t max_payload_size) override;
35 int32_t RegisterEncodeCompleteCallback( 36 int32_t RegisterEncodeCompleteCallback(
36 webrtc::EncodedImageCallback* callback) override; 37 webrtc::EncodedImageCallback* callback) override;
37 int32_t Release() override; 38 int32_t Release() override;
38 int32_t Encode(const webrtc::VideoFrame& frame, 39 int32_t Encode(const webrtc::VideoFrame& frame,
39 const webrtc::CodecSpecificInfo* codec_specific_info, 40 const webrtc::CodecSpecificInfo* codec_specific_info,
40 const std::vector<webrtc::FrameType>* frame_types) override; 41 const std::vector<webrtc::FrameType>* frame_types) override;
41 int32_t SetChannelParameters(uint32_t packet_loss, int64_t rtt) override; 42 int32_t SetChannelParameters(uint32_t packet_loss, int64_t rtt) override;
42 int32_t SetRates(uint32_t bitrate, uint32_t framerate) override; 43 int32_t SetRates(uint32_t bitrate, uint32_t framerate) override;
43 44
44 webrtc::EncodedImageCallback::Result SendEncodedFrame( 45 webrtc::EncodedImageCallback::Result SendEncodedFrame(
45 std::unique_ptr<VideoPacket> packet, 46 std::unique_ptr<WebrtcVideoEncoder::EncodedFrame> frame,
46 base::TimeTicks capture_time); 47 base::TimeTicks capture_time);
47 void SetKeyFrameRequestCallback(const base::Closure& key_frame_request); 48 void SetKeyFrameRequestCallback(const base::Closure& key_frame_request);
48 void SetTargetBitrateCallback(const TargetBitrateCallback& target_bitrate_cb); 49 void SetTargetBitrateCallback(const TargetBitrateCallback& target_bitrate_cb);
49 50
50 private: 51 private:
51 // Protects |encoded_callback_|, |key_frame_request_|, 52 // Protects |encoded_callback_|, |key_frame_request_|,
52 // |target_bitrate_cb_| and |state_|. 53 // |target_bitrate_cb_| and |state_|.
53 base::Lock lock_; 54 base::Lock lock_;
54 State state_; 55 State state_;
55 webrtc::EncodedImageCallback* encoded_callback_; 56 webrtc::EncodedImageCallback* encoded_callback_;
56 57
57 base::Closure key_frame_request_; 58 base::Closure key_frame_request_;
58 TargetBitrateCallback target_bitrate_cb_; 59 TargetBitrateCallback target_bitrate_cb_;
59 webrtc::VideoCodecType video_codec_type_; 60 webrtc::VideoCodecType video_codec_type_;
60 }; 61 };
61 62
62 // This is the external encoder factory implementation that is passed to 63 // This is the external encoder factory implementation that is passed to
63 // WebRTC at the time of creation of peer connection. The external encoder 64 // WebRTC at the time of creation of peer connection. The external encoder
64 // factory primarily manages creation and destruction of encoder. 65 // factory primarily manages creation and destruction of encoder.
65 class WebrtcVideoEncoderFactory : public cricket::WebRtcVideoEncoderFactory { 66 class WebrtcDummyVideoEncoderFactory
67 : public cricket::WebRtcVideoEncoderFactory {
66 public: 68 public:
67 WebrtcVideoEncoderFactory(); 69 WebrtcDummyVideoEncoderFactory();
68 ~WebrtcVideoEncoderFactory() override; 70 ~WebrtcDummyVideoEncoderFactory() override;
69 71
70 webrtc::VideoEncoder* CreateVideoEncoder( 72 webrtc::VideoEncoder* CreateVideoEncoder(
71 webrtc::VideoCodecType type) override; 73 webrtc::VideoCodecType type) override;
72 const std::vector<cricket::WebRtcVideoEncoderFactory::VideoCodec>& codecs() 74 const std::vector<cricket::WebRtcVideoEncoderFactory::VideoCodec>& codecs()
73 const override; 75 const override;
74 76
75 // Returns true to directly provide encoded frames to webrtc 77 // Returns true to directly provide encoded frames to webrtc
76 bool EncoderTypeHasInternalSource(webrtc::VideoCodecType type) const override; 78 bool EncoderTypeHasInternalSource(webrtc::VideoCodecType type) const override;
77 void DestroyVideoEncoder(webrtc::VideoEncoder* encoder) override; 79 void DestroyVideoEncoder(webrtc::VideoEncoder* encoder) override;
78 80
79 webrtc::EncodedImageCallback::Result SendEncodedFrame( 81 webrtc::EncodedImageCallback::Result SendEncodedFrame(
80 std::unique_ptr<VideoPacket> packet, 82 std::unique_ptr<WebrtcVideoEncoder::EncodedFrame> packet,
81 base::TimeTicks capture_time); 83 base::TimeTicks capture_time);
82 84
83 void SetKeyFrameRequestCallback(const base::Closure& key_frame_request); 85 void SetKeyFrameRequestCallback(const base::Closure& key_frame_request);
84 void SetTargetBitrateCallback(const TargetBitrateCallback& target_bitrate_cb); 86 void SetTargetBitrateCallback(const TargetBitrateCallback& target_bitrate_cb);
85 87
86 private: 88 private:
87 // Protects |key_frame_request_| and |target_bitrate_cb_|. 89 // Protects |key_frame_request_| and |target_bitrate_cb_|.
88 base::Lock lock_; 90 base::Lock lock_;
89 base::Closure key_frame_request_; 91 base::Closure key_frame_request_;
90 TargetBitrateCallback target_bitrate_cb_; 92 TargetBitrateCallback target_bitrate_cb_;
91 std::vector<cricket::WebRtcVideoEncoderFactory::VideoCodec> codecs_; 93 std::vector<cricket::WebRtcVideoEncoderFactory::VideoCodec> codecs_;
92 std::vector<std::unique_ptr<WebrtcVideoEncoder>> encoders_; 94 std::vector<std::unique_ptr<WebrtcDummyVideoEncoder>> encoders_;
93 }; 95 };
94 96
97 } // namespace protocol
95 } // namespace remoting 98 } // namespace remoting
96 99
97 #endif // REMOTING_PROTOCOL_WEBRTC_VIDEO_ENCODER_FACTORY_H_ 100 #endif // REMOTING_PROTOCOL_DUMMY_WEBRTC_VIDEO_ENCODER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698