Android: Add helper functions for comparing H264 codecs
These helper functions will be useful when making the legacy video codecs injectable. Bug: webrtc:7925 Change-Id: Id5a480666f07eccc3116d2c2e61803cc4daf7c9f Reviewed-on: https://webrtc-review.googlesource.com/88365 Reviewed-by: Sami Kalliomäki <sakal@webrtc.org> Commit-Queue: Magnus Jedvert <magjed@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23954}
This commit is contained in:

committed by
Commit Bot

parent
3f84f498e4
commit
1045af2989
@ -262,7 +262,6 @@ generate_jni("generated_java_audio_device_module_native_jni") {
|
|||||||
generate_jni("generated_video_jni") {
|
generate_jni("generated_video_jni") {
|
||||||
sources = [
|
sources = [
|
||||||
"api/org/webrtc/EncodedImage.java",
|
"api/org/webrtc/EncodedImage.java",
|
||||||
"api/org/webrtc/HardwareVideoEncoderFactory.java",
|
|
||||||
"api/org/webrtc/MediaCodecVideoDecoder.java",
|
"api/org/webrtc/MediaCodecVideoDecoder.java",
|
||||||
"api/org/webrtc/MediaCodecVideoEncoder.java",
|
"api/org/webrtc/MediaCodecVideoEncoder.java",
|
||||||
"api/org/webrtc/VideoCodecInfo.java",
|
"api/org/webrtc/VideoCodecInfo.java",
|
||||||
@ -278,6 +277,7 @@ generate_jni("generated_video_jni") {
|
|||||||
"api/org/webrtc/VideoSource.java",
|
"api/org/webrtc/VideoSource.java",
|
||||||
"api/org/webrtc/VideoTrack.java",
|
"api/org/webrtc/VideoTrack.java",
|
||||||
"api/org/webrtc/YuvHelper.java",
|
"api/org/webrtc/YuvHelper.java",
|
||||||
|
"src/java/org/webrtc/H264Utils.java",
|
||||||
"src/java/org/webrtc/NV12Buffer.java",
|
"src/java/org/webrtc/NV12Buffer.java",
|
||||||
"src/java/org/webrtc/NV21Buffer.java",
|
"src/java/org/webrtc/NV21Buffer.java",
|
||||||
"src/java/org/webrtc/NativeCapturerObserver.java",
|
"src/java/org/webrtc/NativeCapturerObserver.java",
|
||||||
@ -299,7 +299,7 @@ rtc_static_library("video_jni") {
|
|||||||
"src/jni/androidvideotracksource.h",
|
"src/jni/androidvideotracksource.h",
|
||||||
"src/jni/encodedimage.cc",
|
"src/jni/encodedimage.cc",
|
||||||
"src/jni/encodedimage.h",
|
"src/jni/encodedimage.h",
|
||||||
"src/jni/hardwarevideoencoderfactory.cc",
|
"src/jni/h264utils.cc",
|
||||||
"src/jni/jni_generator_helper.h",
|
"src/jni/jni_generator_helper.h",
|
||||||
"src/jni/nativecapturerobserver.cc",
|
"src/jni/nativecapturerobserver.cc",
|
||||||
"src/jni/nativecapturerobserver.h",
|
"src/jni/nativecapturerobserver.h",
|
||||||
@ -879,6 +879,7 @@ rtc_android_library("video_java") {
|
|||||||
"api/org/webrtc/VideoDecoderFallback.java",
|
"api/org/webrtc/VideoDecoderFallback.java",
|
||||||
"api/org/webrtc/VideoEncoderFallback.java",
|
"api/org/webrtc/VideoEncoderFallback.java",
|
||||||
"src/java/org/webrtc/NV21Buffer.java",
|
"src/java/org/webrtc/NV21Buffer.java",
|
||||||
|
"src/java/org/webrtc/H264Utils.java",
|
||||||
"src/java/org/webrtc/VideoDecoderWrapper.java",
|
"src/java/org/webrtc/VideoDecoderWrapper.java",
|
||||||
"src/java/org/webrtc/VideoEncoderWrapper.java",
|
"src/java/org/webrtc/VideoEncoderWrapper.java",
|
||||||
"src/java/org/webrtc/WrappedNativeI420Buffer.java",
|
"src/java/org/webrtc/WrappedNativeI420Buffer.java",
|
||||||
|
@ -79,15 +79,17 @@ public class HardwareVideoEncoderFactory implements VideoEncoderFactory {
|
|||||||
MediaCodecUtils.ENCODER_COLOR_FORMATS, info.getCapabilitiesForType(mime));
|
MediaCodecUtils.ENCODER_COLOR_FORMATS, info.getCapabilitiesForType(mime));
|
||||||
|
|
||||||
if (type == VideoCodecType.H264) {
|
if (type == VideoCodecType.H264) {
|
||||||
boolean isHighProfile = nativeIsSameH264Profile(input.params,
|
boolean isHighProfile = H264Utils.isSameH264Profile(
|
||||||
MediaCodecUtils.getCodecProperties(type, /* highProfile= */ true))
|
input.params, MediaCodecUtils.getCodecProperties(type, /* highProfile= */ true));
|
||||||
&& isH264HighProfileSupported(info);
|
boolean isBaselineProfile = H264Utils.isSameH264Profile(
|
||||||
boolean isBaselineProfile = nativeIsSameH264Profile(
|
|
||||||
input.params, MediaCodecUtils.getCodecProperties(type, /* highProfile= */ false));
|
input.params, MediaCodecUtils.getCodecProperties(type, /* highProfile= */ false));
|
||||||
|
|
||||||
if (!isHighProfile && !isBaselineProfile) {
|
if (!isHighProfile && !isBaselineProfile) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
if (isHighProfile && !isH264HighProfileSupported(info)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new HardwareVideoEncoder(codecName, type, surfaceColorFormat, yuvColorFormat,
|
return new HardwareVideoEncoder(codecName, type, surfaceColorFormat, yuvColorFormat,
|
||||||
@ -243,7 +245,4 @@ public class HardwareVideoEncoderFactory implements VideoEncoderFactory {
|
|||||||
return enableH264HighProfile && Build.VERSION.SDK_INT > Build.VERSION_CODES.M
|
return enableH264HighProfile && Build.VERSION.SDK_INT > Build.VERSION_CODES.M
|
||||||
&& info.getName().startsWith(EXYNOS_PREFIX);
|
&& info.getName().startsWith(EXYNOS_PREFIX);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native boolean nativeIsSameH264Profile(
|
|
||||||
Map<String, String> params1, Map<String, String> params2);
|
|
||||||
}
|
}
|
||||||
|
52
sdk/android/src/java/org/webrtc/H264Utils.java
Normal file
52
sdk/android/src/java/org/webrtc/H264Utils.java
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2017 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 java.util.Map;
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
/** Container for static helper functions related to dealing with H264 codecs. */
|
||||||
|
class H264Utils {
|
||||||
|
public static final String H264_FMTP_PROFILE_LEVEL_ID = "profile-level-id";
|
||||||
|
public static final String H264_FMTP_LEVEL_ASYMMETRY_ALLOWED = "level-asymmetry-allowed";
|
||||||
|
public static final String H264_FMTP_PACKETIZATION_MODE = "packetization-mode";
|
||||||
|
|
||||||
|
public static final String H264_PROFILE_CONSTRAINED_BASELINE = "42e0";
|
||||||
|
public static final String H264_PROFILE_CONSTRAINED_HIGH = "640c";
|
||||||
|
public static final String H264_LEVEL_3_1 = "1f"; // 31 in hex.
|
||||||
|
public static final String H264_CONSTRAINED_HIGH_3_1 =
|
||||||
|
H264_PROFILE_CONSTRAINED_HIGH + H264_LEVEL_3_1;
|
||||||
|
public static final String H264_CONSTRAINED_BASELINE_3_1 =
|
||||||
|
H264_PROFILE_CONSTRAINED_BASELINE + H264_LEVEL_3_1;
|
||||||
|
|
||||||
|
public static Map<String, String> getDefaultH264Params(boolean isHighProfile) {
|
||||||
|
final Map<String, String> params = new HashMap<>();
|
||||||
|
params.put(VideoCodecInfo.H264_FMTP_LEVEL_ASYMMETRY_ALLOWED, "1");
|
||||||
|
params.put(VideoCodecInfo.H264_FMTP_PACKETIZATION_MODE, "1");
|
||||||
|
params.put(VideoCodecInfo.H264_FMTP_PROFILE_LEVEL_ID,
|
||||||
|
isHighProfile ? VideoCodecInfo.H264_CONSTRAINED_HIGH_3_1
|
||||||
|
: VideoCodecInfo.H264_CONSTRAINED_BASELINE_3_1);
|
||||||
|
return params;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static VideoCodecInfo DEFAULT_H264_BASELINE_PROFILE_CODEC =
|
||||||
|
new VideoCodecInfo("H264", getDefaultH264Params(/* isHighProfile= */ false));
|
||||||
|
public static VideoCodecInfo DEFAULT_H264_HIGH_PROFILE_CODEC =
|
||||||
|
new VideoCodecInfo("H264", getDefaultH264Params(/* isHighProfile= */ true));
|
||||||
|
|
||||||
|
public static boolean isSameH264Profile(
|
||||||
|
Map<String, String> params1, Map<String, String> params2) {
|
||||||
|
return nativeIsSameH264Profile(params1, params2);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static native boolean nativeIsSameH264Profile(
|
||||||
|
Map<String, String> params1, Map<String, String> params2);
|
||||||
|
}
|
@ -84,13 +84,7 @@ class MediaCodecUtils {
|
|||||||
case VP9:
|
case VP9:
|
||||||
return new HashMap<String, String>();
|
return new HashMap<String, String>();
|
||||||
case H264:
|
case H264:
|
||||||
Map<String, String> properties = new HashMap<>();
|
return H264Utils.getDefaultH264Params(highProfile);
|
||||||
properties.put(VideoCodecInfo.H264_FMTP_LEVEL_ASYMMETRY_ALLOWED, "1");
|
|
||||||
properties.put(VideoCodecInfo.H264_FMTP_PACKETIZATION_MODE, "1");
|
|
||||||
properties.put(VideoCodecInfo.H264_FMTP_PROFILE_LEVEL_ID,
|
|
||||||
highProfile ? VideoCodecInfo.H264_CONSTRAINED_HIGH_3_1
|
|
||||||
: VideoCodecInfo.H264_CONSTRAINED_BASELINE_3_1);
|
|
||||||
return properties;
|
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("Unsupported codec: " + type);
|
throw new IllegalArgumentException("Unsupported codec: " + type);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2017 The WebRTC project authors. All Rights Reserved.
|
* Copyright 2018 The WebRTC project authors. All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Use of this source code is governed by a BSD-style license
|
* 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
|
* that can be found in the LICENSE file in the root of the source
|
||||||
@ -8,23 +8,21 @@
|
|||||||
* be found in the AUTHORS file in the root of the source tree.
|
* be found in the AUTHORS file in the root of the source tree.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <jni.h>
|
#include "sdk/android/src/jni/videocodecinfo.h"
|
||||||
|
|
||||||
#include "media/base/h264_profile_level_id.h"
|
#include "common_video/h264/profile_level_id.h"
|
||||||
#include "sdk/android/generated_video_jni/jni/HardwareVideoEncoderFactory_jni.h"
|
#include "sdk/android/generated_video_jni/jni/H264Utils_jni.h"
|
||||||
#include "sdk/android/native_api/jni/java_types.h"
|
|
||||||
#include "sdk/android/src/jni/jni_helpers.h"
|
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
namespace jni {
|
namespace jni {
|
||||||
|
|
||||||
static jboolean JNI_HardwareVideoEncoderFactory_IsSameH264Profile(
|
static jboolean JNI_H264Utils_IsSameH264Profile(
|
||||||
JNIEnv* jni,
|
JNIEnv* env,
|
||||||
const JavaParamRef<jclass>&,
|
const JavaParamRef<jclass>&,
|
||||||
const JavaParamRef<jobject>& params1,
|
const JavaParamRef<jobject>& params1,
|
||||||
const JavaParamRef<jobject>& params2) {
|
const JavaParamRef<jobject>& params2) {
|
||||||
return H264::IsSameH264Profile(JavaToNativeStringMap(jni, params1),
|
return H264::IsSameH264Profile(JavaToNativeStringMap(env, params1),
|
||||||
JavaToNativeStringMap(jni, params2));
|
JavaToNativeStringMap(env, params2));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace jni
|
} // namespace jni
|
Reference in New Issue
Block a user