Revert "Call native codec factories from Android ones."
This reverts commit 937a59268e2ae56a58f648fba827444f7beb4466. Reason for revert: Breaks downstream project Original change's description: > Call native codec factories from Android ones. > > Android video codec factories are expected to be synchronised with the native ones in terms on supported codecs. But before this change there were differences: > > 1. Native decoder factory keeps AV1 support behind RTC_DAV1D_IN_INTERNAL_DECODER_FACTORY while Android decoder factory advertises AV1 unconditionally; > > 2. Native encoder factory advertises AV1 if RTC_USE_LIBAOM_AV1_ENCODER is enabled while Android encoder factory never advertises AV1. > > This CL synchronises the codecs set in Android factories with that of native factories by calling native factories from Android ones. > > Bug: webrtc:13573, b/257272020 > Change-Id: I99d801eda0c5f3400bac222b9b08d719f1a6ed72 > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/282240 > Reviewed-by: Rasmus Brandt <brandtr@webrtc.org> > Commit-Queue: Sergey Silkin <ssilkin@webrtc.org> > Reviewed-by: Xavier Lepaul <xalep@webrtc.org> > Cr-Commit-Position: refs/heads/main@{#38583} Bug: webrtc:13573, b/257272020 Change-Id: I8128f5fc5d86902e35ab2812c984169c4b106118 No-Presubmit: true No-Tree-Checks: true No-Try: true Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/282800 Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> Auto-Submit: Andrey Logvin <landrey@google.com> Owners-Override: Mirko Bonadei <mbonadei@webrtc.org> Bot-Commit: rubber-stamper@appspot.gserviceaccount.com <rubber-stamper@appspot.gserviceaccount.com> Commit-Queue: Mirko Bonadei <mbonadei@webrtc.org> Cr-Commit-Position: refs/heads/main@{#38586}
This commit is contained in:
committed by
WebRTC LUCI CQ
parent
fdcfefa708
commit
7dbd77c8b9
@ -885,20 +885,9 @@ if (current_os == "linux" || is_android) {
|
|||||||
rtc_library("swcodecs_jni") {
|
rtc_library("swcodecs_jni") {
|
||||||
visibility = [ "*" ]
|
visibility = [ "*" ]
|
||||||
allow_poison = [ "software_video_codecs" ]
|
allow_poison = [ "software_video_codecs" ]
|
||||||
sources = [
|
|
||||||
"src/jni/software_video_decoder_factory.cc",
|
|
||||||
"src/jni/software_video_encoder_factory.cc",
|
|
||||||
]
|
|
||||||
deps = [
|
deps = [
|
||||||
":base_jni",
|
|
||||||
":generated_swcodecs_jni",
|
|
||||||
":libvpx_vp8_jni",
|
":libvpx_vp8_jni",
|
||||||
":libvpx_vp9_jni",
|
":libvpx_vp9_jni",
|
||||||
":native_api_jni",
|
|
||||||
":video_jni",
|
|
||||||
"../../api/video_codecs:builtin_video_decoder_factory",
|
|
||||||
"../../api/video_codecs:builtin_video_encoder_factory",
|
|
||||||
"../../api/video_codecs:video_codecs_api",
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1364,16 +1353,6 @@ if (current_os == "linux" || is_android) {
|
|||||||
jni_generator_include = "//sdk/android/src/jni/jni_generator_helper.h"
|
jni_generator_include = "//sdk/android/src/jni/jni_generator_helper.h"
|
||||||
}
|
}
|
||||||
|
|
||||||
generate_jni("generated_swcodecs_jni") {
|
|
||||||
sources = [
|
|
||||||
"api/org/webrtc/SoftwareVideoDecoderFactory.java",
|
|
||||||
"api/org/webrtc/SoftwareVideoEncoderFactory.java",
|
|
||||||
]
|
|
||||||
|
|
||||||
namespace = "webrtc::jni"
|
|
||||||
jni_generator_include = "//sdk/android/src/jni/jni_generator_helper.h"
|
|
||||||
}
|
|
||||||
|
|
||||||
generate_jni("generated_peerconnection_jni") {
|
generate_jni("generated_peerconnection_jni") {
|
||||||
sources = [
|
sources = [
|
||||||
"api/org/webrtc/AddIceObserver.java",
|
"api/org/webrtc/AddIceObserver.java",
|
||||||
@ -1492,8 +1471,6 @@ if (is_android) {
|
|||||||
"instrumentationtests/src/org/webrtc/RtcCertificatePemTest.java",
|
"instrumentationtests/src/org/webrtc/RtcCertificatePemTest.java",
|
||||||
"instrumentationtests/src/org/webrtc/RtpSenderTest.java",
|
"instrumentationtests/src/org/webrtc/RtpSenderTest.java",
|
||||||
"instrumentationtests/src/org/webrtc/RtpTransceiverTest.java",
|
"instrumentationtests/src/org/webrtc/RtpTransceiverTest.java",
|
||||||
"instrumentationtests/src/org/webrtc/SoftwareVideoDecoderFactoryTest.java",
|
|
||||||
"instrumentationtests/src/org/webrtc/SoftwareVideoEncoderFactoryTest.java",
|
|
||||||
"instrumentationtests/src/org/webrtc/SurfaceTextureHelperTest.java",
|
"instrumentationtests/src/org/webrtc/SurfaceTextureHelperTest.java",
|
||||||
"instrumentationtests/src/org/webrtc/SurfaceViewRendererOnMeasureTest.java",
|
"instrumentationtests/src/org/webrtc/SurfaceViewRendererOnMeasureTest.java",
|
||||||
"instrumentationtests/src/org/webrtc/TestConstants.java",
|
"instrumentationtests/src/org/webrtc/TestConstants.java",
|
||||||
|
|||||||
@ -16,33 +16,40 @@ import java.util.HashMap;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class SoftwareVideoDecoderFactory implements VideoDecoderFactory {
|
public class SoftwareVideoDecoderFactory implements VideoDecoderFactory {
|
||||||
private static final String TAG = "SoftwareVideoDecoderFactory";
|
|
||||||
|
|
||||||
private final long nativeFactory;
|
|
||||||
|
|
||||||
public SoftwareVideoDecoderFactory() {
|
|
||||||
this.nativeFactory = nativeCreateFactory();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public VideoDecoder createDecoder(VideoCodecInfo info) {
|
public VideoDecoder createDecoder(VideoCodecInfo codecInfo) {
|
||||||
return new WrappedNativeVideoDecoder() {
|
String codecName = codecInfo.getName();
|
||||||
@Override
|
|
||||||
public long createNativeVideoDecoder() {
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.VP8.name())) {
|
||||||
return nativeCreateDecoder(nativeFactory, info);
|
return new LibvpxVp8Decoder();
|
||||||
}
|
}
|
||||||
};
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.VP9.name())
|
||||||
|
&& LibvpxVp9Decoder.nativeIsSupported()) {
|
||||||
|
return new LibvpxVp9Decoder();
|
||||||
|
}
|
||||||
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.AV1.name())) {
|
||||||
|
return new Dav1dDecoder();
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VideoCodecInfo[] getSupportedCodecs() {
|
public VideoCodecInfo[] getSupportedCodecs() {
|
||||||
return nativeGetSupportedCodecs(nativeFactory).toArray(new VideoCodecInfo[0]);
|
return supportedCodecs();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native long nativeCreateFactory();
|
static VideoCodecInfo[] supportedCodecs() {
|
||||||
|
List<VideoCodecInfo> codecs = new ArrayList<VideoCodecInfo>();
|
||||||
|
|
||||||
private static native long nativeCreateDecoder(long factory, VideoCodecInfo videoCodecInfo);
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.VP8.name(), new HashMap<>()));
|
||||||
|
if (LibvpxVp9Decoder.nativeIsSupported()) {
|
||||||
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.VP9.name(), new HashMap<>()));
|
||||||
|
}
|
||||||
|
|
||||||
private static native List<VideoCodecInfo> nativeGetSupportedCodecs(long factory);
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.AV1.name(), new HashMap<>()));
|
||||||
|
|
||||||
|
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -16,38 +16,35 @@ import java.util.HashMap;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class SoftwareVideoEncoderFactory implements VideoEncoderFactory {
|
public class SoftwareVideoEncoderFactory implements VideoEncoderFactory {
|
||||||
private static final String TAG = "SoftwareVideoEncoderFactory";
|
|
||||||
|
|
||||||
private final long nativeFactory;
|
|
||||||
|
|
||||||
public SoftwareVideoEncoderFactory() {
|
|
||||||
this.nativeFactory = nativeCreateFactory();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@Override
|
@Override
|
||||||
public VideoEncoder createEncoder(VideoCodecInfo info) {
|
public VideoEncoder createEncoder(VideoCodecInfo codecInfo) {
|
||||||
return new WrappedNativeVideoEncoder() {
|
String codecName = codecInfo.getName();
|
||||||
@Override
|
|
||||||
public long createNativeVideoEncoder() {
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.VP8.name())) {
|
||||||
return nativeCreateEncoder(nativeFactory, info);
|
return new LibvpxVp8Encoder();
|
||||||
|
}
|
||||||
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.VP9.name())
|
||||||
|
&& LibvpxVp9Encoder.nativeIsSupported()) {
|
||||||
|
return new LibvpxVp9Encoder();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
return null;
|
||||||
public boolean isHardwareEncoder() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VideoCodecInfo[] getSupportedCodecs() {
|
public VideoCodecInfo[] getSupportedCodecs() {
|
||||||
return nativeGetSupportedCodecs(nativeFactory).toArray(new VideoCodecInfo[0]);
|
return supportedCodecs();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native long nativeCreateFactory();
|
static VideoCodecInfo[] supportedCodecs() {
|
||||||
|
List<VideoCodecInfo> codecs = new ArrayList<VideoCodecInfo>();
|
||||||
|
|
||||||
private static native long nativeCreateEncoder(long factory, VideoCodecInfo videoCodecInfo);
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.VP8.name(), new HashMap<>()));
|
||||||
|
if (LibvpxVp9Encoder.nativeIsSupported()) {
|
||||||
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.VP9.name(), new HashMap<>()));
|
||||||
|
}
|
||||||
|
|
||||||
private static native List<VideoCodecInfo> nativeGetSupportedCodecs(long factory);
|
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -22,10 +22,27 @@ import org.junit.Test;
|
|||||||
/** Unit tests for {@link DefaultVideoEncoderFactory}. */
|
/** Unit tests for {@link DefaultVideoEncoderFactory}. */
|
||||||
public class DefaultVideoEncoderFactoryTest {
|
public class DefaultVideoEncoderFactoryTest {
|
||||||
static class CustomHardwareVideoEncoderFactory implements VideoEncoderFactory {
|
static class CustomHardwareVideoEncoderFactory implements VideoEncoderFactory {
|
||||||
private VideoCodecInfo supportedCodec;
|
private ArrayList<VideoCodecInfo> codecs = new ArrayList<>();
|
||||||
|
|
||||||
public CustomHardwareVideoEncoderFactory(VideoCodecInfo supportedCodec) {
|
public CustomHardwareVideoEncoderFactory(boolean includeVP8, boolean includeH264High) {
|
||||||
this.supportedCodec = supportedCodec;
|
if (includeVP8) {
|
||||||
|
codecs.add(new VideoCodecInfo("VP8", new HashMap<>()));
|
||||||
|
}
|
||||||
|
codecs.add(new VideoCodecInfo("VP9", new HashMap<>()));
|
||||||
|
|
||||||
|
HashMap<String, String> baselineParams = new HashMap<String, String>();
|
||||||
|
baselineParams.put("profile-level-id", "42e01f");
|
||||||
|
baselineParams.put("level-asymmetry-allowed", "1");
|
||||||
|
baselineParams.put("packetization-mode", "1");
|
||||||
|
codecs.add(new VideoCodecInfo("H264", baselineParams));
|
||||||
|
|
||||||
|
if (includeH264High) {
|
||||||
|
HashMap<String, String> highParams = new HashMap<String, String>();
|
||||||
|
highParams.put("profile-level-id", "640c1f");
|
||||||
|
highParams.put("level-asymmetry-allowed", "1");
|
||||||
|
highParams.put("packetization-mode", "1");
|
||||||
|
codecs.add(new VideoCodecInfo("H264", highParams));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -35,7 +52,7 @@ public class DefaultVideoEncoderFactoryTest {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public VideoCodecInfo[] getSupportedCodecs() {
|
public VideoCodecInfo[] getSupportedCodecs() {
|
||||||
return new VideoCodecInfo[] {supportedCodec};
|
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,32 +63,44 @@ public class DefaultVideoEncoderFactoryTest {
|
|||||||
|
|
||||||
@SmallTest
|
@SmallTest
|
||||||
@Test
|
@Test
|
||||||
public void getSupportedCodecs_hwVp8SameParamsAsSwVp8_oneVp8() {
|
public void testGetSupportedCodecsWithHardwareH264HighProfile() {
|
||||||
VideoCodecInfo hwVp8Encoder = new VideoCodecInfo("VP8", new HashMap<>());
|
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(true, true);
|
||||||
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(hwVp8Encoder);
|
DefaultVideoEncoderFactory dvef = new DefaultVideoEncoderFactory(hwFactory);
|
||||||
DefaultVideoEncoderFactory defFactory = new DefaultVideoEncoderFactory(hwFactory);
|
VideoCodecInfo[] videoCodecs = dvef.getSupportedCodecs();
|
||||||
VideoCodecInfo[] supportedCodecs = defFactory.getSupportedCodecs();
|
assertEquals(4, videoCodecs.length);
|
||||||
assertEquals(3, supportedCodecs.length);
|
assertEquals("VP8", videoCodecs[0].name);
|
||||||
assertEquals("VP8", supportedCodecs[0].name);
|
assertEquals("VP9", videoCodecs[1].name);
|
||||||
assertEquals("AV1", supportedCodecs[1].name);
|
assertEquals("H264", videoCodecs[2].name);
|
||||||
assertEquals("VP9", supportedCodecs[2].name);
|
assertEquals("42e01f", videoCodecs[2].params.get("profile-level-id"));
|
||||||
|
assertEquals("H264", videoCodecs[3].name);
|
||||||
|
assertEquals("640c1f", videoCodecs[3].params.get("profile-level-id"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@SmallTest
|
@SmallTest
|
||||||
@Test
|
@Test
|
||||||
public void getSupportedCodecs_hwVp8WithDifferentParams_twoVp8() {
|
public void testGetSupportedCodecsWithoutHardwareH264HighProfile() {
|
||||||
VideoCodecInfo hwVp8Encoder = new VideoCodecInfo("VP8", new HashMap<String, String>() {
|
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(true, false);
|
||||||
{ put("param", "value"); }
|
DefaultVideoEncoderFactory dvef = new DefaultVideoEncoderFactory(hwFactory);
|
||||||
});
|
VideoCodecInfo[] videoCodecs = dvef.getSupportedCodecs();
|
||||||
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(hwVp8Encoder);
|
assertEquals(3, videoCodecs.length);
|
||||||
DefaultVideoEncoderFactory defFactory = new DefaultVideoEncoderFactory(hwFactory);
|
assertEquals("VP8", videoCodecs[0].name);
|
||||||
VideoCodecInfo[] supportedCodecs = defFactory.getSupportedCodecs();
|
assertEquals("VP9", videoCodecs[1].name);
|
||||||
assertEquals(4, supportedCodecs.length);
|
assertEquals("H264", videoCodecs[2].name);
|
||||||
assertEquals("VP8", supportedCodecs[0].name);
|
assertEquals("42e01f", videoCodecs[2].params.get("profile-level-id"));
|
||||||
assertEquals("AV1", supportedCodecs[1].name);
|
}
|
||||||
assertEquals("VP9", supportedCodecs[2].name);
|
|
||||||
assertEquals("VP8", supportedCodecs[3].name);
|
@SmallTest
|
||||||
assertEquals(1, supportedCodecs[3].params.size());
|
@Test
|
||||||
assertEquals("value", supportedCodecs[3].params.get("param"));
|
public void testGetSupportedCodecsWithoutHardwareVP8() {
|
||||||
|
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(false, true);
|
||||||
|
DefaultVideoEncoderFactory dvef = new DefaultVideoEncoderFactory(hwFactory);
|
||||||
|
VideoCodecInfo[] videoCodecs = dvef.getSupportedCodecs();
|
||||||
|
assertEquals(4, videoCodecs.length);
|
||||||
|
assertEquals("VP8", videoCodecs[0].name);
|
||||||
|
assertEquals("VP9", videoCodecs[1].name);
|
||||||
|
assertEquals("H264", videoCodecs[2].name);
|
||||||
|
assertEquals("42e01f", videoCodecs[2].params.get("profile-level-id"));
|
||||||
|
assertEquals("H264", videoCodecs[3].name);
|
||||||
|
assertEquals("640c1f", videoCodecs[3].params.get("profile-level-id"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,42 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2022 The WebRTC Project Authors. All rights reserved.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.webrtc;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
import androidx.annotation.Nullable;
|
|
||||||
import androidx.test.filters.SmallTest;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
/** Unit tests for {@link SoftwareVideoDecoderFactory}. */
|
|
||||||
public class SoftwareVideoDecoderFactoryTest {
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
NativeLibrary.initialize(new NativeLibrary.DefaultLoader(), TestConstants.NATIVE_LIBRARY);
|
|
||||||
}
|
|
||||||
|
|
||||||
@SmallTest
|
|
||||||
@Test
|
|
||||||
public void getSupportedCodecs_returnsDefaultCodecs() {
|
|
||||||
VideoDecoderFactory factory = new SoftwareVideoDecoderFactory();
|
|
||||||
VideoCodecInfo[] codecs = factory.getSupportedCodecs();
|
|
||||||
assertEquals(6, codecs.length);
|
|
||||||
assertEquals("VP8", codecs[0].name);
|
|
||||||
assertEquals("VP9", codecs[1].name);
|
|
||||||
assertEquals("VP9", codecs[2].name);
|
|
||||||
assertEquals("VP9", codecs[3].name);
|
|
||||||
assertEquals("AV1", codecs[4].name);
|
|
||||||
assertEquals("AV1", codecs[5].name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,39 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2022 The WebRTC Project Authors. All rights reserved.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.webrtc;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
import androidx.annotation.Nullable;
|
|
||||||
import androidx.test.filters.SmallTest;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
/** Unit tests for {@link SoftwareVideoEncoderFactory}. */
|
|
||||||
public class SoftwareVideoEncoderFactoryTest {
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
NativeLibrary.initialize(new NativeLibrary.DefaultLoader(), TestConstants.NATIVE_LIBRARY);
|
|
||||||
}
|
|
||||||
|
|
||||||
@SmallTest
|
|
||||||
@Test
|
|
||||||
public void getSupportedCodecs_returnsDefaultCodecs() {
|
|
||||||
VideoEncoderFactory factory = new SoftwareVideoEncoderFactory();
|
|
||||||
VideoCodecInfo[] codecs = factory.getSupportedCodecs();
|
|
||||||
assertEquals(3, codecs.length);
|
|
||||||
assertEquals("VP8", codecs[0].name);
|
|
||||||
assertEquals("AV1", codecs[1].name);
|
|
||||||
assertEquals("VP9", codecs[2].name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,50 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2022 The WebRTC project authors. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "api/video_codecs/builtin_video_decoder_factory.h"
|
|
||||||
#include "api/video_codecs/video_decoder.h"
|
|
||||||
#include "sdk/android/generated_swcodecs_jni/SoftwareVideoDecoderFactory_jni.h"
|
|
||||||
#include "sdk/android/native_api/jni/java_types.h"
|
|
||||||
#include "sdk/android/src/jni/jni_helpers.h"
|
|
||||||
#include "sdk/android/src/jni/video_codec_info.h"
|
|
||||||
|
|
||||||
namespace webrtc {
|
|
||||||
namespace jni {
|
|
||||||
|
|
||||||
static jlong JNI_SoftwareVideoDecoderFactory_CreateFactory(JNIEnv* env) {
|
|
||||||
return webrtc::NativeToJavaPointer(
|
|
||||||
CreateBuiltinVideoDecoderFactory().release());
|
|
||||||
}
|
|
||||||
|
|
||||||
static jlong JNI_SoftwareVideoDecoderFactory_CreateDecoder(
|
|
||||||
JNIEnv* env,
|
|
||||||
jlong j_factory,
|
|
||||||
const webrtc::JavaParamRef<jobject>& j_video_codec_info) {
|
|
||||||
auto* const native_factory =
|
|
||||||
reinterpret_cast<webrtc::VideoDecoderFactory*>(j_factory);
|
|
||||||
const auto video_format =
|
|
||||||
webrtc::jni::VideoCodecInfoToSdpVideoFormat(env, j_video_codec_info);
|
|
||||||
|
|
||||||
return webrtc::NativeToJavaPointer(
|
|
||||||
native_factory->CreateVideoDecoder(video_format).release());
|
|
||||||
}
|
|
||||||
|
|
||||||
static webrtc::ScopedJavaLocalRef<jobject>
|
|
||||||
JNI_SoftwareVideoDecoderFactory_GetSupportedCodecs(JNIEnv* env,
|
|
||||||
jlong j_factory) {
|
|
||||||
auto* const native_factory =
|
|
||||||
reinterpret_cast<webrtc::VideoDecoderFactory*>(j_factory);
|
|
||||||
|
|
||||||
return webrtc::NativeToJavaList(env, native_factory->GetSupportedFormats(),
|
|
||||||
&webrtc::jni::SdpVideoFormatToVideoCodecInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace jni
|
|
||||||
} // namespace webrtc
|
|
||||||
@ -1,50 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2022 The WebRTC project authors. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "api/video_codecs/builtin_video_encoder_factory.h"
|
|
||||||
#include "api/video_codecs/video_encoder.h"
|
|
||||||
#include "sdk/android/generated_swcodecs_jni/SoftwareVideoEncoderFactory_jni.h"
|
|
||||||
#include "sdk/android/native_api/jni/java_types.h"
|
|
||||||
#include "sdk/android/src/jni/jni_helpers.h"
|
|
||||||
#include "sdk/android/src/jni/video_codec_info.h"
|
|
||||||
|
|
||||||
namespace webrtc {
|
|
||||||
namespace jni {
|
|
||||||
|
|
||||||
static jlong JNI_SoftwareVideoEncoderFactory_CreateFactory(JNIEnv* env) {
|
|
||||||
return webrtc::NativeToJavaPointer(
|
|
||||||
CreateBuiltinVideoEncoderFactory().release());
|
|
||||||
}
|
|
||||||
|
|
||||||
static jlong JNI_SoftwareVideoEncoderFactory_CreateEncoder(
|
|
||||||
JNIEnv* env,
|
|
||||||
jlong j_factory,
|
|
||||||
const webrtc::JavaParamRef<jobject>& j_video_codec_info) {
|
|
||||||
auto* const native_factory =
|
|
||||||
reinterpret_cast<webrtc::VideoEncoderFactory*>(j_factory);
|
|
||||||
const auto video_format =
|
|
||||||
webrtc::jni::VideoCodecInfoToSdpVideoFormat(env, j_video_codec_info);
|
|
||||||
|
|
||||||
return webrtc::NativeToJavaPointer(
|
|
||||||
native_factory->CreateVideoEncoder(video_format).release());
|
|
||||||
}
|
|
||||||
|
|
||||||
static webrtc::ScopedJavaLocalRef<jobject>
|
|
||||||
JNI_SoftwareVideoEncoderFactory_GetSupportedCodecs(JNIEnv* env,
|
|
||||||
jlong j_factory) {
|
|
||||||
auto* const native_factory =
|
|
||||||
reinterpret_cast<webrtc::VideoEncoderFactory*>(j_factory);
|
|
||||||
|
|
||||||
return webrtc::NativeToJavaList(env, native_factory->GetSupportedFormats(),
|
|
||||||
&webrtc::jni::SdpVideoFormatToVideoCodecInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace jni
|
|
||||||
} // namespace webrtc
|
|
||||||
Reference in New Issue
Block a user