mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-17 07:37:51 +01:00

In the SoftwareVideoCodecFactories, don't try to create VP9 encoder or decoder if WebRTC was built without support for it. Bug: None Change-Id: I09b87fdcf798c763310af4998dbea8011843010d Reviewed-on: https://webrtc-review.googlesource.com/22924 Reviewed-by: Sami Kalliomäki <sakal@webrtc.org> Commit-Queue: Anders Carlsson <andersc@webrtc.org> Cr-Commit-Position: refs/heads/master@{#20672}
45 lines
1.3 KiB
Java
45 lines
1.3 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 java.util.ArrayList;
|
|
import java.util.HashMap;
|
|
import java.util.List;
|
|
|
|
public class SoftwareVideoEncoderFactory implements VideoEncoderFactory {
|
|
@Override
|
|
public VideoEncoder createEncoder(VideoCodecInfo info) {
|
|
if (info.name.equalsIgnoreCase("VP8")) {
|
|
return new VP8Encoder();
|
|
}
|
|
if (info.name.equalsIgnoreCase("VP9") && VP9Encoder.isSupported()) {
|
|
return new VP9Encoder();
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public VideoCodecInfo[] getSupportedCodecs() {
|
|
return supportedCodecs();
|
|
}
|
|
|
|
static VideoCodecInfo[] supportedCodecs() {
|
|
List<VideoCodecInfo> codecs = new ArrayList<VideoCodecInfo>();
|
|
|
|
codecs.add(new VideoCodecInfo("VP8", new HashMap<>()));
|
|
if (VP9Encoder.isSupported()) {
|
|
codecs.add(new VideoCodecInfo("VP9", new HashMap<>()));
|
|
}
|
|
|
|
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
|
|
}
|
|
}
|