2013-07-10 00:45:36 +00:00
|
|
|
/*
|
2016-02-10 07:54:43 -08:00
|
|
|
* Copyright 2013 The WebRTC project authors. All Rights Reserved.
|
2013-07-10 00:45:36 +00:00
|
|
|
*
|
2016-02-10 07:54:43 -08:00
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
2013-07-10 00:45:36 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
package org.webrtc;
|
|
|
|
|
|
2018-12-10 12:30:46 +01:00
|
|
|
import android.support.annotation.Nullable;
|
2018-04-24 15:11:02 +02:00
|
|
|
|
2013-10-03 18:23:13 +00:00
|
|
|
/**
|
2016-09-21 16:20:03 +02:00
|
|
|
* Java wrapper of native AndroidVideoTrackSource.
|
2013-10-03 18:23:13 +00:00
|
|
|
*/
|
2013-07-10 00:45:36 +00:00
|
|
|
public class VideoSource extends MediaSource {
|
2018-05-02 14:41:22 +02:00
|
|
|
private final NativeCapturerObserver capturerObserver;
|
2018-04-24 15:11:02 +02:00
|
|
|
|
2013-07-10 00:45:36 +00:00
|
|
|
public VideoSource(long nativeSource) {
|
|
|
|
|
super(nativeSource);
|
2019-01-31 13:23:46 +01:00
|
|
|
this.capturerObserver = new NativeCapturerObserver(nativeSource);
|
2018-04-24 15:11:02 +02:00
|
|
|
}
|
|
|
|
|
|
2016-09-21 16:20:03 +02:00
|
|
|
/**
|
|
|
|
|
* Calling this function will cause frames to be scaled down to the requested resolution. Also,
|
|
|
|
|
* frames will be cropped to match the requested aspect ratio, and frames will be dropped to match
|
|
|
|
|
* the requested fps. The requested aspect ratio is orientation agnostic and will be adjusted to
|
|
|
|
|
* maintain the input orientation, so it doesn't matter if e.g. 1280x720 or 720x1280 is requested.
|
|
|
|
|
*/
|
|
|
|
|
public void adaptOutputFormat(int width, int height, int fps) {
|
2018-10-26 14:00:18 +02:00
|
|
|
final int maxSide = Math.max(width, height);
|
|
|
|
|
final int minSide = Math.min(width, height);
|
|
|
|
|
adaptOutputFormat(maxSide, minSide, minSide, maxSide, fps);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Same as above, but allows setting two different target resolutions depending on incoming
|
|
|
|
|
* frame orientation. This gives more fine-grained control and can e.g. be used to force landscape
|
|
|
|
|
* video to be cropped to portrait video.
|
|
|
|
|
*/
|
|
|
|
|
public void adaptOutputFormat(
|
|
|
|
|
int landscapeWidth, int landscapeHeight, int portraitWidth, int portraitHeight, int fps) {
|
|
|
|
|
nativeAdaptOutputFormat(getNativeVideoTrackSource(), landscapeWidth, landscapeHeight,
|
|
|
|
|
portraitWidth, portraitHeight, fps);
|
2016-09-21 16:20:03 +02:00
|
|
|
}
|
|
|
|
|
|
2018-07-05 17:06:51 +02:00
|
|
|
public CapturerObserver getCapturerObserver() {
|
2018-04-24 15:11:02 +02:00
|
|
|
return capturerObserver;
|
|
|
|
|
}
|
|
|
|
|
|
2018-09-28 14:38:21 +02:00
|
|
|
/** Returns a pointer to webrtc::VideoTrackSourceInterface. */
|
|
|
|
|
long getNativeVideoTrackSource() {
|
|
|
|
|
return getNativeMediaSource();
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-26 14:00:18 +02:00
|
|
|
private static native void nativeAdaptOutputFormat(long source, int landscapeWidth,
|
|
|
|
|
int landscapeHeight, int portraitWidth, int portraitHeight, int fps);
|
2013-07-10 00:45:36 +00:00
|
|
|
}
|