Class DecoderInputBuffer

  • Direct Known Subclasses:
    MetadataInputBuffer, SubtitleInputBuffer

    @Deprecated
    public class DecoderInputBuffer
    extends Buffer
    Deprecated.
    com.google.android.exoplayer2 is deprecated. Please migrate to androidx.media3 (which contains the same ExoPlayer code). See the migration guide for more details, including a script to help with the migration.
    Holds input for a decoder.
    • Field Detail

      • BUFFER_REPLACEMENT_MODE_DISABLED

        public static final int BUFFER_REPLACEMENT_MODE_DISABLED
        Deprecated.
        Disallows buffer replacement.
        See Also:
        Constant Field Values
      • format

        @Nullable
        public Format format
        Deprecated.
        The Format.
      • data

        @Nullable
        public ByteBuffer data
        Deprecated.
        The buffer's data, or null if no data has been set.
      • waitingForKeys

        public boolean waitingForKeys
        Deprecated.
        Whether the last attempt to read a sample into this buffer failed due to not yet having the DRM keys associated with the next sample.
      • timeUs

        public long timeUs
        Deprecated.
        The time at which the sample should be presented.
      • supplementalData

        @Nullable
        public ByteBuffer supplementalData
        Deprecated.
        Supplemental data related to the buffer, if Buffer.hasSupplementalData() returns true. If present, the buffer is populated with supplemental data from position 0 to its limit.
    • Constructor Detail

      • DecoderInputBuffer

        public DecoderInputBuffer​(@com.google.android.exoplayer2.decoder.DecoderInputBuffer.BufferReplacementMode int bufferReplacementMode)
        Deprecated.
        Creates a new instance.
        Parameters:
        bufferReplacementMode - The DecoderInputBuffer.BufferReplacementMode replacement mode.
      • DecoderInputBuffer

        public DecoderInputBuffer​(@com.google.android.exoplayer2.decoder.DecoderInputBuffer.BufferReplacementMode int bufferReplacementMode,
                                  int paddingSize)
        Deprecated.
        Creates a new instance.
        Parameters:
        bufferReplacementMode - The DecoderInputBuffer.BufferReplacementMode replacement mode.
        paddingSize - If non-zero, ensureSpaceForWrite(int) will ensure that the buffer is this number of bytes larger than the requested length. This can be useful for decoders that consume data in fixed size blocks, for efficiency. Setting the padding size to the decoder's fixed read size is necessary to prevent such a decoder from trying to read beyond the end of the buffer.
    • Method Detail

      • newNoDataInstance

        public static DecoderInputBuffer newNoDataInstance()
        Deprecated.
        Returns a new instance that's not able to hold any data.
      • resetSupplementalData

        @EnsuresNonNull("supplementalData")
        public void resetSupplementalData​(int length)
        Deprecated.
        Clears supplementalData and ensures that it's large enough to accommodate length bytes.
        Parameters:
        length - The length of the supplemental data that must be accommodated, in bytes.
      • ensureSpaceForWrite

        @EnsuresNonNull("data")
        public void ensureSpaceForWrite​(int length)
        Deprecated.
        Ensures that data is large enough to accommodate a write of a given length at its current position.

        If the capacity of data is sufficient this method does nothing. If the capacity is insufficient then an attempt is made to replace data with a new ByteBuffer whose capacity is sufficient. Data up to the current position is copied to the new buffer.

        Parameters:
        length - The length of the write that must be accommodated, in bytes.
        Throws:
        DecoderInputBuffer.InsufficientCapacityException - If there is insufficient capacity to accommodate the write and bufferReplacementMode is BUFFER_REPLACEMENT_MODE_DISABLED.
      • isEncrypted

        public final boolean isEncrypted()
        Deprecated.
        Returns whether the C.BUFFER_FLAG_ENCRYPTED flag is set.
      • clear

        public void clear()
        Deprecated.
        Description copied from class: Buffer
        Clears the buffer.
        Overrides:
        clear in class Buffer