Package com.telnyx.webrtc.lib
Class ScreenCapturerAndroid
java.lang.Object
com.telnyx.webrtc.lib.ScreenCapturerAndroid
- All Implemented Interfaces:
VideoCapturer,VideoSink
An implementation of VideoCapturer to capture the screen content as a video stream.
Capturing is done by
MediaProjection on a SurfaceTexture. We interact with this
SurfaceTexture using a SurfaceTextureHelper.
The SurfaceTextureHelper is created by the native code and passed to this capturer in
VideoCapturer.initialize(). On receiving a new frame, this capturer passes it
as a texture to the native code via CapturerObserver.onFrameCaptured(). This takes
place on the HandlerThread of the given SurfaceTextureHelper. When done with each frame,
the native code returns the buffer to the SurfaceTextureHelper to be used for new
frames. At any time, at most one frame is being processed.-
Constructor Summary
ConstructorsConstructorDescriptionScreenCapturerAndroid(Intent mediaProjectionPermissionResultData, MediaProjection.Callback mediaProjectionCallback) Constructs a new Screen Capturer. -
Method Summary
Modifier and TypeMethodDescriptionvoidchangeCaptureFormat(int width, int height, int ignoredFramerate) Changes output video format.voiddispose()Perform any final cleanup here.longvoidinitialize(SurfaceTextureHelper surfaceTextureHelper, Context applicationContext, CapturerObserver capturerObserver) This function is used to initialize the camera thread, the android application context, and the capture observer.booleanvoidonFrame(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.voidStop capturing.
-
Constructor Details
-
ScreenCapturerAndroid
public ScreenCapturerAndroid(Intent mediaProjectionPermissionResultData, 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 Details
-
getMediaProjection
-
initialize
public void initialize(SurfaceTextureHelper surfaceTextureHelper, 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
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()
-