OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_FRAMER_FRAME_BUFFER | 5 #ifndef MEDIA_CAST_FRAMER_FRAME_BUFFER |
6 #define MEDIA_CAST_FRAMER_FRAME_BUFFER | 6 #define MEDIA_CAST_FRAMER_FRAME_BUFFER |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "media/cast/cast_config.h" | 11 #include "media/cast/cast_config.h" |
12 #include "media/cast/rtp_receiver/rtp_receiver_defines.h" | 12 #include "media/cast/rtp_receiver/rtp_receiver_defines.h" |
13 | 13 |
14 namespace media { | 14 namespace media { |
15 namespace cast { | 15 namespace cast { |
16 | 16 |
17 typedef std::map<uint16, std::vector<uint8> > PacketMap; | 17 typedef std::map<uint16, std::vector<uint8> > PacketMap; |
18 | 18 |
19 class FrameBuffer { | 19 class FrameBuffer { |
20 public: | 20 public: |
21 FrameBuffer(); | 21 FrameBuffer(); |
22 ~FrameBuffer(); | 22 ~FrameBuffer(); |
23 void InsertPacket(const uint8* payload_data, | 23 void InsertPacket(const uint8* payload_data, |
24 size_t payload_size, | 24 size_t payload_size, |
25 const RtpCastHeader& rtp_header); | 25 const RtpCastHeader& rtp_header); |
26 bool Complete() const; | 26 bool Complete() const; |
27 | 27 |
28 bool GetEncodedAudioFrame(transport::EncodedAudioFrame* audio_frame) const; | 28 // If a frame is complete, sets the frame IDs and RTP timestamp in |frame|, |
29 // and also copies the data from all packets into the data field in |frame|. | |
30 // Returns true if the frame was complete; false if incomplete and |frame| | |
31 // remains unchanged. | |
32 bool AssembleEncodedFrame(transport::EncodedFrame* frame) const; | |
29 | 33 |
30 bool GetEncodedVideoFrame(transport::EncodedVideoFrame* video_frame) const; | 34 bool is_key_frame() const { return frame_id_ == last_referenced_frame_id_; } |
Alpha Left Google
2014/05/15 22:11:23
I don't think we need to change this.
A key frame
miu
2014/05/16 04:27:25
Done.
You make an excellent point. I talked with
| |
31 | |
32 bool is_key_frame() const { return is_key_frame_; } | |
33 | 35 |
34 uint32 last_referenced_frame_id() const { return last_referenced_frame_id_; } | 36 uint32 last_referenced_frame_id() const { return last_referenced_frame_id_; } |
35 | 37 |
36 private: | 38 private: |
37 uint32 frame_id_; | 39 uint32 frame_id_; |
38 uint16 max_packet_id_; | 40 uint16 max_packet_id_; |
39 uint16 num_packets_received_; | 41 uint16 num_packets_received_; |
40 bool is_key_frame_; | |
41 size_t total_data_size_; | 42 size_t total_data_size_; |
42 uint32 last_referenced_frame_id_; | 43 uint32 last_referenced_frame_id_; |
43 uint32 rtp_timestamp_; | 44 uint32 rtp_timestamp_; |
44 PacketMap packets_; | 45 PacketMap packets_; |
45 | 46 |
46 DISALLOW_COPY_AND_ASSIGN(FrameBuffer); | 47 DISALLOW_COPY_AND_ASSIGN(FrameBuffer); |
47 }; | 48 }; |
48 | 49 |
49 } // namespace cast | 50 } // namespace cast |
50 } // namespace media | 51 } // namespace media |
51 | 52 |
52 #endif // MEDIA_CAST_FRAMER_FRAME_BUFFER | 53 #endif // MEDIA_CAST_FRAMER_FRAME_BUFFER |
OLD | NEW |