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 #include "media/cast/framer/frame_buffer.h" | 5 #include "media/cast/framer/frame_buffer.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 | 8 |
9 namespace media { | 9 namespace media { |
10 namespace cast { | 10 namespace cast { |
(...skipping 10 matching lines...) Expand all Loading... |
21 FrameBuffer::~FrameBuffer() {} | 21 FrameBuffer::~FrameBuffer() {} |
22 | 22 |
23 void FrameBuffer::InsertPacket(const uint8* payload_data, | 23 void FrameBuffer::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 // Is this the first packet in the frame? | 26 // Is this the first packet in the frame? |
27 if (packets_.empty()) { | 27 if (packets_.empty()) { |
28 frame_id_ = rtp_header.frame_id; | 28 frame_id_ = rtp_header.frame_id; |
29 max_packet_id_ = rtp_header.max_packet_id; | 29 max_packet_id_ = rtp_header.max_packet_id; |
30 is_key_frame_ = rtp_header.is_key_frame; | 30 is_key_frame_ = rtp_header.is_key_frame; |
| 31 if (is_key_frame_) |
| 32 DCHECK_EQ(rtp_header.frame_id, rtp_header.reference_frame_id); |
31 last_referenced_frame_id_ = rtp_header.reference_frame_id; | 33 last_referenced_frame_id_ = rtp_header.reference_frame_id; |
32 rtp_timestamp_ = rtp_header.rtp_timestamp; | 34 rtp_timestamp_ = rtp_header.rtp_timestamp; |
33 } | 35 } |
34 // Is this the correct frame? | 36 // Is this the correct frame? |
35 if (rtp_header.frame_id != frame_id_) | 37 if (rtp_header.frame_id != frame_id_) |
36 return; | 38 return; |
37 | 39 |
38 // Insert every packet only once. | 40 // Insert every packet only once. |
39 if (packets_.find(rtp_header.packet_id) != packets_.end()) { | 41 if (packets_.find(rtp_header.packet_id) != packets_.end()) { |
40 return; | 42 return; |
41 } | 43 } |
42 | 44 |
43 std::vector<uint8> data; | 45 std::vector<uint8> data; |
44 std::pair<PacketMap::iterator, bool> retval = | 46 std::pair<PacketMap::iterator, bool> retval = |
45 packets_.insert(make_pair(rtp_header.packet_id, data)); | 47 packets_.insert(make_pair(rtp_header.packet_id, data)); |
46 | 48 |
47 // Insert the packet. | 49 // Insert the packet. |
48 retval.first->second.resize(payload_size); | 50 retval.first->second.resize(payload_size); |
49 std::copy( | 51 std::copy( |
50 payload_data, payload_data + payload_size, retval.first->second.begin()); | 52 payload_data, payload_data + payload_size, retval.first->second.begin()); |
51 | 53 |
52 ++num_packets_received_; | 54 ++num_packets_received_; |
53 total_data_size_ += payload_size; | 55 total_data_size_ += payload_size; |
54 } | 56 } |
55 | 57 |
56 bool FrameBuffer::Complete() const { | 58 bool FrameBuffer::Complete() const { |
57 return num_packets_received_ - 1 == max_packet_id_; | 59 return num_packets_received_ - 1 == max_packet_id_; |
58 } | 60 } |
59 | 61 |
60 bool FrameBuffer::GetEncodedAudioFrame( | 62 bool FrameBuffer::AssembleEncodedFrame(transport::EncodedFrame* frame) const { |
61 transport::EncodedAudioFrame* audio_frame) const { | |
62 if (!Complete()) | 63 if (!Complete()) |
63 return false; | 64 return false; |
64 | 65 |
65 // Frame is complete -> construct. | 66 // Frame is complete -> construct. |
66 audio_frame->frame_id = frame_id_; | 67 if (is_key_frame_) |
67 audio_frame->rtp_timestamp = rtp_timestamp_; | 68 frame->dependency = transport::EncodedFrame::KEY; |
| 69 else if (frame_id_ == last_referenced_frame_id_) |
| 70 frame->dependency = transport::EncodedFrame::INDEPENDENT; |
| 71 else |
| 72 frame->dependency = transport::EncodedFrame::DEPENDENT; |
| 73 frame->frame_id = frame_id_; |
| 74 frame->referenced_frame_id = last_referenced_frame_id_; |
| 75 frame->rtp_timestamp = rtp_timestamp_; |
68 | 76 |
69 // Build the data vector. | 77 // Build the data vector. |
70 audio_frame->data.clear(); | 78 frame->data.clear(); |
71 audio_frame->data.reserve(total_data_size_); | 79 frame->data.reserve(total_data_size_); |
72 PacketMap::const_iterator it; | 80 PacketMap::const_iterator it; |
73 for (it = packets_.begin(); it != packets_.end(); ++it) { | 81 for (it = packets_.begin(); it != packets_.end(); ++it) |
74 audio_frame->data.insert( | 82 frame->data.insert(frame->data.end(), it->second.begin(), it->second.end()); |
75 audio_frame->data.end(), it->second.begin(), it->second.end()); | |
76 } | |
77 return true; | 83 return true; |
78 } | 84 } |
79 | 85 |
80 bool FrameBuffer::GetEncodedVideoFrame( | |
81 transport::EncodedVideoFrame* video_frame) const { | |
82 if (!Complete()) | |
83 return false; | |
84 // Frame is complete -> construct. | |
85 video_frame->key_frame = is_key_frame_; | |
86 video_frame->frame_id = frame_id_; | |
87 video_frame->last_referenced_frame_id = last_referenced_frame_id_; | |
88 video_frame->rtp_timestamp = rtp_timestamp_; | |
89 | |
90 // Build the data vector. | |
91 video_frame->data.clear(); | |
92 video_frame->data.reserve(total_data_size_); | |
93 PacketMap::const_iterator it; | |
94 for (it = packets_.begin(); it != packets_.end(); ++it) { | |
95 video_frame->data.insert( | |
96 video_frame->data.end(), it->second.begin(), it->second.end()); | |
97 } | |
98 return true; | |
99 } | |
100 | |
101 } // namespace cast | 86 } // namespace cast |
102 } // namespace media | 87 } // namespace media |
OLD | NEW |