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

Side by Side Diff: talk/app/webrtc/java/jni/androidmediaencoder_jni.cc

Issue 1291543006: Update Bind to match its comments and always capture by value. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Removed references to std::remove_reference (har har) Created 5 years, 1 month 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
OLDNEW
1 /* 1 /*
2 * libjingle 2 * libjingle
3 * Copyright 2015 Google Inc. 3 * Copyright 2015 Google Inc.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met: 6 * modification, are permitted provided that the following conditions are met:
7 * 7 *
8 * 1. Redistributions of source code must retain the above copyright notice, 8 * 1. Redistributions of source code must retain the above copyright notice,
9 * this list of conditions and the following disclaimer. 9 * this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright notice, 10 * 2. Redistributions in binary form must reproduce the above copyright notice,
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after
112 void ResetCodec(); 112 void ResetCodec();
113 113
114 // Implementation of webrtc::VideoEncoder methods above, all running on the 114 // Implementation of webrtc::VideoEncoder methods above, all running on the
115 // codec thread exclusively. 115 // codec thread exclusively.
116 // 116 //
117 // If width==0 then this is assumed to be a re-initialization and the 117 // If width==0 then this is assumed to be a re-initialization and the
118 // previously-current values are reused instead of the passed parameters 118 // previously-current values are reused instead of the passed parameters
119 // (makes it easier to reason about thread-safety). 119 // (makes it easier to reason about thread-safety).
120 int32_t InitEncodeOnCodecThread(int width, int height, int kbps, int fps); 120 int32_t InitEncodeOnCodecThread(int width, int height, int kbps, int fps);
121 int32_t EncodeOnCodecThread( 121 int32_t EncodeOnCodecThread(
122 const webrtc::VideoFrame& input_image, 122 const webrtc::VideoFrame* input_image,
magjed_webrtc 2015/10/23 05:17:01 Leave this unchanged - implicit copies of webrtc::
noahric 2015/10/23 06:02:16 SGTM. Done.
123 const std::vector<webrtc::FrameType>* frame_types); 123 const std::vector<webrtc::FrameType>* frame_types);
124 int32_t RegisterEncodeCompleteCallbackOnCodecThread( 124 int32_t RegisterEncodeCompleteCallbackOnCodecThread(
125 webrtc::EncodedImageCallback* callback); 125 webrtc::EncodedImageCallback* callback);
126 int32_t ReleaseOnCodecThread(); 126 int32_t ReleaseOnCodecThread();
127 int32_t SetRatesOnCodecThread(uint32_t new_bit_rate, uint32_t frame_rate); 127 int32_t SetRatesOnCodecThread(uint32_t new_bit_rate, uint32_t frame_rate);
128 128
129 // Helper accessors for MediaCodecVideoEncoder$OutputBufferInfo members. 129 // Helper accessors for MediaCodecVideoEncoder$OutputBufferInfo members.
130 int GetOutputBufferInfoIndex(JNIEnv* jni, jobject j_output_buffer_info); 130 int GetOutputBufferInfoIndex(JNIEnv* jni, jobject j_output_buffer_info);
131 jobject GetOutputBufferInfoBuffer(JNIEnv* jni, jobject j_output_buffer_info); 131 jobject GetOutputBufferInfoBuffer(JNIEnv* jni, jobject j_output_buffer_info);
132 bool GetOutputBufferInfoIsKeyFrame(JNIEnv* jni, jobject j_output_buffer_info); 132 bool GetOutputBufferInfoIsKeyFrame(JNIEnv* jni, jobject j_output_buffer_info);
(...skipping 199 matching lines...) Expand 10 before | Expand all | Expand 10 after
332 codec_settings->height, 332 codec_settings->height,
333 codec_settings->startBitrate, 333 codec_settings->startBitrate,
334 codec_settings->maxFramerate)); 334 codec_settings->maxFramerate));
335 } 335 }
336 336
337 int32_t MediaCodecVideoEncoder::Encode( 337 int32_t MediaCodecVideoEncoder::Encode(
338 const webrtc::VideoFrame& frame, 338 const webrtc::VideoFrame& frame,
339 const webrtc::CodecSpecificInfo* /* codec_specific_info */, 339 const webrtc::CodecSpecificInfo* /* codec_specific_info */,
340 const std::vector<webrtc::FrameType>* frame_types) { 340 const std::vector<webrtc::FrameType>* frame_types) {
341 return codec_thread_->Invoke<int32_t>(Bind( 341 return codec_thread_->Invoke<int32_t>(Bind(
342 &MediaCodecVideoEncoder::EncodeOnCodecThread, this, frame, frame_types)); 342 &MediaCodecVideoEncoder::EncodeOnCodecThread, this, &frame, frame_types));
343 } 343 }
344 344
345 int32_t MediaCodecVideoEncoder::RegisterEncodeCompleteCallback( 345 int32_t MediaCodecVideoEncoder::RegisterEncodeCompleteCallback(
346 webrtc::EncodedImageCallback* callback) { 346 webrtc::EncodedImageCallback* callback) {
347 return codec_thread_->Invoke<int32_t>( 347 return codec_thread_->Invoke<int32_t>(
348 Bind(&MediaCodecVideoEncoder::RegisterEncodeCompleteCallbackOnCodecThread, 348 Bind(&MediaCodecVideoEncoder::RegisterEncodeCompleteCallbackOnCodecThread,
349 this, 349 this,
350 callback)); 350 callback));
351 } 351 }
352 352
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after
492 CHECK_EXCEPTION(jni); 492 CHECK_EXCEPTION(jni);
493 RTC_CHECK(yuv_buffer_capacity >= yuv_size_) << "Insufficient capacity"; 493 RTC_CHECK(yuv_buffer_capacity >= yuv_size_) << "Insufficient capacity";
494 } 494 }
495 CHECK_EXCEPTION(jni); 495 CHECK_EXCEPTION(jni);
496 496
497 codec_thread_->PostDelayed(kMediaCodecPollMs, this); 497 codec_thread_->PostDelayed(kMediaCodecPollMs, this);
498 return WEBRTC_VIDEO_CODEC_OK; 498 return WEBRTC_VIDEO_CODEC_OK;
499 } 499 }
500 500
501 int32_t MediaCodecVideoEncoder::EncodeOnCodecThread( 501 int32_t MediaCodecVideoEncoder::EncodeOnCodecThread(
502 const webrtc::VideoFrame& frame, 502 const webrtc::VideoFrame* frame,
503 const std::vector<webrtc::FrameType>* frame_types) { 503 const std::vector<webrtc::FrameType>* frame_types) {
504 CheckOnCodecThread(); 504 CheckOnCodecThread();
505 JNIEnv* jni = AttachCurrentThreadIfNeeded(); 505 JNIEnv* jni = AttachCurrentThreadIfNeeded();
506 ScopedLocalRefFrame local_ref_frame(jni); 506 ScopedLocalRefFrame local_ref_frame(jni);
507 507
508 if (!inited_) { 508 if (!inited_) {
509 return WEBRTC_VIDEO_CODEC_UNINITIALIZED; 509 return WEBRTC_VIDEO_CODEC_UNINITIALIZED;
510 } 510 }
511 frames_received_++; 511 frames_received_++;
512 if (!DeliverPendingOutputs(jni)) { 512 if (!DeliverPendingOutputs(jni)) {
513 ResetCodec(); 513 ResetCodec();
514 // Continue as if everything's fine. 514 // Continue as if everything's fine.
515 } 515 }
516 516
517 if (drop_next_input_frame_) { 517 if (drop_next_input_frame_) {
518 ALOGV("Encoder drop frame - failed callback."); 518 ALOGV("Encoder drop frame - failed callback.");
519 drop_next_input_frame_ = false; 519 drop_next_input_frame_ = false;
520 return WEBRTC_VIDEO_CODEC_OK; 520 return WEBRTC_VIDEO_CODEC_OK;
521 } 521 }
522 522
523 RTC_CHECK(frame_types->size() == 1) << "Unexpected stream count"; 523 RTC_CHECK(frame_types->size() == 1) << "Unexpected stream count";
524 // Check framerate before spatial resolution change. 524 // Check framerate before spatial resolution change.
525 if (scale_) 525 if (scale_)
526 quality_scaler_.OnEncodeFrame(frame); 526 quality_scaler_.OnEncodeFrame(*frame);
527 527
528 const VideoFrame& input_frame = 528 const VideoFrame& input_frame =
529 scale_ ? quality_scaler_.GetScaledFrame(frame) : frame; 529 scale_ ? quality_scaler_.GetScaledFrame(*frame) : *frame;
530 530
531 if (input_frame.width() != width_ || input_frame.height() != height_) { 531 if (input_frame.width() != width_ || input_frame.height() != height_) {
532 ALOGD << "Frame resolution change from " << width_ << " x " << height_ << 532 ALOGD << "Frame resolution change from " << width_ << " x " << height_ <<
533 " to " << input_frame.width() << " x " << input_frame.height(); 533 " to " << input_frame.width() << " x " << input_frame.height();
534 width_ = input_frame.width(); 534 width_ = input_frame.width();
535 height_ = input_frame.height(); 535 height_ = input_frame.height();
536 ResetCodec(); 536 ResetCodec();
537 return WEBRTC_VIDEO_CODEC_OK; 537 return WEBRTC_VIDEO_CODEC_OK;
538 } 538 }
539 539
(...skipping 415 matching lines...) Expand 10 before | Expand all | Expand 10 after
955 } 955 }
956 956
957 void MediaCodecVideoEncoderFactory::DestroyVideoEncoder( 957 void MediaCodecVideoEncoderFactory::DestroyVideoEncoder(
958 webrtc::VideoEncoder* encoder) { 958 webrtc::VideoEncoder* encoder) {
959 ALOGD << "Destroy video encoder."; 959 ALOGD << "Destroy video encoder.";
960 delete encoder; 960 delete encoder;
961 } 961 }
962 962
963 } // namespace webrtc_jni 963 } // namespace webrtc_jni
964 964
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698