TweaksConfig 
    This configuration is used as an incubator for experimental features. Tweaks are not officially supported and are not guaranteed to be stable, i.e. their naming, functionality and API can change at any time within the tweaks or when being promoted to an official feature and moved into its final configuration namespace.
Constructors
Types
Properties
Specifies whether the player should try to prepare HLS streams without downloading media segments. This is generally possible if the #EXT-X-STREAM-INF tag contains the CODECS attribute and may speed up startup time.
Specifies whether the player should try to prepare HLS streaming ads without downloading media segments.
When using allowChunklessPreparationForHls the player is unable to determine the timed metadata type present in the HLS stream. By default, the player assumes that the timed metadata is of type ID3. If the timed metadata is known to be of type event message (EMSG), this property can be set to true. If there is no timed metadata in the stream, this property has no effect.
Enables automatic recovery from a stuck video decoder.
Specifies the bandwidth meter and configuration the player should use.
Enables approximate seeking for MP3, ADTS and AMR streams, assuming a constant bitrate. Note: This approximation is a fallback if there is no seek table available.
The timeout for detaching a surface from the player. In seconds. If null, the timeout falls back to the default value of 2.0. Please note, this value might change in future releases.
Some devices have an incorrect implementation of MediaCodec.setOutputSurface. This leads to failure when the surface changes. To prevent failure, the codec will be released and re-instantiated in those scenarios.
Disables the audio tracks when the app is backgrounded by calling Player.onStop or PlayerView.onStop. Audio tracks are re-enabled when the app is foregrounded by calling Player.onStart or PlayerView.onStart. This is a workaround that can be applied to prevent the player from crashing on devices that are known to not clean up audio resources properly when backgrounding the app.
Disables the video tracks when the app is backgrounded by calling Player.onStop or PlayerView.onStop. Video tracks are re-enabled when the app is foregrounded by calling Player.onStart or PlayerView.onStart.
Specifies whether ads are discarded when played over during casting. If disabled (=false) ads are postponed until the cast session is stopped. For IMA VMAP ads, the postponing still might drop single ads, except for the last one held back.
Do not adapt between HLS variants if the next part is a preload hint that isn't of index 0.
Enables automatic retries for DRM license renewal requests.
Specifies whether the PlayerEvent.FrameAboutToBeRendered should be emitted or not.
Specifies whether Hls Interstitials are enabled. Hls Interstitials support is still under development and some functionality is missing or not stable.
Specifies whether the active source should be decoded during ads playback.
A cache instance that is used by the player in read-only mode. Ignored when playing back OfflineSourceConfigs.
Force HLS segment index to increase on quality change.
When switching between video formats (eg: adapting between video qualities) the codec might be recreated due to several reasons. This behaviour can cause brief black screens when switching between video qualities as codec recreation can be slow.
Specifies the HttpRequestType for which the NetworkConfig.preprocessHttpResponseCallback should be invoked.
Specifies if the language property on DASH Representations, HLS Renditions and SmoothStreaming QualityLevels is normalized. If enabled, language properties are normalized to IETF BCP 47 language tags. Examples: - "ENG" is normalized to "en" - "en_us" is normalized to "en-us" - "en-US-x-lvariant-POSIX" is normalized to "en-us-posix"
Specifies the behaviour for determining when the player should fall back to a different resource in case of a load error, given that a fallback resource is available. Even if the fallback config does not match the encountered error, a retry might be still applied.
The interval in which dynamic DASH windows are updated locally. I.e. The rate by which the playback window is moved forward on the timeline.
The maximum duration in seconds of buffered data required for the selected track to switch to one of lower quality.
The minimum duration in seconds of buffered data required for the selected track to switch to one of higher quality.
Controls at which time the subtitles are parsed:
When enabled, small deviations in period start times between successive period snapshots will not cause the old period to be discarded.
The timeout to release the player (triggered by Player.destroy). In seconds. If null, the timeout falls back to the default value of 0.5. Please note, this value might change in future releases.
The callback which can be used to manipulate the retry handling in case of potentially recoverable playback errors.
Enables reusing the IMA AdsLoader across multiple ads and playback sessions for improved ad startup time performance.
The frequency in seconds the TimeChanged will be fired.
Specifies whether a DRM session should be used for clear tracks of type video and audio. Using DRM sessions for clear content avoids the recreation of decoders when transitioning between clear and encrypted sections of content. Default is false.
Specifies whether a DRM session should be used for clear tracks of type video and audio in a clear source that follows after a DRM protected source. In addition, a DRM session will be used for clear periods in a DRM protected source. Using DRM sessions for clear content avoids the recreation of decoders when transitioning between clear and encrypted sections of content. Default is false.
Specifies if the player should always fall back to an extractor matching the file type, if no matching extractor was found. If the fallback is applied, this will ignore potential incompatibilities with streams and thus can result in unstable or failing playback.