Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2014 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 class RTPFragmentationHeader; | 22 class RTPFragmentationHeader; |
| 23 // TODO(pbos): Expose these through a public (root) header or change these APIs. | 23 // TODO(pbos): Expose these through a public (root) header or change these APIs. |
| 24 struct CodecSpecificInfo; | 24 struct CodecSpecificInfo; |
| 25 struct VideoCodec; | 25 struct VideoCodec; |
| 26 | 26 |
| 27 class DecodedImageCallback { | 27 class DecodedImageCallback { |
| 28 public: | 28 public: |
| 29 virtual ~DecodedImageCallback() {} | 29 virtual ~DecodedImageCallback() {} |
| 30 | 30 |
| 31 virtual int32_t Decoded(VideoFrame& decodedImage) = 0; | 31 virtual int32_t Decoded(VideoFrame& decodedImage) = 0; |
| 32 // Provides an alternative interface that allows the decoder to specify the | |
| 33 // decode time excluding waiting time for any previous pending frame to | |
| 34 // return. This is necessary for breaking positive feedback in the delay | |
| 35 // estimation when the decoder has a single output buffer. | |
| 36 virtual int32_t Decoded(VideoFrame& decodedImage, int64_t decode_time_ms) { | |
| 37 // The default implementation ignores custom decode time value. | |
| 38 return Decoded(decodedImage); | |
| 39 } | |
|
stefan-webrtc
2015/11/10 10:32:00
Are there many places where you have to make this
| |
| 40 | |
| 32 virtual int32_t ReceivedDecodedReferenceFrame(const uint64_t pictureId) { | 41 virtual int32_t ReceivedDecodedReferenceFrame(const uint64_t pictureId) { |
| 33 return -1; | 42 return -1; |
| 34 } | 43 } |
| 35 | 44 |
| 36 virtual int32_t ReceivedDecodedFrame(const uint64_t pictureId) { return -1; } | 45 virtual int32_t ReceivedDecodedFrame(const uint64_t pictureId) { return -1; } |
| 37 }; | 46 }; |
| 38 | 47 |
| 39 class VideoDecoder { | 48 class VideoDecoder { |
| 40 public: | 49 public: |
| 41 enum DecoderType { | 50 enum DecoderType { |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 96 | 105 |
| 97 VideoCodec codec_settings_; | 106 VideoCodec codec_settings_; |
| 98 int32_t number_of_cores_; | 107 int32_t number_of_cores_; |
| 99 rtc::scoped_ptr<VideoDecoder> fallback_decoder_; | 108 rtc::scoped_ptr<VideoDecoder> fallback_decoder_; |
| 100 DecodedImageCallback* callback_; | 109 DecodedImageCallback* callback_; |
| 101 }; | 110 }; |
| 102 | 111 |
| 103 } // namespace webrtc | 112 } // namespace webrtc |
| 104 | 113 |
| 105 #endif // WEBRTC_VIDEO_DECODER_H_ | 114 #endif // WEBRTC_VIDEO_DECODER_H_ |
| OLD | NEW |