OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "remoting/host/video_scheduler.h" | 5 #include "remoting/host/video_scheduler.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/callback.h" | 10 #include "base/callback.h" |
(...skipping 277 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
288 scoped_ptr<VideoPacket> packet(new VideoPacket()); | 288 scoped_ptr<VideoPacket> packet(new VideoPacket()); |
289 packet->set_flags(VideoPacket::LAST_PARTITION); | 289 packet->set_flags(VideoPacket::LAST_PARTITION); |
290 packet->set_client_sequence_number(sequence_number); | 290 packet->set_client_sequence_number(sequence_number); |
291 network_task_runner_->PostTask( | 291 network_task_runner_->PostTask( |
292 FROM_HERE, base::Bind(&VideoScheduler::SendVideoPacket, this, | 292 FROM_HERE, base::Bind(&VideoScheduler::SendVideoPacket, this, |
293 base::Passed(&packet))); | 293 base::Passed(&packet))); |
294 capture_task_runner_->DeleteSoon(FROM_HERE, frame.release()); | 294 capture_task_runner_->DeleteSoon(FROM_HERE, frame.release()); |
295 return; | 295 return; |
296 } | 296 } |
297 | 297 |
298 encoder_->Encode( | 298 scoped_ptr<VideoPacket> packet = encoder_->Encode(*frame); |
299 frame.get(), base::Bind(&VideoScheduler::EncodedDataAvailableCallback, | 299 packet->set_client_sequence_number(sequence_number); |
300 this, sequence_number)); | |
301 capture_task_runner_->DeleteSoon(FROM_HERE, frame.release()); | |
302 } | |
303 | 300 |
304 void VideoScheduler::EncodedDataAvailableCallback( | 301 // Destroy the frame before sending |packet| because SendVideoPacket() may |
305 int64 sequence_number, | 302 // trigger another frame to be captured, and the screen capturer expects the |
306 scoped_ptr<VideoPacket> packet) { | 303 // old frame to be freed by then. |
307 DCHECK(encode_task_runner_->BelongsToCurrentThread()); | 304 frame.reset(); |
308 | |
309 packet->set_client_sequence_number(sequence_number); | |
310 | 305 |
311 bool last = (packet->flags() & VideoPacket::LAST_PACKET) != 0; | 306 bool last = (packet->flags() & VideoPacket::LAST_PACKET) != 0; |
312 if (last) { | 307 if (last) { |
313 scheduler_.RecordEncodeTime( | 308 scheduler_.RecordEncodeTime( |
314 base::TimeDelta::FromMilliseconds(packet->encode_time_ms())); | 309 base::TimeDelta::FromMilliseconds(packet->encode_time_ms())); |
315 } | 310 } |
316 | 311 |
317 network_task_runner_->PostTask( | 312 network_task_runner_->PostTask( |
318 FROM_HERE, base::Bind(&VideoScheduler::SendVideoPacket, this, | 313 FROM_HERE, base::Bind(&VideoScheduler::SendVideoPacket, this, |
319 base::Passed(&packet))); | 314 base::Passed(&packet))); |
320 } | 315 } |
321 | 316 |
322 } // namespace remoting | 317 } // namespace remoting |
OLD | NEW |