| Index: webrtc/api/java/android/org/webrtc/EglBase14.java
|
| diff --git a/webrtc/api/java/android/org/webrtc/EglBase14.java b/webrtc/api/java/android/org/webrtc/EglBase14.java
|
| deleted file mode 100644
|
| index 71d6d99873616c2dccd36a4f29170caa1641ac32..0000000000000000000000000000000000000000
|
| --- a/webrtc/api/java/android/org/webrtc/EglBase14.java
|
| +++ /dev/null
|
| @@ -1,258 +0,0 @@
|
| -/*
|
| - * Copyright 2015 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 android.annotation.TargetApi;
|
| -import android.graphics.SurfaceTexture;
|
| -import android.opengl.EGL14;
|
| -import android.opengl.EGLConfig;
|
| -import android.opengl.EGLContext;
|
| -import android.opengl.EGLDisplay;
|
| -import android.opengl.EGLExt;
|
| -import android.opengl.EGLSurface;
|
| -import android.view.Surface;
|
| -
|
| -import org.webrtc.Logging;
|
| -
|
| -/**
|
| - * Holds EGL state and utility methods for handling an EGL14 EGLContext, an EGLDisplay,
|
| - * and an EGLSurface.
|
| - */
|
| -@TargetApi(18)
|
| -public final class EglBase14 extends EglBase {
|
| - private static final String TAG = "EglBase14";
|
| - private static final int EGLExt_SDK_VERSION = android.os.Build.VERSION_CODES.JELLY_BEAN_MR2;
|
| - private static final int CURRENT_SDK_VERSION = android.os.Build.VERSION.SDK_INT;
|
| - private EGLContext eglContext;
|
| - private EGLConfig eglConfig;
|
| - private EGLDisplay eglDisplay;
|
| - private EGLSurface eglSurface = EGL14.EGL_NO_SURFACE;
|
| -
|
| - // EGL 1.4 is supported from API 17. But EGLExt that is used for setting presentation
|
| - // time stamp on a surface is supported from 18 so we require 18.
|
| - public static boolean isEGL14Supported() {
|
| - Logging.d(TAG, "SDK version: " + CURRENT_SDK_VERSION
|
| - + ". isEGL14Supported: " + (CURRENT_SDK_VERSION >= EGLExt_SDK_VERSION));
|
| - return (CURRENT_SDK_VERSION >= EGLExt_SDK_VERSION);
|
| - }
|
| -
|
| - public static class Context extends EglBase.Context {
|
| - private final android.opengl.EGLContext egl14Context;
|
| -
|
| - public Context(android.opengl.EGLContext eglContext) {
|
| - this.egl14Context = eglContext;
|
| - }
|
| - }
|
| -
|
| - // Create a new context with the specified config type, sharing data with sharedContext.
|
| - // |sharedContext| may be null.
|
| - public EglBase14(EglBase14.Context sharedContext, int[] configAttributes) {
|
| - eglDisplay = getEglDisplay();
|
| - eglConfig = getEglConfig(eglDisplay, configAttributes);
|
| - eglContext = createEglContext(sharedContext, eglDisplay, eglConfig);
|
| - }
|
| -
|
| - // Create EGLSurface from the Android Surface.
|
| - @Override
|
| - public void createSurface(Surface surface) {
|
| - createSurfaceInternal(surface);
|
| - }
|
| -
|
| - // Create EGLSurface from the Android SurfaceTexture.
|
| - @Override
|
| - public void createSurface(SurfaceTexture surfaceTexture) {
|
| - createSurfaceInternal(surfaceTexture);
|
| - }
|
| -
|
| - // Create EGLSurface from either Surface or SurfaceTexture.
|
| - private void createSurfaceInternal(Object surface) {
|
| - if (!(surface instanceof Surface) && !(surface instanceof SurfaceTexture)) {
|
| - throw new IllegalStateException("Input must be either a Surface or SurfaceTexture");
|
| - }
|
| - checkIsNotReleased();
|
| - if (eglSurface != EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException("Already has an EGLSurface");
|
| - }
|
| - int[] surfaceAttribs = {EGL14.EGL_NONE};
|
| - eglSurface = EGL14.eglCreateWindowSurface(eglDisplay, eglConfig, surface, surfaceAttribs, 0);
|
| - if (eglSurface == EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException("Failed to create window surface");
|
| - }
|
| - }
|
| -
|
| - @Override
|
| - public void createDummyPbufferSurface() {
|
| - createPbufferSurface(1, 1);
|
| - }
|
| -
|
| - @Override
|
| - public void createPbufferSurface(int width, int height) {
|
| - checkIsNotReleased();
|
| - if (eglSurface != EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException("Already has an EGLSurface");
|
| - }
|
| - int[] surfaceAttribs = {EGL14.EGL_WIDTH, width, EGL14.EGL_HEIGHT, height, EGL14.EGL_NONE};
|
| - eglSurface = EGL14.eglCreatePbufferSurface(eglDisplay, eglConfig, surfaceAttribs, 0);
|
| - if (eglSurface == EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException(
|
| - "Failed to create pixel buffer surface with size: " + width + "x" + height);
|
| - }
|
| - }
|
| -
|
| - @Override
|
| - public Context getEglBaseContext() {
|
| - return new EglBase14.Context(eglContext);
|
| - }
|
| -
|
| - @Override
|
| - public boolean hasSurface() {
|
| - return eglSurface != EGL14.EGL_NO_SURFACE;
|
| - }
|
| -
|
| - @Override
|
| - public int surfaceWidth() {
|
| - final int widthArray[] = new int[1];
|
| - EGL14.eglQuerySurface(eglDisplay, eglSurface, EGL14.EGL_WIDTH, widthArray, 0);
|
| - return widthArray[0];
|
| - }
|
| -
|
| - @Override
|
| - public int surfaceHeight() {
|
| - final int heightArray[] = new int[1];
|
| - EGL14.eglQuerySurface(eglDisplay, eglSurface, EGL14.EGL_HEIGHT, heightArray, 0);
|
| - return heightArray[0];
|
| - }
|
| -
|
| - @Override
|
| - public void releaseSurface() {
|
| - if (eglSurface != EGL14.EGL_NO_SURFACE) {
|
| - EGL14.eglDestroySurface(eglDisplay, eglSurface);
|
| - eglSurface = EGL14.EGL_NO_SURFACE;
|
| - }
|
| - }
|
| -
|
| - private void checkIsNotReleased() {
|
| - if (eglDisplay == EGL14.EGL_NO_DISPLAY || eglContext == EGL14.EGL_NO_CONTEXT
|
| - || eglConfig == null) {
|
| - throw new RuntimeException("This object has been released");
|
| - }
|
| - }
|
| -
|
| - @Override
|
| - public void release() {
|
| - checkIsNotReleased();
|
| - releaseSurface();
|
| - detachCurrent();
|
| - EGL14.eglDestroyContext(eglDisplay, eglContext);
|
| - EGL14.eglReleaseThread();
|
| - EGL14.eglTerminate(eglDisplay);
|
| - eglContext = EGL14.EGL_NO_CONTEXT;
|
| - eglDisplay = EGL14.EGL_NO_DISPLAY;
|
| - eglConfig = null;
|
| - }
|
| -
|
| - @Override
|
| - public void makeCurrent() {
|
| - checkIsNotReleased();
|
| - if (eglSurface == EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException("No EGLSurface - can't make current");
|
| - }
|
| - synchronized (EglBase.lock) {
|
| - if (!EGL14.eglMakeCurrent(eglDisplay, eglSurface, eglSurface, eglContext)) {
|
| - throw new RuntimeException("eglMakeCurrent failed");
|
| - }
|
| - }
|
| - }
|
| -
|
| - // Detach the current EGL context, so that it can be made current on another thread.
|
| - @Override
|
| - public void detachCurrent() {
|
| - synchronized (EglBase.lock) {
|
| - if (!EGL14.eglMakeCurrent(
|
| - eglDisplay, EGL14.EGL_NO_SURFACE, EGL14.EGL_NO_SURFACE, EGL14.EGL_NO_CONTEXT)) {
|
| - throw new RuntimeException("eglDetachCurrent failed");
|
| - }
|
| - }
|
| - }
|
| -
|
| - @Override
|
| - public void swapBuffers() {
|
| - checkIsNotReleased();
|
| - if (eglSurface == EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException("No EGLSurface - can't swap buffers");
|
| - }
|
| - synchronized (EglBase.lock) {
|
| - EGL14.eglSwapBuffers(eglDisplay, eglSurface);
|
| - }
|
| - }
|
| -
|
| - public void swapBuffers(long timeStampNs) {
|
| - checkIsNotReleased();
|
| - if (eglSurface == EGL14.EGL_NO_SURFACE) {
|
| - throw new RuntimeException("No EGLSurface - can't swap buffers");
|
| - }
|
| - synchronized (EglBase.lock) {
|
| - // See https://android.googlesource.com/platform/frameworks/native/+/tools_r22.2/opengl/specs/EGL_ANDROID_presentation_time.txt
|
| - EGLExt.eglPresentationTimeANDROID(eglDisplay, eglSurface, timeStampNs);
|
| - EGL14.eglSwapBuffers(eglDisplay, eglSurface);
|
| - }
|
| - }
|
| -
|
| - // Return an EGLDisplay, or die trying.
|
| - private static EGLDisplay getEglDisplay() {
|
| - EGLDisplay eglDisplay = EGL14.eglGetDisplay(EGL14.EGL_DEFAULT_DISPLAY);
|
| - if (eglDisplay == EGL14.EGL_NO_DISPLAY) {
|
| - throw new RuntimeException("Unable to get EGL14 display");
|
| - }
|
| - int[] version = new int[2];
|
| - if (!EGL14.eglInitialize(eglDisplay, version, 0, version, 1)) {
|
| - throw new RuntimeException("Unable to initialize EGL14");
|
| - }
|
| - return eglDisplay;
|
| - }
|
| -
|
| - // Return an EGLConfig, or die trying.
|
| - private static EGLConfig getEglConfig(EGLDisplay eglDisplay, int[] configAttributes) {
|
| - EGLConfig[] configs = new EGLConfig[1];
|
| - int[] numConfigs = new int[1];
|
| - if (!EGL14.eglChooseConfig(
|
| - eglDisplay, configAttributes, 0, configs, 0, configs.length, numConfigs, 0)) {
|
| - throw new RuntimeException("eglChooseConfig failed");
|
| - }
|
| - if (numConfigs[0] <= 0) {
|
| - throw new RuntimeException("Unable to find any matching EGL config");
|
| - }
|
| - final EGLConfig eglConfig = configs[0];
|
| - if (eglConfig == null) {
|
| - throw new RuntimeException("eglChooseConfig returned null");
|
| - }
|
| - return eglConfig;
|
| - }
|
| -
|
| - // Return an EGLConfig, or die trying.
|
| - private static EGLContext createEglContext(
|
| - EglBase14.Context sharedContext, EGLDisplay eglDisplay, EGLConfig eglConfig) {
|
| - if (sharedContext != null && sharedContext.egl14Context == EGL14.EGL_NO_CONTEXT) {
|
| - throw new RuntimeException("Invalid sharedContext");
|
| - }
|
| - int[] contextAttributes = {EGL14.EGL_CONTEXT_CLIENT_VERSION, 2, EGL14.EGL_NONE};
|
| - EGLContext rootContext =
|
| - sharedContext == null ? EGL14.EGL_NO_CONTEXT : sharedContext.egl14Context;
|
| - final EGLContext eglContext;
|
| - synchronized (EglBase.lock) {
|
| - eglContext = EGL14.eglCreateContext(eglDisplay, eglConfig, rootContext, contextAttributes, 0);
|
| - }
|
| - if (eglContext == EGL14.EGL_NO_CONTEXT) {
|
| - throw new RuntimeException("Failed to create EGL context");
|
| - }
|
| - return eglContext;
|
| - }
|
| -}
|
|
|