OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 11 matching lines...) Expand all Loading... |
22 #include "webrtc/media/base/videosinkinterface.h" | 22 #include "webrtc/media/base/videosinkinterface.h" |
23 #include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimat
or.h" | 23 #include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimat
or.h" |
24 #include "webrtc/modules/video_coding/include/video_coding_defines.h" | 24 #include "webrtc/modules/video_coding/include/video_coding_defines.h" |
25 #include "webrtc/typedefs.h" | 25 #include "webrtc/typedefs.h" |
26 | 26 |
27 namespace webrtc { | 27 namespace webrtc { |
28 | 28 |
29 class CallStatsObserver; | 29 class CallStatsObserver; |
30 class ChannelStatsObserver; | 30 class ChannelStatsObserver; |
31 class EncodedImageCallback; | 31 class EncodedImageCallback; |
32 class I420FrameCallback; | |
33 class ReceiveStatisticsProxy; | 32 class ReceiveStatisticsProxy; |
34 class VideoRenderCallback; | 33 class VideoRenderCallback; |
35 | 34 |
36 namespace vcm { | 35 namespace vcm { |
37 class VideoReceiver; | 36 class VideoReceiver; |
38 } // namespace vcm | 37 } // namespace vcm |
39 | 38 |
40 enum StreamType { | 39 enum StreamType { |
41 kViEStreamTypeNormal = 0, // Normal media stream | 40 kViEStreamTypeNormal = 0, // Normal media stream |
42 kViEStreamTypeRtx = 1 // Retransmission media stream | 41 kViEStreamTypeRtx = 1 // Retransmission media stream |
43 }; | 42 }; |
44 | 43 |
45 class VideoStreamDecoder : public VCMReceiveCallback, | 44 class VideoStreamDecoder : public VCMReceiveCallback, |
46 public VCMReceiveStatisticsCallback, | 45 public VCMReceiveStatisticsCallback, |
47 public VCMDecoderTimingCallback, | 46 public VCMDecoderTimingCallback, |
48 public CallStatsObserver { | 47 public CallStatsObserver { |
49 public: | 48 public: |
50 friend class ChannelStatsObserver; | 49 friend class ChannelStatsObserver; |
51 | 50 |
52 VideoStreamDecoder(vcm::VideoReceiver* video_receiver, | 51 VideoStreamDecoder( |
53 VCMFrameTypeCallback* vcm_frame_type_callback, | 52 vcm::VideoReceiver* video_receiver, |
54 VCMPacketRequestCallback* vcm_packet_request_callback, | 53 VCMFrameTypeCallback* vcm_frame_type_callback, |
55 bool enable_nack, | 54 VCMPacketRequestCallback* vcm_packet_request_callback, |
56 bool enable_fec, | 55 bool enable_nack, |
57 ReceiveStatisticsProxy* receive_statistics_proxy, | 56 bool enable_fec, |
58 rtc::VideoSinkInterface<VideoFrame>* incoming_video_stream, | 57 ReceiveStatisticsProxy* receive_statistics_proxy, |
59 I420FrameCallback* pre_render_callback); | 58 rtc::VideoSinkInterface<VideoFrame>* incoming_video_stream); |
60 ~VideoStreamDecoder(); | 59 ~VideoStreamDecoder(); |
61 | 60 |
62 // Implements VCMReceiveCallback. | 61 // Implements VCMReceiveCallback. |
63 int32_t FrameToRender(VideoFrame& video_frame, | 62 int32_t FrameToRender(VideoFrame& video_frame, |
64 rtc::Optional<uint8_t> qp) override; | 63 rtc::Optional<uint8_t> qp) override; |
65 int32_t ReceivedDecodedReferenceFrame(const uint64_t picture_id) override; | 64 int32_t ReceivedDecodedReferenceFrame(const uint64_t picture_id) override; |
66 void OnIncomingPayloadType(int payload_type) override; | 65 void OnIncomingPayloadType(int payload_type) override; |
67 void OnDecoderImplementationName(const char* implementation_name) override; | 66 void OnDecoderImplementationName(const char* implementation_name) override; |
68 | 67 |
69 // Implements VCMReceiveStatisticsCallback. | 68 // Implements VCMReceiveStatisticsCallback. |
(...skipping 26 matching lines...) Expand all Loading... |
96 | 95 |
97 private: | 96 private: |
98 // Used for all registered callbacks except rendering. | 97 // Used for all registered callbacks except rendering. |
99 rtc::CriticalSection crit_; | 98 rtc::CriticalSection crit_; |
100 | 99 |
101 vcm::VideoReceiver* const video_receiver_; | 100 vcm::VideoReceiver* const video_receiver_; |
102 | 101 |
103 ReceiveStatisticsProxy* const receive_stats_callback_; | 102 ReceiveStatisticsProxy* const receive_stats_callback_; |
104 rtc::VideoSinkInterface<VideoFrame>* const incoming_video_stream_; | 103 rtc::VideoSinkInterface<VideoFrame>* const incoming_video_stream_; |
105 | 104 |
106 // TODO(tommi): This callback is basically the same thing as the one above. | |
107 // We shouldn't need to support both. | |
108 I420FrameCallback* const pre_render_callback_; | |
109 | |
110 int64_t last_rtt_ms_ GUARDED_BY(crit_); | 105 int64_t last_rtt_ms_ GUARDED_BY(crit_); |
111 }; | 106 }; |
112 | 107 |
113 } // namespace webrtc | 108 } // namespace webrtc |
114 | 109 |
115 #endif // WEBRTC_VIDEO_VIDEO_STREAM_DECODER_H_ | 110 #endif // WEBRTC_VIDEO_VIDEO_STREAM_DECODER_H_ |
OLD | NEW |