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

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: rebase 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
« no previous file with comments | « media/cast/framer/frame_buffer.h ('k') | media/cast/framer/frame_buffer_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 {
(...skipping 10 matching lines...) Expand all
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
OLDNEW
« no previous file with comments | « media/cast/framer/frame_buffer.h ('k') | media/cast/framer/frame_buffer_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698