Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(91)

Side by Side Diff: media/cast/framer/frame_buffer.cc

Issue 288103002: [Cast] EncodedAudioFrame+EncodedVideoFrame+reference_time --> EncodedFrame (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 {
11 11
12 FrameBuffer::FrameBuffer() 12 FrameBuffer::FrameBuffer()
13 : frame_id_(0), 13 : frame_id_(0),
14 max_packet_id_(0), 14 max_packet_id_(0),
15 num_packets_received_(0), 15 num_packets_received_(0),
16 is_key_frame_(false),
17 total_data_size_(0), 16 total_data_size_(0),
18 last_referenced_frame_id_(0), 17 last_referenced_frame_id_(0),
19 packets_() {} 18 packets_() {}
20 19
21 FrameBuffer::~FrameBuffer() {} 20 FrameBuffer::~FrameBuffer() {}
22 21
23 void FrameBuffer::InsertPacket(const uint8* payload_data, 22 void FrameBuffer::InsertPacket(const uint8* payload_data,
24 size_t payload_size, 23 size_t payload_size,
25 const RtpCastHeader& rtp_header) { 24 const RtpCastHeader& rtp_header) {
26 // Is this the first packet in the frame? 25 // Is this the first packet in the frame?
27 if (packets_.empty()) { 26 if (packets_.empty()) {
28 frame_id_ = rtp_header.frame_id; 27 frame_id_ = rtp_header.frame_id;
29 max_packet_id_ = rtp_header.max_packet_id; 28 max_packet_id_ = rtp_header.max_packet_id;
30 is_key_frame_ = rtp_header.is_key_frame; 29 if (rtp_header.is_key_frame) {
31 last_referenced_frame_id_ = rtp_header.reference_frame_id; 30 DCHECK_EQ(rtp_header.frame_id, rtp_header.reference_frame_id);
31 last_referenced_frame_id_ = rtp_header.frame_id;
32 } else {
33 last_referenced_frame_id_ = rtp_header.reference_frame_id;
34 }
32 rtp_timestamp_ = rtp_header.rtp_timestamp; 35 rtp_timestamp_ = rtp_header.rtp_timestamp;
33 } 36 }
34 // Is this the correct frame? 37 // Is this the correct frame?
35 if (rtp_header.frame_id != frame_id_) 38 if (rtp_header.frame_id != frame_id_)
36 return; 39 return;
37 40
38 // Insert every packet only once. 41 // Insert every packet only once.
39 if (packets_.find(rtp_header.packet_id) != packets_.end()) { 42 if (packets_.find(rtp_header.packet_id) != packets_.end()) {
40 return; 43 return;
41 } 44 }
42 45
43 std::vector<uint8> data; 46 std::vector<uint8> data;
44 std::pair<PacketMap::iterator, bool> retval = 47 std::pair<PacketMap::iterator, bool> retval =
45 packets_.insert(make_pair(rtp_header.packet_id, data)); 48 packets_.insert(make_pair(rtp_header.packet_id, data));
46 49
47 // Insert the packet. 50 // Insert the packet.
48 retval.first->second.resize(payload_size); 51 retval.first->second.resize(payload_size);
49 std::copy( 52 std::copy(
50 payload_data, payload_data + payload_size, retval.first->second.begin()); 53 payload_data, payload_data + payload_size, retval.first->second.begin());
51 54
52 ++num_packets_received_; 55 ++num_packets_received_;
53 total_data_size_ += payload_size; 56 total_data_size_ += payload_size;
54 } 57 }
55 58
56 bool FrameBuffer::Complete() const { 59 bool FrameBuffer::Complete() const {
57 return num_packets_received_ - 1 == max_packet_id_; 60 return num_packets_received_ - 1 == max_packet_id_;
58 } 61 }
59 62
60 bool FrameBuffer::GetEncodedAudioFrame( 63 bool FrameBuffer::AssembleEncodedFrame(transport::EncodedFrame* frame) const {
61 transport::EncodedAudioFrame* audio_frame) const {
62 if (!Complete()) 64 if (!Complete())
63 return false; 65 return false;
64 66
65 // Frame is complete -> construct. 67 // Frame is complete -> construct.
66 audio_frame->frame_id = frame_id_; 68 frame->frame_id = frame_id_;
67 audio_frame->rtp_timestamp = rtp_timestamp_; 69 frame->base_frame_id = last_referenced_frame_id_;
70 frame->rtp_timestamp = rtp_timestamp_;
68 71
69 // Build the data vector. 72 // Build the data vector.
70 audio_frame->data.clear(); 73 frame->data.clear();
71 audio_frame->data.reserve(total_data_size_); 74 frame->data.reserve(total_data_size_);
72 PacketMap::const_iterator it; 75 PacketMap::const_iterator it;
73 for (it = packets_.begin(); it != packets_.end(); ++it) { 76 for (it = packets_.begin(); it != packets_.end(); ++it)
74 audio_frame->data.insert( 77 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; 78 return true;
78 } 79 }
79 80
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 81 } // namespace cast
102 } // namespace media 82 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698