Package tvi.webrtc
Class ScreenCapturerAndroid
- java.lang.Object
-
- tvi.webrtc.ScreenCapturerAndroid
-
- All Implemented Interfaces:
VideoCapturer,VideoSink
public class ScreenCapturerAndroid extends java.lang.Object implements VideoCapturer, VideoSink
An implementation of VideoCapturer to capture the screen content as a video stream. Capturing is done byMediaProjectionon aSurfaceTexture. We interact with thisSurfaceTextureusing aSurfaceTextureHelper. TheSurfaceTextureHelperis created by the native code and passed to this capturer inVideoCapturer.initialize(). On receiving a new frame, this capturer passes it as a texture to the native code viaCapturerObserver.onFrameCaptured(). This takes place on the HandlerThread of the givenSurfaceTextureHelper. When done with each frame, the native code returns the buffer to theSurfaceTextureHelperto be used for new frames. At any time, at most one frame is being processed. Note: This class is only supported on Android Lollipop and above.
-
-
Constructor Summary
Constructors Constructor Description ScreenCapturerAndroid(android.content.Intent mediaProjectionPermissionResultData, android.media.projection.MediaProjection.Callback mediaProjectionCallback)Constructs a new Screen Capturer.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidchangeCaptureFormat(int width, int height, int ignoredFramerate)Changes output video format.voiddispose()Perform any final cleanup here.android.media.projection.MediaProjectiongetMediaProjection()longgetNumCapturedFrames()voidinitialize(SurfaceTextureHelper surfaceTextureHelper, android.content.Context applicationContext, CapturerObserver capturerObserver)This function is used to initialize the camera thread, the android application context, and the capture observer.booleanisScreencast()voidonFrame(VideoFrame frame)Implementations should call frame.retain() if they need to hold a reference to the frame after this function returns.voidstartCapture(int width, int height, int ignoredFramerate)Start capturing frames in a format that is as close as possible towidth x heightandframerate.voidstopCapture()Stop capturing.
-
-
-
Constructor Detail
-
ScreenCapturerAndroid
public ScreenCapturerAndroid(android.content.Intent mediaProjectionPermissionResultData, android.media.projection.MediaProjection.Callback mediaProjectionCallback)Constructs a new Screen Capturer.- Parameters:
mediaProjectionPermissionResultData- the result data of MediaProjection permission activity; the calling app must validate that result code is Activity.RESULT_OK before calling this method.mediaProjectionCallback- MediaProjection callback to implement application specific logic in events such as when the user revokes a previously granted capture permission.
-
-
Method Detail
-
getMediaProjection
@Nullable public android.media.projection.MediaProjection getMediaProjection()
-
initialize
public void initialize(SurfaceTextureHelper surfaceTextureHelper, android.content.Context applicationContext, CapturerObserver capturerObserver)
Description copied from interface:VideoCapturerThis function is used to initialize the camera thread, the android application context, and the capture observer. It will be called only once and before any startCapture() request. The camera thread is guaranteed to be valid until dispose() is called. If the VideoCapturer wants to deliver texture frames, it should do this by rendering on the SurfaceTexture insurfaceTextureHelper, register itself as a listener, and forward the frames to CapturerObserver.onFrameCaptured(). The caller still has ownership ofsurfaceTextureHelperand is responsible for making sure surfaceTextureHelper.dispose() is called. This also means that the caller can reuse the SurfaceTextureHelper to initialize a new VideoCapturer once the previous VideoCapturer has been disposed.- Specified by:
initializein interfaceVideoCapturer
-
startCapture
public void startCapture(int width, int height, int ignoredFramerate)Description copied from interface:VideoCapturerStart capturing frames in a format that is as close as possible towidth x heightandframerate.- Specified by:
startCapturein interfaceVideoCapturer
-
stopCapture
public void stopCapture()
Description copied from interface:VideoCapturerStop capturing. This function should block until capture is actually stopped.- Specified by:
stopCapturein interfaceVideoCapturer
-
dispose
public void dispose()
Description copied from interface:VideoCapturerPerform any final cleanup here. No more capturing will be done after this call.- Specified by:
disposein interfaceVideoCapturer
-
changeCaptureFormat
public void changeCaptureFormat(int width, int height, int ignoredFramerate)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.- Specified by:
changeCaptureFormatin interfaceVideoCapturer- Parameters:
width- new output video widthheight- new output video heightignoredFramerate- ignored
-
onFrame
public void onFrame(VideoFrame frame)
Description copied from interface:VideoSinkImplementations should call frame.retain() if they need to hold a reference to the frame after this function returns. Each call to retain() should be followed by a call to frame.release() when the reference is no longer needed.
-
isScreencast
public boolean isScreencast()
- Specified by:
isScreencastin interfaceVideoCapturer- Returns:
- true if-and-only-if this is a screen capturer.
-
getNumCapturedFrames
public long getNumCapturedFrames()
-
-