OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 MEDIA_CAST_SENDER_SOFTWARE_VIDEO_ENCODER_H_ | 5 #ifndef MEDIA_CAST_SENDER_SOFTWARE_VIDEO_ENCODER_H_ |
6 #define MEDIA_CAST_SENDER_SOFTWARE_VIDEO_ENCODER_H_ | 6 #define MEDIA_CAST_SENDER_SOFTWARE_VIDEO_ENCODER_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
10 #include "media/cast/sender/sender_encoded_frame.h" | |
11 | 10 |
12 namespace base { | 11 namespace base { |
13 class TimeTicks; | 12 class TimeTicks; |
14 } | 13 } |
15 | 14 |
16 namespace media { | 15 namespace media { |
17 class VideoFrame; | 16 class VideoFrame; |
18 } | 17 } |
19 | 18 |
20 namespace media { | 19 namespace media { |
21 namespace cast { | 20 namespace cast { |
| 21 struct EncodedFrame; |
22 | 22 |
23 class SoftwareVideoEncoder { | 23 class SoftwareVideoEncoder { |
24 public: | 24 public: |
25 virtual ~SoftwareVideoEncoder() {} | 25 virtual ~SoftwareVideoEncoder() {} |
26 | 26 |
27 // Initialize the encoder before Encode() can be called. This method | 27 // Initialize the encoder before Encode() can be called. This method |
28 // must be called on the thread that Encode() is called. | 28 // must be called on the thread that Encode() is called. |
29 virtual void Initialize() = 0; | 29 virtual void Initialize() = 0; |
30 | 30 |
31 // Encode a raw image (as a part of a video stream). | 31 // Encode a raw image (as a part of a video stream). |
32 virtual void Encode(const scoped_refptr<media::VideoFrame>& video_frame, | 32 virtual void Encode(const scoped_refptr<media::VideoFrame>& video_frame, |
33 const base::TimeTicks& reference_time, | 33 const base::TimeTicks& reference_time, |
34 SenderEncodedFrame* encoded_frame) = 0; | 34 EncodedFrame* encoded_frame) = 0; |
35 | 35 |
36 // Update the encoder with a new target bit rate. | 36 // Update the encoder with a new target bit rate. |
37 virtual void UpdateRates(uint32 new_bitrate) = 0; | 37 virtual void UpdateRates(uint32 new_bitrate) = 0; |
38 | 38 |
39 // Set the next frame to be a key frame. | 39 // Set the next frame to be a key frame. |
40 virtual void GenerateKeyFrame() = 0; | 40 virtual void GenerateKeyFrame() = 0; |
41 | 41 |
42 // Set the last frame to reference. | 42 // Set the last frame to reference. |
43 virtual void LatestFrameIdToReference(uint32 frame_id) = 0; | 43 virtual void LatestFrameIdToReference(uint32 frame_id) = 0; |
44 }; | 44 }; |
45 | 45 |
46 } // namespace cast | 46 } // namespace cast |
47 } // namespace media | 47 } // namespace media |
48 | 48 |
49 #endif // MEDIA_CAST_SENDER_SOFTWARE_VIDEO_ENCODER_H_ | 49 #endif // MEDIA_CAST_SENDER_SOFTWARE_VIDEO_ENCODER_H_ |
OLD | NEW |