Bug: webrtc:13573 Change-Id: If2948cf144e0b670f4fa6fabb06e2a14b4a8e281 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/279561 Commit-Queue: Philip Eliasson <philipel@webrtc.org> Reviewed-by: Xavier Lepaul <xalep@webrtc.org> Cr-Commit-Position: refs/heads/main@{#38430}
51 lines
1.5 KiB
Java
51 lines
1.5 KiB
Java
/*
|
|
* 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 androidx.annotation.Nullable;
|
|
import java.util.ArrayList;
|
|
import java.util.HashMap;
|
|
import java.util.List;
|
|
|
|
public class SoftwareVideoEncoderFactory implements VideoEncoderFactory {
|
|
@Nullable
|
|
@Override
|
|
public VideoEncoder createEncoder(VideoCodecInfo codecInfo) {
|
|
String codecName = codecInfo.getName();
|
|
|
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.VP8.name())) {
|
|
return new LibvpxVp8Encoder();
|
|
}
|
|
if (codecName.equalsIgnoreCase(VideoCodecMimeType.VP9.name())
|
|
&& LibvpxVp9Encoder.nativeIsSupported()) {
|
|
return new LibvpxVp9Encoder();
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public VideoCodecInfo[] getSupportedCodecs() {
|
|
return supportedCodecs();
|
|
}
|
|
|
|
static VideoCodecInfo[] supportedCodecs() {
|
|
List<VideoCodecInfo> codecs = new ArrayList<VideoCodecInfo>();
|
|
|
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.VP8.name(), new HashMap<>()));
|
|
if (LibvpxVp9Encoder.nativeIsSupported()) {
|
|
codecs.add(new VideoCodecInfo(VideoCodecMimeType.VP9.name(), new HashMap<>()));
|
|
}
|
|
|
|
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
|
|
}
|
|
}
|