| Index: webrtc/api/android/java/src/org/webrtc/ScreenCapturerAndroid.java
|
| diff --git a/webrtc/api/android/java/src/org/webrtc/ScreenCapturerAndroid.java b/webrtc/api/android/java/src/org/webrtc/ScreenCapturerAndroid.java
|
| deleted file mode 100644
|
| index 08d34dda8ab3b472b07b83523425969bd76b635e..0000000000000000000000000000000000000000
|
| --- a/webrtc/api/android/java/src/org/webrtc/ScreenCapturerAndroid.java
|
| +++ /dev/null
|
| @@ -1,203 +0,0 @@
|
| -/*
|
| - * Copyright 2016 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.app.Activity;
|
| -import android.content.Context;
|
| -import android.content.Intent;
|
| -import android.hardware.display.DisplayManager;
|
| -import android.hardware.display.VirtualDisplay;
|
| -import android.media.projection.MediaProjection;
|
| -import android.media.projection.MediaProjectionManager;
|
| -import android.view.Surface;
|
| -
|
| -import java.util.ArrayList;
|
| -import java.util.List;
|
| -
|
| -/**
|
| - * An implementation of VideoCapturer to capture the screen content as a video stream.
|
| - * Capturing is done by {@code MediaProjection} on a {@code SurfaceTexture}. We interact with this
|
| - * {@code SurfaceTexture} using a {@code SurfaceTextureHelper}.
|
| - * The {@code SurfaceTextureHelper} is created by the native code and passed to this capturer in
|
| - * {@code VideoCapturer.initialize()}. On receiving a new frame, this capturer passes it
|
| - * as a texture to the native code via {@code CapturerObserver.onTextureFrameCaptured()}. This takes
|
| - * place on the HandlerThread of the given {@code SurfaceTextureHelper}. When done with each frame,
|
| - * the native code returns the buffer to the {@code SurfaceTextureHelper} to be used for new
|
| - * frames. At any time, at most one frame is being processed.
|
| - */
|
| -@TargetApi(21)
|
| -public class ScreenCapturerAndroid
|
| - implements VideoCapturer, SurfaceTextureHelper.OnTextureFrameAvailableListener {
|
| - private static final int DISPLAY_FLAGS =
|
| - DisplayManager.VIRTUAL_DISPLAY_FLAG_PUBLIC | DisplayManager.VIRTUAL_DISPLAY_FLAG_PRESENTATION;
|
| - // DPI for VirtualDisplay, does not seem to matter for us.
|
| - private static final int VIRTUAL_DISPLAY_DPI = 400;
|
| -
|
| - private final Intent mediaProjectionPermissionResultData;
|
| - private final MediaProjection.Callback mediaProjectionCallback;
|
| -
|
| - private int width;
|
| - private int height;
|
| - private VirtualDisplay virtualDisplay;
|
| - private SurfaceTextureHelper surfaceTextureHelper;
|
| - private CapturerObserver capturerObserver;
|
| - private long numCapturedFrames = 0;
|
| - private MediaProjection mediaProjection;
|
| - private boolean isDisposed = false;
|
| - private MediaProjectionManager mediaProjectionManager;
|
| -
|
| - /**
|
| - * Constructs a new Screen Capturer.
|
| - *
|
| - * @param mediaProjectionPermissionResultData the result data of MediaProjection permission
|
| - * activity; the calling app must validate that result code is Activity.RESULT_OK before
|
| - * calling this method.
|
| - * @param mediaProjectionCallback MediaProjection callback to implement application specific
|
| - * logic in events such as when the user revokes a previously granted capture permission.
|
| - **/
|
| - public ScreenCapturerAndroid(Intent mediaProjectionPermissionResultData,
|
| - MediaProjection.Callback mediaProjectionCallback) {
|
| - this.mediaProjectionPermissionResultData = mediaProjectionPermissionResultData;
|
| - this.mediaProjectionCallback = mediaProjectionCallback;
|
| - }
|
| -
|
| - private void checkNotDisposed() {
|
| - if (isDisposed) {
|
| - throw new RuntimeException("capturer is disposed.");
|
| - }
|
| - }
|
| -
|
| - @Override
|
| - public synchronized void initialize(final SurfaceTextureHelper surfaceTextureHelper,
|
| - final Context applicationContext, final VideoCapturer.CapturerObserver capturerObserver) {
|
| - checkNotDisposed();
|
| -
|
| - if (capturerObserver == null) {
|
| - throw new RuntimeException("capturerObserver not set.");
|
| - }
|
| - this.capturerObserver = capturerObserver;
|
| -
|
| - if (surfaceTextureHelper == null) {
|
| - throw new RuntimeException("surfaceTextureHelper not set.");
|
| - }
|
| - this.surfaceTextureHelper = surfaceTextureHelper;
|
| -
|
| - mediaProjectionManager = (MediaProjectionManager) applicationContext.getSystemService(
|
| - Context.MEDIA_PROJECTION_SERVICE);
|
| - }
|
| -
|
| - @Override
|
| - public synchronized void startCapture(
|
| - final int width, final int height, final int ignoredFramerate) {
|
| - checkNotDisposed();
|
| -
|
| - this.width = width;
|
| - this.height = height;
|
| -
|
| - mediaProjection = mediaProjectionManager.getMediaProjection(
|
| - Activity.RESULT_OK, mediaProjectionPermissionResultData);
|
| -
|
| - // Let MediaProjection callback use the SurfaceTextureHelper thread.
|
| - mediaProjection.registerCallback(mediaProjectionCallback, surfaceTextureHelper.getHandler());
|
| -
|
| - createVirtualDisplay();
|
| - capturerObserver.onCapturerStarted(true);
|
| - surfaceTextureHelper.startListening(ScreenCapturerAndroid.this);
|
| - }
|
| -
|
| - @Override
|
| - public synchronized void stopCapture() {
|
| - checkNotDisposed();
|
| - ThreadUtils.invokeAtFrontUninterruptibly(surfaceTextureHelper.getHandler(), new Runnable() {
|
| - @Override
|
| - public void run() {
|
| - surfaceTextureHelper.stopListening();
|
| - capturerObserver.onCapturerStopped();
|
| -
|
| - if (virtualDisplay != null) {
|
| - virtualDisplay.release();
|
| - virtualDisplay = null;
|
| - }
|
| -
|
| - if (mediaProjection != null) {
|
| - // Unregister the callback before stopping, otherwise the callback recursively
|
| - // calls this method.
|
| - mediaProjection.unregisterCallback(mediaProjectionCallback);
|
| - mediaProjection.stop();
|
| - mediaProjection = null;
|
| - }
|
| - }
|
| - });
|
| - }
|
| -
|
| - @Override
|
| - public synchronized void dispose() {
|
| - isDisposed = true;
|
| - }
|
| -
|
| - /**
|
| - * Changes output video format. This method can be used to scale the output
|
| - * video, or to change orientation when the captured screen is rotated for example.
|
| - *
|
| - * @param width new output video width
|
| - * @param height new output video height
|
| - * @param ignoredFramerate ignored
|
| - */
|
| - @Override
|
| - public synchronized void changeCaptureFormat(
|
| - final int width, final int height, final int ignoredFramerate) {
|
| - checkNotDisposed();
|
| -
|
| - this.width = width;
|
| - this.height = height;
|
| -
|
| - if (virtualDisplay == null) {
|
| - // Capturer is stopped, the virtual display will be created in startCaptuer().
|
| - return;
|
| - }
|
| -
|
| - // Create a new virtual display on the surfaceTextureHelper thread to avoid interference
|
| - // with frame processing, which happens on the same thread (we serialize events by running
|
| - // them on the same thread).
|
| - ThreadUtils.invokeAtFrontUninterruptibly(surfaceTextureHelper.getHandler(), new Runnable() {
|
| - @Override
|
| - public void run() {
|
| - virtualDisplay.release();
|
| - createVirtualDisplay();
|
| - }
|
| - });
|
| - }
|
| -
|
| - private void createVirtualDisplay() {
|
| - surfaceTextureHelper.getSurfaceTexture().setDefaultBufferSize(width, height);
|
| - virtualDisplay = mediaProjection.createVirtualDisplay("WebRTC_ScreenCapture", width, height,
|
| - VIRTUAL_DISPLAY_DPI, DISPLAY_FLAGS, new Surface(surfaceTextureHelper.getSurfaceTexture()),
|
| - null /* callback */, null /* callback handler */);
|
| - }
|
| -
|
| - // This is called on the internal looper thread of {@Code SurfaceTextureHelper}.
|
| - @Override
|
| - public void onTextureFrameAvailable(int oesTextureId, float[] transformMatrix, long timestampNs) {
|
| - numCapturedFrames++;
|
| - capturerObserver.onTextureFrameCaptured(
|
| - width, height, oesTextureId, transformMatrix, 0 /* rotation */, timestampNs);
|
| - }
|
| -
|
| - @Override
|
| - public boolean isScreencast() {
|
| - return true;
|
| - }
|
| -
|
| - public long getNumCapturedFrames() {
|
| - return numCapturedFrames;
|
| - }
|
| -}
|
|
|