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

Issue 1960073002: New method CreateScaledFrame in the VideoFrameFactory interface.

Created:
4 years, 7 months ago by nisse-webrtc
Modified:
4 years, 6 months ago
Reviewers:
CC:
webrtc-reviews_webrtc.org, tterriberry_mozilla.com, the sun
Base URL:
https://chromium.googlesource.com/external/webrtc.git@master
Target Ref:
refs/pending/heads/master
Project:
webrtc
Visibility:
Public.

Description

New method CreateScaledFrame in the VideoFrameFactory interface. Intended to replace the CreateAliasedFrame methods. Implemented in WebRtcVideoFrameFactory. BUG=webrtc:5682

Patch Set 1 #

Total comments: 6

Patch Set 2 : Swap dst width and height when apply_rotation is true. Address nits. #

Patch Set 3 : Implement cropping. #

Total comments: 2

Patch Set 4 : Fix vertical cropping case. Add test case. #

Patch Set 5 : Move cropping logic to VideoFrameFactory base class. #

Patch Set 6 : Implemented AndroidVideoCapturer::FrameFactory::CreateScaledCroppedFrame. #

Patch Set 7 : Fix android compile. #

Total comments: 16

Patch Set 8 : Add missing override declaration. #

Total comments: 3

Patch Set 9 : Rename method to CreateCroppedAndScaledFrame. Comment and format improvements. #

Total comments: 5
Unified diffs Side-by-side diffs Delta from patch set Stats (+394 lines, -19 lines) Patch
M webrtc/api/androidvideocapturer.cc View 1 2 3 4 5 6 7 8 1 chunk +36 lines, -0 lines 2 comments Download
M webrtc/common_video/include/video_frame_buffer.h View 1 2 3 4 5 6 7 8 2 chunks +29 lines, -0 lines 1 comment Download
M webrtc/common_video/video_frame_buffer.cc View 1 2 3 4 5 6 7 8 4 chunks +72 lines, -8 lines 1 comment Download
M webrtc/media/base/videocapturer.cc View 1 2 3 4 5 6 7 8 1 chunk +2 lines, -5 lines 0 comments Download
M webrtc/media/base/videoframefactory.h View 1 2 3 4 5 6 7 8 3 chunks +34 lines, -2 lines 0 comments Download
M webrtc/media/base/videoframefactory.cc View 1 2 3 4 5 6 7 8 1 chunk +48 lines, -0 lines 1 comment Download
M webrtc/media/engine/webrtcvideoframefactory.h View 1 2 3 4 5 6 7 8 1 chunk +9 lines, -0 lines 0 comments Download
M webrtc/media/engine/webrtcvideoframefactory.cc View 1 2 3 4 5 6 7 8 1 chunk +65 lines, -0 lines 0 comments Download
M webrtc/media/engine/webrtcvideoframefactory_unittest.cc View 1 2 3 4 chunks +99 lines, -4 lines 0 comments Download

Messages

Total messages: 20 (7 generated)
nisse-webrtc
Please have a first look. Fails the test case WebRtcVideoFrameFactoryTest.CreateScaledFrameApplyRotation I think I have to ...
4 years, 7 months ago (2016-05-09 10:10:01 UTC) #2
magjed_webrtc
https://codereview.webrtc.org/1960073002/diff/1/webrtc/media/engine/webrtcvideoframefactory.cc File webrtc/media/engine/webrtcvideoframefactory.cc (right): https://codereview.webrtc.org/1960073002/diff/1/webrtc/media/engine/webrtcvideoframefactory.cc#newcode17 webrtc/media/engine/webrtcvideoframefactory.cc:17: // #include "webrtc/common_video/include/video_frame_buffer.h" remove if not used https://codereview.webrtc.org/1960073002/diff/1/webrtc/media/engine/webrtcvideoframefactory.cc#newcode42 webrtc/media/engine/webrtcvideoframefactory.cc:42: ...
4 years, 7 months ago (2016-05-09 10:58:08 UTC) #3
commit-bot: I haz the power
Dry run: CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/1960073002/20001 View timeline at https://chromium-cq-status.appspot.com/patch-timeline/1960073002/20001
4 years, 7 months ago (2016-05-09 11:04:55 UTC) #5
nisse-webrtc
Done the simple things. Will try cropping next. Any idea on how to write a ...
4 years, 7 months ago (2016-05-09 11:06:01 UTC) #6
commit-bot: I haz the power
Dry run: Try jobs failed on following builders: linux_msan on tryserver.webrtc (JOB_FAILED, http://build.chromium.org/p/tryserver.webrtc/builders/linux_msan/builds/9923)
4 years, 7 months ago (2016-05-09 11:48:46 UTC) #8
nisse-webrtc
Added cropping. Still missing a unit test.
4 years, 7 months ago (2016-05-09 12:01:44 UTC) #9
magjed_webrtc
You should update AndroidVideoCapturer::FrameFactory in this CL as well. https://codereview.webrtc.org/1960073002/diff/40001/webrtc/media/engine/webrtcvideoframefactory.cc File webrtc/media/engine/webrtcvideoframefactory.cc (right): https://codereview.webrtc.org/1960073002/diff/40001/webrtc/media/engine/webrtcvideoframefactory.cc#newcode38 webrtc/media/engine/webrtcvideoframefactory.cc:38: ...
4 years, 7 months ago (2016-05-09 13:44:55 UTC) #10
nisse-webrtc
Added a test case, and fixed a typo breaking vertical cropping. I'll look at AndroidVideoCapturer::FrameFactory ...
4 years, 7 months ago (2016-05-10 07:56:23 UTC) #11
commit-bot: I haz the power
Dry run: CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/patch-status/1960073002/120001 View timeline at https://chromium-cq-status.appspot.com/patch-timeline/1960073002/120001
4 years, 7 months ago (2016-05-11 06:59:43 UTC) #13
commit-bot: I haz the power
Dry run: Try jobs failed on following builders: android_compile_x86_dbg on tryserver.webrtc (JOB_FAILED, http://build.chromium.org/p/tryserver.webrtc/builders/android_compile_x86_dbg/builds/3887)
4 years, 7 months ago (2016-05-11 07:10:54 UTC) #15
perkj_webrtc
https://codereview.webrtc.org/1960073002/diff/120001/webrtc/common_video/include/video_frame_buffer.h File webrtc/common_video/include/video_frame_buffer.h (right): https://codereview.webrtc.org/1960073002/diff/120001/webrtc/common_video/include/video_frame_buffer.h#newcode134 webrtc/common_video/include/video_frame_buffer.h:134: int crop_width, please document what the arguments means. https://codereview.webrtc.org/1960073002/diff/120001/webrtc/common_video/video_frame_buffer.cc ...
4 years, 7 months ago (2016-05-11 10:05:17 UTC) #16
nisse-webrtc
https://codereview.webrtc.org/1960073002/diff/120001/webrtc/common_video/include/video_frame_buffer.h File webrtc/common_video/include/video_frame_buffer.h (right): https://codereview.webrtc.org/1960073002/diff/120001/webrtc/common_video/include/video_frame_buffer.h#newcode134 webrtc/common_video/include/video_frame_buffer.h:134: int crop_width, On 2016/05/11 10:05:17, perkj_webrtc wrote: > please ...
4 years, 7 months ago (2016-05-12 12:23:07 UTC) #17
perkj_webrtc
4 years, 7 months ago (2016-05-16 06:48:47 UTC) #18
https://codereview.webrtc.org/1960073002/diff/140001/webrtc/common_video/vide...
File webrtc/common_video/video_frame_buffer.cc (right):

https://codereview.webrtc.org/1960073002/diff/140001/webrtc/common_video/vide...
webrtc/common_video/video_frame_buffer.cc:211: rtc::scoped_refptr<I420Buffer>
I420Buffer::CropAndScale(
On 2016/05/12 12:23:07, nisse-webrtc wrote:
> On 2016/05/11 10:05:17, perkj_webrtc wrote:
> > Add unit test for this method please. 
> 
> Ok. Something similar to the corresponding WebRtcVideoFrameFactoryTest test
> should do.

Test still missing in webrtcvideoframe_unittests and/or videoframe_unittest.h

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/api/androidvideoc...
File webrtc/api/androidvideocapturer.cc (right):

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/api/androidvideoc...
webrtc/api/androidvideocapturer.cc:77: // TODO(nisse): Must handle texture
frames too.
I think you have to do this now. CreateAliasedFrame handles textures but since
you override CreateCroppedAndScaledFrame it will not be called?

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/api/androidvideoc...
webrtc/api/androidvideocapturer.cc:99:
frame->GetCopyWithRotationApplied()->Copy())
nit: Should there be a TODO here to fix GetCopyWithRotationApplied()->Copy()) ?
ie- should GetCopyWithRotationApplied() return a new I420Buffer  so you don't
need to call Copy? The capturer  could potentially cash the rotated buffer if it
has multiple sinks. 

(or we we just pretend that we have not seen this funny thing at the
moment.....)

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/common_video/incl...
File webrtc/common_video/include/video_frame_buffer.h (right):

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/common_video/incl...
webrtc/common_video/include/video_frame_buffer.h:131: // lower left corner at
|crop_x|, |crop_y|, and returns a new frame
lower left? -really ? isn't this upper left?

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/common_video/vide...
File webrtc/common_video/video_frame_buffer.cc (right):

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/common_video/vide...
webrtc/common_video/video_frame_buffer.cc:228: // TODO(nisse): Duplicated in
ShallowCrop.
remove this todo. I am fine with this duplication.

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/media/base/videof...
File webrtc/media/base/videoframefactory.cc (right):

https://codereview.webrtc.org/1960073002/diff/160001/webrtc/media/base/videof...
webrtc/media/base/videoframefactory.cc:32: // TODO(nisse): Old code carried a
comment saying that MJPG can
You can add a DCHECK here if you want to check that input_frame is not MJPG. But
we don't support MJPG at this level anymore anyway, MGJP has already been
supported to I420 before reaching libjingle.

Powered by Google App Engine
This is Rietveld 408576698