diff options
author | perkj@chromium.org <perkj@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-05-22 17:24:00 +0000 |
---|---|---|
committer | perkj@chromium.org <perkj@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-05-22 17:24:00 +0000 |
commit | ff993f9b82f03a23113fd2ce90cda6f276ae148c (patch) | |
tree | 8b1e3bb20a48437ad1dd36eba8d94547d8f170dd /content/browser/media/webrtc_browsertest.cc | |
parent | 714b1bc31b98f73a8c218c40ba6eaaf72ca03b1e (diff) | |
download | chromium_src-ff993f9b82f03a23113fd2ce90cda6f276ae148c.zip chromium_src-ff993f9b82f03a23113fd2ce90cda6f276ae148c.tar.gz chromium_src-ff993f9b82f03a23113fd2ce90cda6f276ae148c.tar.bz2 |
Change MediaStreamVideoSource to output different resolutions do different tracks depending on the track constraints.
This cl introduce a new class VideoTrackAdapter. The adapter is responsible for forwarding frames on the IO-thread from a MediaStreamVideoSource to a the tracks connected to the source. It has the ability to wrap media::VideoFrames with new visible_rect and natural_size to match max width and height resolutions as well as min and max aspect ratio per track.
Note that this does not yet work for textures.
It also changes the WebrtcVideoCaptureAdapter to use libyuv::Scale instead of libyuv::I420Copy. This is needed to allow the video frames sent on a PC to be both cropped and scaled.
BUG= 346616
Review URL: https://codereview.chromium.org/246433006
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@272214 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/browser/media/webrtc_browsertest.cc')
-rw-r--r-- | content/browser/media/webrtc_browsertest.cc | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/content/browser/media/webrtc_browsertest.cc b/content/browser/media/webrtc_browsertest.cc index 68c5b3f..5ec6a81 100644 --- a/content/browser/media/webrtc_browsertest.cc +++ b/content/browser/media/webrtc_browsertest.cc @@ -106,6 +106,22 @@ IN_PROC_BROWSER_TEST_P(WebRtcBrowserTest, CanSetupVideoCallWith1To1AspecRatio) { MakeTypicalPeerConnectionCall(javascript); } +IN_PROC_BROWSER_TEST_P(WebRtcBrowserTest, + CanSetupVideoCallWith16To9AspecRatio) { + const std::string javascript = + "callAndExpectResolution({video: {mandatory: {minWidth: 640," + " maxWidth: 640, minAspectRatio: 1.777}}}, 640, 360);"; + MakeTypicalPeerConnectionCall(javascript); +} + +IN_PROC_BROWSER_TEST_P(WebRtcBrowserTest, + CanSetupVideoCallWith4To3AspecRatio) { + const std::string javascript = + "callAndExpectResolution({video: {mandatory: {minWidth: 960," + "maxAspectRatio: 1.333}}}, 960, 720);"; + MakeTypicalPeerConnectionCall(javascript); +} + #if defined(OS_LINUX) && !defined(OS_CHROMEOS) && defined(ARCH_CPU_ARM_FAMILY) // Timing out on ARM linux, see http://crbug.com/240376 #define MAYBE_CanSetupAudioAndVideoCall DISABLED_CanSetupAudioAndVideoCall |