mirror of
https://github.com/samsonjs/media.git
synced 2026-04-27 15:07:40 +00:00
Add interface MediaCodecInputBufferEnqueuer
MediaCodecInputBufferEnqueuer wraps MediaCodec queue operations. PiperOrigin-RevId: 294182717
This commit is contained in:
parent
016bacd178
commit
d8802df62e
3 changed files with 115 additions and 3 deletions
|
|
@ -52,6 +52,7 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
private long pendingFlushCount;
|
private long pendingFlushCount;
|
||||||
private @State int state;
|
private @State int state;
|
||||||
private Runnable codecStartRunnable;
|
private Runnable codecStartRunnable;
|
||||||
|
private final MediaCodecInputBufferEnqueuer bufferEnqueuer;
|
||||||
@Nullable private IllegalStateException internalException;
|
@Nullable private IllegalStateException internalException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -75,6 +76,7 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
this.handlerThread = handlerThread;
|
this.handlerThread = handlerThread;
|
||||||
state = STATE_CREATED;
|
state = STATE_CREATED;
|
||||||
codecStartRunnable = codec::start;
|
codecStartRunnable = codec::start;
|
||||||
|
bufferEnqueuer = new SynchronousMediaCodecBufferEnqueuer(this.codec);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -82,6 +84,7 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
handlerThread.start();
|
handlerThread.start();
|
||||||
handler = new Handler(handlerThread.getLooper());
|
handler = new Handler(handlerThread.getLooper());
|
||||||
codec.setCallback(this, handler);
|
codec.setCallback(this, handler);
|
||||||
|
bufferEnqueuer.start();
|
||||||
codecStartRunnable.run();
|
codecStartRunnable.run();
|
||||||
state = STATE_STARTED;
|
state = STATE_STARTED;
|
||||||
}
|
}
|
||||||
|
|
@ -91,7 +94,7 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
int index, int offset, int size, long presentationTimeUs, int flags) {
|
int index, int offset, int size, long presentationTimeUs, int flags) {
|
||||||
// This method does not need to be synchronized because it does not interact with the
|
// This method does not need to be synchronized because it does not interact with the
|
||||||
// mediaCodecAsyncCallback.
|
// mediaCodecAsyncCallback.
|
||||||
codec.queueInputBuffer(index, offset, size, presentationTimeUs, flags);
|
bufferEnqueuer.queueInputBuffer(index, offset, size, presentationTimeUs, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -99,7 +102,7 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
int index, int offset, MediaCodec.CryptoInfo info, long presentationTimeUs, int flags) {
|
int index, int offset, MediaCodec.CryptoInfo info, long presentationTimeUs, int flags) {
|
||||||
// This method does not need to be synchronized because it does not interact with the
|
// This method does not need to be synchronized because it does not interact with the
|
||||||
// mediaCodecAsyncCallback.
|
// mediaCodecAsyncCallback.
|
||||||
codec.queueSecureInputBuffer(index, offset, info, presentationTimeUs, flags);
|
bufferEnqueuer.queueSecureInputBuffer(index, offset, info, presentationTimeUs, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
@ -129,6 +132,7 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized void flush() {
|
public synchronized void flush() {
|
||||||
|
bufferEnqueuer.flush();
|
||||||
codec.flush();
|
codec.flush();
|
||||||
++pendingFlushCount;
|
++pendingFlushCount;
|
||||||
Util.castNonNull(handler).post(this::onFlushCompleted);
|
Util.castNonNull(handler).post(this::onFlushCompleted);
|
||||||
|
|
@ -137,10 +141,10 @@ import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
||||||
@Override
|
@Override
|
||||||
public synchronized void shutdown() {
|
public synchronized void shutdown() {
|
||||||
if (state == STATE_STARTED) {
|
if (state == STATE_STARTED) {
|
||||||
|
bufferEnqueuer.shutdown();
|
||||||
handlerThread.quit();
|
handlerThread.quit();
|
||||||
mediaCodecAsyncCallback.flush();
|
mediaCodecAsyncCallback.flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
state = STATE_SHUT_DOWN;
|
state = STATE_SHUT_DOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,51 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2020 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.google.android.exoplayer2.mediacodec;
|
||||||
|
|
||||||
|
import android.media.MediaCodec;
|
||||||
|
|
||||||
|
/** Abstracts operations to enqueue input buffer on a {@link android.media.MediaCodec}. */
|
||||||
|
interface MediaCodecInputBufferEnqueuer {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Starts this instance.
|
||||||
|
*
|
||||||
|
* <p>Call this method after creating an instance.
|
||||||
|
*/
|
||||||
|
void start();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Submits an input buffer for decoding.
|
||||||
|
*
|
||||||
|
* @see android.media.MediaCodec#queueInputBuffer
|
||||||
|
*/
|
||||||
|
void queueInputBuffer(int index, int offset, int size, long presentationTimeUs, int flags);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Submits an input buffer that potentially contains encrypted data for decoding.
|
||||||
|
*
|
||||||
|
* @see MediaCodec#queueSecureInputBuffer
|
||||||
|
*/
|
||||||
|
void queueSecureInputBuffer(
|
||||||
|
int index, int offset, MediaCodec.CryptoInfo info, long presentationTimeUs, int flags);
|
||||||
|
|
||||||
|
/** Flushes the instance. */
|
||||||
|
void flush();
|
||||||
|
|
||||||
|
/** Shut down the instance. Make sure to call this method to release its internal resources. */
|
||||||
|
void shutdown();
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2020 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.google.android.exoplayer2.mediacodec;
|
||||||
|
|
||||||
|
import android.media.MediaCodec;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link MediaCodecInputBufferEnqueuer} that forwards queueing methods directly to {@link
|
||||||
|
* MediaCodec}.
|
||||||
|
*/
|
||||||
|
class SynchronousMediaCodecBufferEnqueuer implements MediaCodecInputBufferEnqueuer {
|
||||||
|
private final MediaCodec codec;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance that queues input buffers on the specified {@link MediaCodec}.
|
||||||
|
*
|
||||||
|
* @param codec The {@link MediaCodec} to submit input buffers to.
|
||||||
|
*/
|
||||||
|
SynchronousMediaCodecBufferEnqueuer(MediaCodec codec) {
|
||||||
|
this.codec = codec;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void start() {}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void queueInputBuffer(
|
||||||
|
int index, int offset, int size, long presentationTimeUs, int flags) {
|
||||||
|
codec.queueInputBuffer(index, offset, size, presentationTimeUs, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void queueSecureInputBuffer(
|
||||||
|
int index, int offset, MediaCodec.CryptoInfo info, long presentationTimeUs, int flags) {
|
||||||
|
codec.queueSecureInputBuffer(index, offset, info, presentationTimeUs, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void flush() {}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void shutdown() {}
|
||||||
|
}
|
||||||
Loading…
Reference in a new issue