HardwareVideoDecoder2.smali
.class public Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Landroid/graphics/SurfaceTexture$OnFrameAvailableListener;
# annotations
.annotation runtime Lcom/tencent/liteav/base/annotations/JNINamespace;
value = "liteav::video"
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;
}
.end annotation
# static fields
.field private static final DRAIN_ERROR:I = -0x1
.field private static final DRAIN_SUCCESS:I = 0x0
.field private static final DRAIN_SUCCESS_MEET_END_OF_STREAM:I = 0x1
# instance fields
.field private final mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
.field private final mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
.field private mEnableLimitMaxDecFrameBufferingInH264Sps:Z
.field private mIsRealTime:Z
.field private mIsStarted:Z
.field private mMediaCodec:Landroid/media/MediaCodec;
.field private mNativeVideoDecoderImplAndroid:J
.field private mOutputSurface:Landroid/view/Surface;
.field private final mSPSModifier:Lcom/tencent/liteav/videoconsumer/decoder/s;
.field private mSurfaceTexture:Landroid/graphics/SurfaceTexture;
.field private final mTAG:Ljava/lang/String;
.field private final mThrottlers:Lcom/tencent/liteav/base/b/b;
# direct methods
.method constructor <init>(ZZIIJ)V
.registers 9
.line 54
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 33
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "HardwareVideoDecoder2_"
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p0}, Ljava/lang/Object;->hashCode()I
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
.line 39
new-instance v0, Lcom/tencent/liteav/base/b/b;
invoke-direct {v0}, Lcom/tencent/liteav/base/b/b;-><init>()V
iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
const/4 v0, 0x0
.line 43
iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
.line 46
new-instance v0, Landroid/media/MediaCodec$BufferInfo;
invoke-direct {v0}, Landroid/media/MediaCodec$BufferInfo;-><init>()V
iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
const/4 v0, 0x0
.line 49
iput-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mEnableLimitMaxDecFrameBufferingInH264Sps:Z
.line 50
new-instance v0, Lcom/tencent/liteav/videoconsumer/decoder/s;
invoke-direct {v0}, Lcom/tencent/liteav/videoconsumer/decoder/s;-><init>()V
iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSPSModifier:Lcom/tencent/liteav/videoconsumer/decoder/s;
.line 55
iput-boolean p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsRealTime:Z
.line 56
iput-wide p5, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mNativeVideoDecoderImplAndroid:J
.line 58
new-instance p1, Lcom/tencent/liteav/videobase/utils/h;
invoke-direct {p1}, Lcom/tencent/liteav/videobase/utils/h;-><init>()V
if-eqz p2, :cond_40
const-string p2, "video/hevc"
goto :goto_42
:cond_40
const-string p2, "video/avc"
.line 1077
:goto_42
iput-object p2, p1, Lcom/tencent/liteav/videobase/utils/h;->e:Ljava/lang/String;
.line 2067
iput p3, p1, Lcom/tencent/liteav/videobase/utils/h;->c:I
.line 2072
iput p4, p1, Lcom/tencent/liteav/videobase/utils/h;->d:I
.line 61
iput-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
return-void
.end method
.method private configureDecoder(Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;Z)Z
.registers 9
.line 346
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
.line 2082
iput-boolean p2, v0, Lcom/tencent/liteav/videobase/utils/h;->f:Z
.line 347
iget-object p2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mDecoderMediaFormatBuilder:Lcom/tencent/liteav/videobase/utils/h;
invoke-virtual {p2}, Lcom/tencent/liteav/videobase/utils/h;->a()Landroid/media/MediaFormat;
move-result-object p2
.line 348
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {p2}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
const-string v2, "mediaFormat:"
invoke-virtual {v2, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
const/4 v0, 0x0
const/4 v1, 0x0
:try_start_1b
const-string v2, "mime"
.line 351
invoke-virtual {p2, v2}, Landroid/media/MediaFormat;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
.line 352
invoke-static {v2}, Landroid/media/MediaCodec;->createDecoderByType(Ljava/lang/String;)Landroid/media/MediaCodec;
move-result-object v2
iput-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
.line 353
iget-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
invoke-virtual {v2, p2, v3, v0, v1}, Landroid/media/MediaCodec;->configure(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V
.line 354
iget-object p2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
const/4 v2, 0x1
invoke-virtual {p2, v2}, Landroid/media/MediaCodec;->setVideoScalingMode(I)V
.line 356
iget-object p2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
invoke-virtual {p2}, Landroid/media/MediaCodec;->start()V
.line 357
iget-object p2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v3, "Start MediaCodec(%s) success."
new-array v4, v2, [Ljava/lang/Object;
iget-object v5, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
.line 358
invoke-virtual {v5}, Landroid/media/MediaCodec;->getName()Ljava/lang/String;
move-result-object v5
aput-object v5, v4, v1
.line 357
invoke-static {p2, v3, v4}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_4a
.catch Ljava/lang/Exception; {:try_start_1b .. :try_end_4a} :catch_4b
return v2
:catch_4b
move-exception p2
.line 361
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v3, "Start MediaCodec failed."
invoke-static {v2, v3, p2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 362
iget-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
invoke-direct {p0, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->destroyMediaCodec(Landroid/media/MediaCodec;)V
.line 363
iput-object v0, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
.line 364
sget-object v0, Lcom/tencent/liteav/videobase/videobase/h$c;->m:Lcom/tencent/liteav/videobase/videobase/h$c;
.line 367
instance-of v2, p2, Ljava/lang/IllegalArgumentException;
if-eqz v2, :cond_65
.line 368
sget-object v0, Lcom/tencent/liteav/videobase/videobase/h$c;->i:Lcom/tencent/liteav/videobase/videobase/h$c;
const-string v2, "VideoDecode: illegal argument, Start decoder failed"
goto :goto_70
.line 371
:cond_65
instance-of v2, p2, Ljava/lang/IllegalStateException;
if-eqz v2, :cond_6e
.line 372
sget-object v0, Lcom/tencent/liteav/videobase/videobase/h$c;->j:Lcom/tencent/liteav/videobase/videobase/h$c;
const-string v2, "VideoDecode: illegal state, Start decoder failed"
goto :goto_70
:cond_6e
const-string v2, "VideoDecode: Start decoder failed"
.line 375
:goto_70
iput-object v0, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->b:Lcom/tencent/liteav/videobase/videobase/h$c;
.line 376
iput-object v2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->c:Ljava/lang/String;
.line 377
iput-object p2, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->d:Ljava/lang/Exception;
return v1
.end method
.method private destroyMediaCodec(Landroid/media/MediaCodec;)V
.registers 8
const-string v0, "release MediaCodec failed."
const-string v1, "mediaCodec release"
if-eqz p1, :cond_53
.line 385
:try_start_6
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v3, "mediaCodec stop"
invoke-static {v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 386
invoke-virtual {p1}, Landroid/media/MediaCodec;->stop()V
:try_end_10
.catch Ljava/lang/Exception; {:try_start_6 .. :try_end_10} :catch_22
.catchall {:try_start_6 .. :try_end_10} :catchall_20
.line 391
:try_start_10
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v2, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 392
invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
:try_end_18
.catch Ljava/lang/Exception; {:try_start_10 .. :try_end_18} :catch_19
return-void
:catch_19
move-exception p1
.line 394
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v1, v0, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
:catchall_20
move-exception v2
goto :goto_43
:catch_22
move-exception v2
.line 388
:try_start_23
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "Stop MediaCodec failed."
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v2
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v3, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;)V
:try_end_3a
.catchall {:try_start_23 .. :try_end_3a} :catchall_20
.line 391
:try_start_3a
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v2, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 392
invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
:try_end_42
.catch Ljava/lang/Exception; {:try_start_3a .. :try_end_42} :catch_19
return-void
.line 391
:goto_43
:try_start_43
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v3, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 392
invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
:try_end_4b
.catch Ljava/lang/Exception; {:try_start_43 .. :try_end_4b} :catch_4c
goto :goto_52
:catch_4c
move-exception p1
.line 394
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v1, v0, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 396
:goto_52
throw v2
:cond_53
return-void
.end method
.method private drainDecodedFrameInternal()I
.registers 9
const/4 v0, 0x0
move v1, v0
:goto_2
const/4 v2, 0x3
const/4 v3, -0x1
if-ge v1, v2, :cond_55
.line 216
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
iget-object v4, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
sget-object v5, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v6, 0xa
.line 217
invoke-virtual {v5, v6, v7}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J
move-result-wide v5
invoke-virtual {v2, v4, v5, v6}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
move-result v2
if-ne v2, v3, :cond_19
return v3
:cond_19
const/4 v4, -0x3
if-ne v2, v4, :cond_24
.line 222
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v3, "on output buffers changed"
invoke-static {v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_2a
:cond_24
const/4 v4, -0x2
if-ne v2, v4, :cond_2d
.line 224
invoke-direct {p0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->outputFormatChange()V
:goto_2a
add-int/lit8 v1, v1, 0x1
goto :goto_2
:cond_2d
const/4 v1, 0x1
if-ltz v2, :cond_46
.line 226
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v3, v2, v1}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
.line 227
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
iget v2, v2, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/lit8 v2, v2, 0x4
if-eqz v2, :cond_45
.line 228
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v2, "meet end of stream."
invoke-static {v0, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
return v1
:cond_45
return v0
.line 235
:cond_46
iget-object v4, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
new-array v1, v1, [Ljava/lang/Object;
invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
aput-object v2, v1, v0
const-string v0, "dequeueOutputBuffer get invalid index: %d"
invoke-static {v4, v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->d(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_55
return v3
.end method
.method private feedDataToMediaCodec(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)Z
.registers 15
.line 168
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
const/4 v1, 0x0
if-nez v0, :cond_d
.line 169
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v0, "MediaCodec is stopped."
invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
return v1
:cond_d
const/4 v0, 0x1
if-eqz p1, :cond_76
.line 173
iget-boolean v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->isEosFrame:Z
if-nez v2, :cond_21
iget-object v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
if-eqz v2, :cond_76
iget-object v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
.line 174
invoke-virtual {v2}, Ljava/nio/ByteBuffer;->remaining()I
move-result v2
if-nez v2, :cond_21
goto :goto_76
.line 179
:cond_21
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v2}, Landroid/media/MediaCodec;->getInputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v2
.line 180
invoke-static {v2}, Lcom/tencent/liteav/videobase/utils/c;->a([Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_35
.line 181
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v0, "get invalid input buffers."
invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;)V
return v1
.line 185
:cond_35
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
const-wide/16 v4, 0x2710
invoke-virtual {v3, v4, v5}, Landroid/media/MediaCodec;->dequeueInputBuffer(J)I
move-result v7
if-gez v7, :cond_40
return v1
.line 189
:cond_40
iget-boolean v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->isEosFrame:Z
if-nez v1, :cond_64
.line 190
invoke-direct {p0, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->limitMaxDecFrameBufferingInH264Sps(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)V
.line 191
iget-object v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->remaining()I
move-result v9
.line 192
aget-object v1, v2, v7
iget-object v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
.line 193
iget-object v6, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
const/4 v8, 0x0
sget-object v1, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
iget-wide v2, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->pts:J
.line 194
invoke-virtual {v1, v2, v3}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J
move-result-wide v10
const/4 v12, 0x0
.line 193
invoke-virtual/range {v6 .. v12}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
goto :goto_75
.line 196
:cond_64
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v1, "feedDataToMediaCodec BUFFER_FLAG_END_OF_STREAM"
invoke-static {p1, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 197
iget-object v6, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
const/4 v8, 0x0
const/4 v9, 0x0
const-wide/16 v10, 0x0
const/4 v12, 0x4
invoke-virtual/range {v6 .. v12}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
:goto_75
return v0
.line 175
:cond_76
:goto_76
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v1, "receive empty buffer."
invoke-static {p1, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
return v0
.end method
.method private getSpsData([B[I)[B
.registers 9
const/4 v0, 0x0
move v1, v0
:cond_2
add-int/lit8 v2, v1, 0x4
.line 283
array-length v3, p1
if-ge v2, v3, :cond_1a
.line 284
invoke-static {p1}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
move-result-object v2
invoke-static {v1, v2}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->getNextNALHeaderPos(ILjava/nio/ByteBuffer;)I
move-result v1
if-ltz v1, :cond_1a
.line 288
aget-byte v2, p1, v1
and-int/lit8 v2, v2, 0x1f
const/4 v3, 0x7
if-ne v2, v3, :cond_2
.line 289
aput v1, p2, v0
.line 293
:cond_1a
aget v1, p2, v0
if-gez v1, :cond_20
const/4 p1, 0x0
return-object p1
.line 296
:cond_20
array-length v1, p1
aget v2, p2, v0
sub-int/2addr v1, v2
.line 297
aget v2, p2, v0
:goto_26
add-int/lit8 v3, v2, 0x3
array-length v4, p1
if-ge v3, v4, :cond_58
.line 298
aget-byte v4, p1, v2
const/4 v5, 0x1
if-nez v4, :cond_3c
add-int/lit8 v4, v2, 0x1
aget-byte v4, p1, v4
if-nez v4, :cond_3c
add-int/lit8 v4, v2, 0x2
aget-byte v4, p1, v4
if-eq v4, v5, :cond_50
:cond_3c
aget-byte v4, p1, v2
if-nez v4, :cond_55
add-int/lit8 v4, v2, 0x1
aget-byte v4, p1, v4
if-nez v4, :cond_55
add-int/lit8 v4, v2, 0x2
aget-byte v4, p1, v4
if-nez v4, :cond_55
aget-byte v3, p1, v3
if-ne v3, v5, :cond_55
.line 301
:cond_50
aget v1, p2, v0
sub-int v1, v2, v1
goto :goto_58
:cond_55
add-int/lit8 v2, v2, 0x1
goto :goto_26
.line 305
:cond_58
:goto_58
new-array v2, v1, [B
.line 306
aget p2, p2, v0
invoke-static {p1, p2, v2, v0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
return-object v2
.end method
.method private varargs handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
.registers 5
.line 401
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v0, p2, p3}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 402
iget-wide p2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mNativeVideoDecoderImplAndroid:J
.line 403
invoke-static {p1}, Lcom/tencent/liteav/videobase/videobase/h;->a(Lcom/tencent/liteav/videobase/videobase/h$c;)I
move-result p1
.line 402
invoke-direct {p0, p2, p3, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->nativeOnDecodedFrameFailed(JI)V
return-void
.end method
.method private initializeSurface(I)Z
.registers 6
.line 311
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v1, "initialize surface"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 312
monitor-enter p0
const/4 v0, 0x0
.line 314
:try_start_9
new-instance v1, Landroid/graphics/SurfaceTexture;
invoke-direct {v1, p1}, Landroid/graphics/SurfaceTexture;-><init>(I)V
iput-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
.line 315
new-instance p1, Landroid/view/Surface;
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
invoke-direct {p1, v1}, Landroid/view/Surface;-><init>(Landroid/graphics/SurfaceTexture;)V
iput-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
.line 316
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
invoke-virtual {p1, p0}, Landroid/graphics/SurfaceTexture;->setOnFrameAvailableListener(Landroid/graphics/SurfaceTexture$OnFrameAvailableListener;)V
:try_end_1e
.catch Landroid/view/Surface$OutOfResourcesException; {:try_start_9 .. :try_end_1e} :catch_34
.catchall {:try_start_9 .. :try_end_1e} :catchall_32
.line 325
:try_start_1e
monitor-exit p0
:try_end_1f
.catchall {:try_start_1e .. :try_end_1f} :catchall_32
.line 327
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
const-string v1, "initializeSurface"
invoke-virtual {p1, v1}, Lcom/tencent/liteav/base/b/b;->a(Ljava/lang/String;)Lcom/tencent/liteav/base/b/a;
move-result-object p1
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v2, "initializeSurface"
new-array v0, v0, [Ljava/lang/Object;
invoke-static {p1, v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Lcom/tencent/liteav/base/b/a;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 p1, 0x1
return p1
:catchall_32
move-exception p1
goto :goto_5f
:catch_34
move-exception p1
.line 318
:try_start_35
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
const-string v2, "surface"
invoke-virtual {v1, v2}, Lcom/tencent/liteav/base/b/b;->a(Ljava/lang/String;)Lcom/tencent/liteav/base/b/a;
move-result-object v1
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v3, "create SurfaceTexture failed."
invoke-static {v1, v2, v3, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Lcom/tencent/liteav/base/b/a;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 319
sget-object v1, Lcom/tencent/liteav/videobase/videobase/h$c;->k:Lcom/tencent/liteav/videobase/videobase/h$c;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "VideoDecode: insufficient resource, Start decoder failed:"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 322
invoke-virtual {p1}, Landroid/view/Surface$OutOfResourcesException;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
new-array v2, v0, [Ljava/lang/Object;
.line 319
invoke-direct {p0, v1, p1, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
.line 323
monitor-exit p0
return v0
.line 325
:goto_5f
monitor-exit p0
:try_end_60
.catchall {:try_start_35 .. :try_end_60} :catchall_32
throw p1
.end method
.method private limitMaxDecFrameBufferingInH264Sps(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)V
.registers 10
.line 243
invoke-virtual {p1}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->isIDRFrame()Z
move-result v0
if-eqz v0, :cond_7f
iget-object v0, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->codecType:Lcom/tencent/liteav/videobase/common/CodecType;
sget-object v1, Lcom/tencent/liteav/videobase/common/CodecType;->b:Lcom/tencent/liteav/videobase/common/CodecType;
if-ne v0, v1, :cond_7f
iget-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mEnableLimitMaxDecFrameBufferingInH264Sps:Z
if-nez v0, :cond_11
goto :goto_7f
.line 247
:cond_11
iget-object v0, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v0}, Ljava/nio/ByteBuffer;->remaining()I
move-result v0
invoke-static {v0}, Lcom/tencent/liteav/videobase/utils/j;->a(I)[B
move-result-object v0
if-nez v0, :cond_1e
return-void
.line 251
:cond_1e
iget-object v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v1, v0}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;
.line 252
iget-object v1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
const/4 v1, 0x1
new-array v1, v1, [I
const/4 v2, -0x1
const/4 v3, 0x0
aput v2, v1, v3
.line 254
invoke-direct {p0, v0, v1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->getSpsData([B[I)[B
move-result-object v2
if-eqz v2, :cond_7f
.line 255
aget v4, v1, v3
if-gez v4, :cond_3a
goto :goto_7f
:cond_3a
const/4 v4, 0x0
.line 260
:try_start_3b
iget-object v5, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSPSModifier:Lcom/tencent/liteav/videoconsumer/decoder/s;
invoke-virtual {v5, v2}, Lcom/tencent/liteav/videoconsumer/decoder/s;->a([B)[B
move-result-object v4
:try_end_41
.catch Ljava/lang/Exception; {:try_start_3b .. :try_end_41} :catch_42
goto :goto_4a
:catch_42
move-exception v5
.line 262
iget-object v6, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v7, "modify dec buffer error "
invoke-static {v6, v7, v5}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_4a
if-nez v4, :cond_4d
return-void
.line 267
:cond_4d
array-length v5, v0
array-length v6, v2
sub-int/2addr v5, v6
array-length v6, v4
add-int/2addr v5, v6
invoke-static {v5}, Lcom/tencent/liteav/videobase/utils/j;->b(I)Ljava/nio/ByteBuffer;
move-result-object v5
if-nez v5, :cond_59
return-void
.line 271
:cond_59
iput-object v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
.line 272
aget v5, v1, v3
if-lez v5, :cond_66
.line 273
iget-object v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
aget v6, v1, v3
invoke-virtual {v5, v0, v3, v6}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;
.line 275
:cond_66
iget-object v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v5, v4}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
.line 276
iget-object v4, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
aget v5, v1, v3
array-length v6, v2
add-int/2addr v5, v6
array-length v6, v0
aget v1, v1, v3
sub-int/2addr v6, v1
array-length v1, v2
sub-int/2addr v6, v1
invoke-virtual {v4, v0, v5, v6}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;
.line 278
iget-object p1, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
:cond_7f
:goto_7f
return-void
.end method
.method private native nativeOnDecodedFrameFailed(JI)V
.end method
.method private native nativeOnFrameAvailable(JJ)V
.end method
.method private outputFormatChange()V
.registers 9
.line 407
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v0}, Landroid/media/MediaCodec;->getOutputFormat()Landroid/media/MediaFormat;
move-result-object v0
.line 408
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
const-string v3, "decode output format changed: "
invoke-virtual {v3, v2}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
const-string v1, "crop-right"
.line 411
invoke-virtual {v0, v1}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v1
const-string v2, "crop-left"
invoke-virtual {v0, v2}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v2
sub-int/2addr v1, v2
invoke-static {v1}, Ljava/lang/Math;->abs(I)I
move-result v1
const/4 v2, 0x1
add-int/2addr v1, v2
const-string v3, "crop-bottom"
.line 413
invoke-virtual {v0, v3}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v3
const-string v4, "crop-top"
invoke-virtual {v0, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v4
sub-int/2addr v3, v4
invoke-static {v3}, Ljava/lang/Math;->abs(I)I
move-result v3
add-int/2addr v3, v2
const-string/jumbo v4, "width"
.line 414
invoke-virtual {v0, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v4
const-string v5, "height"
.line 415
invoke-virtual {v0, v5}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v0
.line 416
iget-object v5, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const/4 v6, 0x4
new-array v6, v6, [Ljava/lang/Object;
.line 417
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
const/4 v7, 0x0
aput-object v1, v6, v7
invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
aput-object v1, v6, v2
invoke-static {v4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
const/4 v2, 0x2
aput-object v1, v6, v2
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
const/4 v1, 0x3
aput-object v0, v6, v1
const-string v0, "cropWidth: %d, cropHeight: %d, frameWidth: %d, frameHeight: %d"
.line 416
invoke-static {v5, v0, v6}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method private uninitializeSurface()V
.registers 3
.line 332
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v1, "uninitialize surface"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 333
monitor-enter p0
.line 334
:try_start_8
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
const/4 v1, 0x0
if-eqz v0, :cond_12
.line 335
invoke-virtual {v0}, Landroid/view/Surface;->release()V
.line 336
iput-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mOutputSurface:Landroid/view/Surface;
.line 338
:cond_12
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
if-eqz v0, :cond_1b
.line 339
invoke-virtual {v0}, Landroid/graphics/SurfaceTexture;->release()V
.line 340
iput-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
.line 342
:cond_1b
monitor-exit p0
return-void
:catchall_1d
move-exception v0
monitor-exit p0
:try_end_1f
.catchall {:try_start_8 .. :try_end_1f} :catchall_1d
throw v0
.end method
# virtual methods
.method public decodeFrame(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)Z
.registers 8
.line 122
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
const/4 v1, 0x0
if-nez v0, :cond_d
.line 123
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v0, "MediaCodec is stopped."
invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
return v1
:cond_d
const/4 v0, 0x1
if-nez p1, :cond_11
return v0
.line 132
:cond_11
:try_start_11
invoke-direct {p0, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->feedDataToMediaCodec(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)Z
move-result v2
if-nez v2, :cond_3c
.line 133
invoke-virtual {p1}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->release()V
:try_end_1a
.catch Ljava/lang/Exception; {:try_start_11 .. :try_end_1a} :catch_1b
return v1
:catch_1b
move-exception v2
.line 137
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v4, "decode failed."
invoke-static {v3, v4, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 138
sget-object v3, Lcom/tencent/liteav/videobase/videobase/h$c;->n:Lcom/tencent/liteav/videobase/videobase/h$c;
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "VideoDecode: decode error, restart decoder message:"
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 139
invoke-virtual {v2}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v2
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
new-array v1, v1, [Ljava/lang/Object;
.line 138
invoke-direct {p0, v3, v2, v1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
.line 141
:cond_3c
invoke-virtual {p1}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->release()V
return v0
.end method
.method public drainDecodedFrame()I
.registers 5
.line 111
:try_start_0
invoke-direct {p0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->drainDecodedFrameInternal()I
move-result v0
:try_end_4
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_4} :catch_5
return v0
:catch_5
move-exception v0
.line 113
iget-object v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v2, "decode failed."
invoke-static {v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 114
sget-object v1, Lcom/tencent/liteav/videobase/videobase/h$c;->n:Lcom/tencent/liteav/videobase/videobase/h$c;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "VideoDecode: decode error, restart decoder message:"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 115
invoke-virtual {v0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const/4 v2, 0x0
new-array v2, v2, [Ljava/lang/Object;
.line 114
invoke-direct {p0, v1, v0, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v0, -0x1
return v0
.end method
.method public onFrameAvailable(Landroid/graphics/SurfaceTexture;)V
.registers 6
.line 423
monitor-enter p0
.line 424
:try_start_1
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
if-eqz v0, :cond_29
if-eq v0, p1, :cond_8
goto :goto_29
.line 427
:cond_8
sget-object v0, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {p1}, Landroid/graphics/SurfaceTexture;->getTimestamp()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v0
const-wide/16 v2, 0x0
cmp-long p1, v0, v2
if-nez p1, :cond_22
.line 431
sget-object p1, Ljava/util/concurrent/TimeUnit;->MICROSECONDS:Ljava/util/concurrent/TimeUnit;
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mBufferInfo:Landroid/media/MediaCodec$BufferInfo;
iget-wide v0, v0, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
invoke-virtual {p1, v0, v1}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v0
.line 433
:cond_22
monitor-exit p0
:try_end_23
.catchall {:try_start_1 .. :try_end_23} :catchall_2b
.line 434
iget-wide v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mNativeVideoDecoderImplAndroid:J
invoke-direct {p0, v2, v3, v0, v1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->nativeOnFrameAvailable(JJ)V
return-void
.line 425
:cond_29
:goto_29
:try_start_29
monitor-exit p0
return-void
:catchall_2b
move-exception p1
.line 433
monitor-exit p0
:try_end_2d
.catchall {:try_start_29 .. :try_end_2d} :catchall_2b
throw p1
.end method
.method public setEnableVui(Z)V
.registers 2
.line 147
iput-boolean p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mEnableLimitMaxDecFrameBufferingInH264Sps:Z
return-void
.end method
.method public start(I)Z
.registers 6
.line 67
iget-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
const/4 v1, 0x1
if-eqz v0, :cond_6
return v1
.line 70
:cond_6
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v2, "Start"
invoke-static {v0, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 71
invoke-direct {p0, p1}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->initializeSurface(I)Z
move-result p1
const/4 v0, 0x0
if-nez p1, :cond_15
return v0
.line 75
:cond_15
new-instance p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;
invoke-direct {p1, v0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;-><init>(B)V
.line 76
iget-boolean v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsRealTime:Z
invoke-direct {p0, p1, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->configureDecoder(Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;Z)Z
move-result v2
if-nez v2, :cond_4f
.line 77
invoke-direct {p0, p1, v0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->configureDecoder(Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;Z)Z
move-result v2
if-eqz v2, :cond_29
goto :goto_4f
.line 83
:cond_29
iget-object v1, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->b:Lcom/tencent/liteav/videobase/videobase/h$c;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "decoder config fail, message:"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v3, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->c:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, " exception:"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object p1, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->d:Ljava/lang/Exception;
.line 85
invoke-virtual {p1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
new-array v2, v0, [Ljava/lang/Object;
.line 83
invoke-direct {p0, v1, p1, v2}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->handleDecoderError(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;[Ljava/lang/Object;)V
return v0
.line 78
:cond_4f
:goto_4f
iget-object p1, p1, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2$a;->a:Landroid/media/MediaCodec;
iput-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
.line 79
iput-boolean v1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
.line 80
iget-object p1, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v0, "Start succeed"
invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
return v1
.end method
.method public stop()V
.registers 3
.line 92
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
const-string v1, "stop"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 93
iget-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
if-nez v0, :cond_c
return-void
.line 96
:cond_c
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
invoke-direct {p0, v0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->destroyMediaCodec(Landroid/media/MediaCodec;)V
const/4 v0, 0x0
.line 97
iput-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mMediaCodec:Landroid/media/MediaCodec;
.line 98
invoke-direct {p0}, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->uninitializeSurface()V
const/4 v0, 0x0
.line 99
iput-boolean v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mIsStarted:Z
return-void
.end method
.method public updateTexImage()[F
.registers 6
.line 152
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
const/4 v1, 0x0
if-nez v0, :cond_6
return-object v1
:cond_6
const/16 v2, 0x10
:try_start_8
new-array v2, v2, [F
.line 157
invoke-virtual {v0}, Landroid/graphics/SurfaceTexture;->updateTexImage()V
.line 158
iget-object v0, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mSurfaceTexture:Landroid/graphics/SurfaceTexture;
invoke-virtual {v0, v2}, Landroid/graphics/SurfaceTexture;->getTransformMatrix([F)V
:try_end_12
.catch Ljava/lang/Exception; {:try_start_8 .. :try_end_12} :catch_13
return-object v2
:catch_13
move-exception v0
.line 162
iget-object v2, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mThrottlers:Lcom/tencent/liteav/base/b/b;
const-string v3, "updateImage"
invoke-virtual {v2, v3}, Lcom/tencent/liteav/base/b/b;->a(Ljava/lang/String;)Lcom/tencent/liteav/base/b/a;
move-result-object v2
iget-object v3, p0, Lcom/tencent/liteav/videoconsumer2/HardwareVideoDecoder2;->mTAG:Ljava/lang/String;
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string v4, "updateTexImage exception: "
invoke-virtual {v4, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const/4 v4, 0x0
new-array v4, v4, [Ljava/lang/Object;
invoke-static {v2, v3, v0, v4}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Lcom/tencent/liteav/base/b/a;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
return-object v1
.end method