ak.smali
.class public final Lcom/tencent/liteav/videoproducer/encoder/ak;
.super Ljava/lang/Object;
.source "SourceFile"
# instance fields
.field private A:J
.field private B:J
.field private C:J
.field private D:J
.field private final E:Ljava/util/Deque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Deque<",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
.field private F:I
.field private final G:Ljava/util/concurrent/atomic/AtomicLong;
.field private final H:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
.field private final I:Ljava/util/concurrent/atomic/AtomicLong;
.field a:Ljava/lang/String;
.field final b:Landroid/os/Bundle;
.field c:Lcom/tencent/liteav/base/util/CustomHandler;
.field d:Landroid/media/MediaCodec;
.field e:Lcom/tencent/liteav/videoproducer/encoder/bp$a;
.field f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
.field g:J
.field h:Lcom/tencent/liteav/base/util/w;
.field i:Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;
.field final j:Ljava/lang/Runnable;
.field private final k:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
.field private final l:Lcom/tencent/liteav/videoproducer/producer/VideoProducerDef$StreamType;
.field private m:[B
.field private n:Z
.field private o:J
.field private p:J
.field private q:J
.field private r:I
.field private final s:Ljava/util/Deque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Deque<",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
.field private t:J
.field private u:J
.field private v:J
.field private w:J
.field private x:Z
.field private y:D
.field private z:J
# direct methods
.method public constructor <init>(Landroid/os/Bundle;Lcom/tencent/liteav/videobase/videobase/IVideoReporter;Lcom/tencent/liteav/videoproducer/producer/VideoProducerDef$StreamType;)V
.registers 9
.line 132
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
.line 77
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->m:[B
const/4 v1, 0x1
.line 79
iput-boolean v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->n:Z
const-wide/16 v1, 0x0
.line 84
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->g:J
.line 85
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->h:Lcom/tencent/liteav/base/util/w;
.line 87
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->o:J
.line 88
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->p:J
.line 89
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
const/4 v0, -0x1
.line 90
iput v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->r:I
.line 93
new-instance v0, Ljava/util/LinkedList;
invoke-direct {v0}, Ljava/util/LinkedList;-><init>()V
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
.line 94
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->t:J
.line 95
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->u:J
.line 96
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->v:J
const-wide/high16 v3, -0x8000000000000000L
.line 97
iput-wide v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->w:J
const/4 v0, 0x0
.line 99
iput-boolean v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->x:Z
const-wide/16 v3, 0x0
.line 103
iput-wide v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->y:D
.line 104
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->z:J
.line 105
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->A:J
.line 108
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->B:J
.line 109
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->C:J
.line 110
iput-wide v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->D:J
.line 113
new-instance v3, Ljava/util/LinkedList;
invoke-direct {v3}, Ljava/util/LinkedList;-><init>()V
iput-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->E:Ljava/util/Deque;
.line 115
iput v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->F:I
.line 119
new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;
invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->G:Ljava/util/concurrent/atomic/AtomicLong;
.line 121
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->H:Ljava/util/List;
.line 122
new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;
invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->I:Ljava/util/concurrent/atomic/AtomicLong;
.line 124
invoke-static {p0}, Lcom/tencent/liteav/videoproducer/encoder/al;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;)Ljava/lang/Runnable;
move-result-object v0
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->j:Ljava/lang/Runnable;
.line 133
iput-object p2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->k:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
.line 134
iput-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->b:Landroid/os/Bundle;
.line 135
iput-object p3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->l:Lcom/tencent/liteav/videoproducer/producer/VideoProducerDef$StreamType;
.line 136
new-instance p1, Ljava/lang/StringBuilder;
const-string p2, "SurfaceInputVideoEncoder_"
invoke-direct {p1, p2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string p2, "_"
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p0}, Ljava/lang/Object;->hashCode()I
move-result p2
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
iput-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
return-void
.end method
.method private a(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)V
.registers 9
.line 536
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-boolean v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->enableBFrame:Z
if-nez v0, :cond_51
iget-boolean v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->x:Z
if-nez v0, :cond_51
iget-wide v0, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->pts:J
iget-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->w:J
cmp-long v0, v0, v2
if-gez v0, :cond_51
.line 538
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const/4 v1, 0x3
new-array v1, v1, [Ljava/lang/Object;
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-boolean v2, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->enableBFrame:Z
.line 540
invoke-static {v2}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v2
const/4 v3, 0x0
aput-object v2, v1, v3
iget-wide v4, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->w:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
const/4 v4, 0x1
aput-object v2, v1, v4
const/4 v2, 0x2
iget-wide v5, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->pts:J
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
aput-object v5, v1, v2
const-string v2, "has B frame,isEnablesBframe=%b,mLastPresentationTimestamp=%d,packet.pts=%d"
.line 538
invoke-static {v0, v2, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 541
iput-boolean v4, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->x:Z
.line 542
new-instance v0, Lcom/tencent/liteav/base/storage/PersistStorage;
const-string v1, "com.liteav.storage.global"
invoke-direct {v0, v1}, Lcom/tencent/liteav/base/storage/PersistStorage;-><init>(Ljava/lang/String;)V
const-string v1, "Liteav.Video.android.local.rtc.enable.high.profile"
.line 543
invoke-virtual {v0, v1, v3}, Lcom/tencent/liteav/base/storage/PersistStorage;->put(Ljava/lang/String;I)V
.line 544
invoke-virtual {v0}, Lcom/tencent/liteav/base/storage/PersistStorage;->commit()V
.line 545
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->e:Lcom/tencent/liteav/videoproducer/encoder/bp$a;
if-eqz v0, :cond_51
.line 546
invoke-virtual {v0}, Lcom/tencent/liteav/videoproducer/encoder/bp$a;->a()V
.line 549
:cond_51
iget-wide v0, p1, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->pts:J
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->w:J
return-void
.end method
.method static synthetic a(Lcom/tencent/liteav/videoproducer/encoder/ak;)V
.registers 1
.line 59
invoke-direct {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->g()V
return-void
.end method
.method private a(Z)V
.registers 4
if-eqz p1, :cond_5
const/4 p1, -0x1
.line 576
iput p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->r:I
.line 578
:cond_5
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
if-eqz p1, :cond_21
iget-boolean p1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fullIFrame:Z
if-nez p1, :cond_21
iget p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->r:I
add-int/lit8 p1, p1, 0x1
iput p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->r:I
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fps:I
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v1, v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->gop:I
mul-int/2addr v0, v1
if-ne p1, v0, :cond_21
.line 581
invoke-virtual {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->f()V
:cond_21
return-void
.end method
.method private a(ZJ)V
.registers 12
.line 718
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
if-eqz p1, :cond_2b
.line 720
iget-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->C:J
const-wide/16 v4, 0x3e8
add-long/2addr v4, v2
cmp-long p1, v0, v4
if-lez p1, :cond_2b
.line 721
iget-wide v4, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->D:J
long-to-double v4, v4
const-wide v6, 0x40bf400000000000L # 8000.0
mul-double/2addr v4, v6
sub-long v2, v0, v2
long-to-double v2, v2
div-double/2addr v4, v2
const-wide/high16 v2, 0x4090000000000000L # 1024.0
div-double/2addr v4, v2
double-to-long v2, v4
iput-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->B:J
const-wide/16 v2, 0x0
.line 723
iput-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->D:J
.line 724
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->C:J
.line 725
invoke-direct {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->j()V
.line 728
:cond_2b
iget-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->D:J
add-long/2addr v0, p2
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->D:J
return-void
.end method
.method private a([BLandroid/media/MediaCodec$BufferInfo;)V
.registers 16
.line 467
iget v0, p2, Landroid/media/MediaCodec$BufferInfo;->flags:I
const/4 v1, 0x1
and-int/2addr v0, v1
const/4 v2, 0x0
if-lez v0, :cond_9
move v0, v1
goto :goto_a
:cond_9
move v0, v2
.line 468
:goto_a
invoke-direct {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Z)V
.line 469
array-length v3, p1
int-to-long v3, v3
invoke-direct {p0, v0, v3, v4}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(ZJ)V
.line 470
invoke-direct {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->h()V
const-wide/16 v3, 0x0
const-wide/16 v5, 0x1
if-eqz v0, :cond_23
.line 473
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->p:J
add-long/2addr v7, v5
iput-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->p:J
.line 474
iput-wide v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
goto :goto_28
.line 476
:cond_23
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
add-long/2addr v7, v5
iput-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
.line 478
:goto_28
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->o:J
add-long/2addr v7, v5
iput-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->o:J
.line 481
invoke-direct {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->i()J
move-result-wide v7
.line 482
sget-object v9, Ljava/util/concurrent/TimeUnit;->MICROSECONDS:Ljava/util/concurrent/TimeUnit;
iget-wide v10, p2, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
invoke-virtual {v9, v10, v11}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v9
.line 483
iget-wide v11, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->t:J
cmp-long v11, v11, v3
if-nez v11, :cond_41
.line 484
iput-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->t:J
.line 486
:cond_41
iget-wide v11, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->u:J
cmp-long v3, v11, v3
if-nez v3, :cond_49
.line 487
iput-wide v9, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->u:J
.line 490
:cond_49
iget-wide v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->t:J
iget-wide v11, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->u:J
sub-long/2addr v3, v11
add-long/2addr v9, v3
.line 491
iget-wide v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->v:J
cmp-long v11, v7, v3
if-gtz v11, :cond_57
add-long v7, v3, v5
:cond_57
cmp-long v3, v7, v9
if-lez v3, :cond_5c
move-wide v7, v9
.line 497
:cond_5c
iput-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->v:J
.line 499
new-instance v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;
invoke-direct {v3}, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;-><init>()V
if-eqz v0, :cond_68
.line 500
sget-object v4, Lcom/tencent/liteav/videobase/common/a;->b:Lcom/tencent/liteav/videobase/common/a;
goto :goto_6a
:cond_68
sget-object v4, Lcom/tencent/liteav/videobase/common/a;->c:Lcom/tencent/liteav/videobase/common/a;
:goto_6a
iput-object v4, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->nalType:Lcom/tencent/liteav/videobase/common/a;
.line 501
array-length v4, p1
invoke-static {v4}, Lcom/tencent/liteav/videobase/utils/j;->b(I)Ljava/nio/ByteBuffer;
move-result-object v4
iput-object v4, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
.line 502
iget-object v4, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
if-nez v4, :cond_7d
const-string p1, "allocate direct buffer for nal failed"
.line 503
invoke-virtual {p0, p1}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
return-void
.line 506
:cond_7d
iget-object v4, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {v4, p1}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
.line 507
iget-object p1, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->data:Ljava/nio/ByteBuffer;
invoke-virtual {p1}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
.line 508
iput-wide v7, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->dts:J
.line 509
iput-wide v9, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->pts:J
.line 510
iput-object p2, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->info:Landroid/media/MediaCodec$BufferInfo;
.line 511
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->p:J
iput-wide v7, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->gopIndex:J
.line 512
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
iput-wide v7, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->frameIndex:J
.line 513
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
iput-wide v7, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->gopFrameIndex:J
if-eqz v0, :cond_9e
.line 514
iget-wide v4, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
goto :goto_a2
:cond_9e
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
sub-long v4, v7, v5
:goto_a2
iput-wide v4, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->refFrameIndex:J
.line 515
sget-object p1, Lcom/tencent/liteav/videobase/common/b;->b:Lcom/tencent/liteav/videobase/common/b;
iput-object p1, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->profileType:Lcom/tencent/liteav/videobase/common/b;
.line 516
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object p1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->codecType:Lcom/tencent/liteav/videobase/common/CodecType;
iput-object p1, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->codecType:Lcom/tencent/liteav/videobase/common/CodecType;
.line 517
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget p1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->width:I
iput p1, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->width:I
.line 518
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget p1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->height:I
iput p1, v3, Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;->height:I
.line 520
iget p1, p2, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/lit8 p1, p1, 0x4
if-lez p1, :cond_c4
.line 522
invoke-virtual {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->e()V
goto :goto_c8
.line 524
:cond_c4
invoke-direct {p0, v3}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;)V
move v1, v2
.line 526
:goto_c8
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->e:Lcom/tencent/liteav/videoproducer/encoder/bp$a;
if-eqz p1, :cond_cf
.line 527
invoke-virtual {p1, v3, v1}, Lcom/tencent/liteav/videoproducer/encoder/bp$a;->onEncodedNAL(Lcom/tencent/liteav/videobase/common/EncodedVideoFrame;Z)V
:cond_cf
return-void
.end method
.method private a(Landroid/media/MediaCodec;Landroid/media/MediaFormat;)Z
.registers 8
const/4 v0, 0x0
if-nez p2, :cond_4
return v0
.line 708
:cond_4
:try_start_4
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v2, "configure format: %s"
const/4 v3, 0x1
new-array v4, v3, [Ljava/lang/Object;
aput-object p2, v4, v0
invoke-static {v1, v2, v4}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 v1, 0x0
.line 709
invoke-virtual {p1, p2, v1, v1, v3}, Landroid/media/MediaCodec;->configure(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V
:try_end_14
.catchall {:try_start_4 .. :try_end_14} :catchall_15
return v3
:catchall_15
move-exception p1
.line 712
iget-object p2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "configure failed."
invoke-static {p2, v1, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return v0
.end method
.method private static a([B)[B
.registers 6
.line 804
array-length v0, p0
const/4 v1, 0x5
if-le v0, v1, :cond_61
const/4 v0, 0x0
aget-byte v2, p0, v0
if-nez v2, :cond_61
const/4 v2, 0x1
aget-byte v3, p0, v2
if-nez v3, :cond_61
const/4 v3, 0x2
aget-byte v3, p0, v3
if-nez v3, :cond_61
const/4 v3, 0x3
aget-byte v3, p0, v3
if-nez v3, :cond_61
const/4 v3, 0x4
aget-byte v3, p0, v3
if-nez v3, :cond_61
aget-byte v1, p0, v1
if-eqz v1, :cond_22
goto :goto_61
:cond_22
move v1, v0
:goto_23
add-int/lit8 v3, v1, 0x3
.line 810
array-length v4, p0
if-ge v3, v4, :cond_50
.line 811
aget-byte v4, p0, v1
if-nez v4, :cond_3c
add-int/lit8 v4, v1, 0x1
aget-byte v4, p0, v4
if-nez v4, :cond_3c
add-int/lit8 v4, v1, 0x2
aget-byte v4, p0, v4
if-nez v4, :cond_3c
aget-byte v3, p0, v3
if-eq v3, v2, :cond_51
:cond_3c
aget-byte v3, p0, v1
if-nez v3, :cond_4d
add-int/lit8 v3, v1, 0x1
aget-byte v3, p0, v3
if-nez v3, :cond_4d
add-int/lit8 v3, v1, 0x2
aget-byte v3, p0, v3
if-ne v3, v2, :cond_4d
goto :goto_51
:cond_4d
add-int/lit8 v1, v1, 0x1
goto :goto_23
:cond_50
move v1, v0
:cond_51
:goto_51
if-eqz v1, :cond_61
.line 819
array-length v2, p0
sub-int/2addr v2, v1
invoke-static {v2}, Lcom/tencent/liteav/videobase/utils/j;->a(I)[B
move-result-object v2
if-nez v2, :cond_5c
return-object p0
.line 823
:cond_5c
array-length v3, v2
invoke-static {p0, v1, v2, v0, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
return-object v2
:cond_61
:goto_61
return-object p0
.end method
.method private b(Ljava/lang/String;)Landroid/media/MediaCodec;
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/Exception;
}
.end annotation
.line 882
invoke-static {p1}, Landroid/media/MediaCodec;->createEncoderByType(Ljava/lang/String;)Landroid/media/MediaCodec;
move-result-object p1
.line 885
:try_start_4
invoke-virtual {p1}, Landroid/media/MediaCodec;->getName()Ljava/lang/String;
move-result-object v0
:try_end_8
.catchall {:try_start_4 .. :try_end_8} :catchall_9
goto :goto_12
:catchall_9
move-exception v0
.line 887
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v2, "mediaCodec getName failed."
invoke-static {v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
const/4 v0, 0x0
.line 889
:goto_12
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
const-string v3, "codecName="
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
if-eqz v0, :cond_47
const-string v1, "OMX.google.h264.encoder"
.line 891
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_2c
goto :goto_47
.line 894
:cond_2c
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
const-string/jumbo v2, "will be destroyed codecName="
invoke-virtual {v2, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 895
invoke-virtual {p0, p1}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Landroid/media/MediaCodec;)V
.line 897
new-instance p1, Ljava/io/IOException;
const-string v0, "this is a Google H264 soft encoder. cancel use MediaCodec."
invoke-direct {p1, v0}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
:cond_47
:goto_47
return-object p1
.end method
.method static synthetic b(Lcom/tencent/liteav/videoproducer/encoder/ak;)V
.registers 1
invoke-direct {p0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->g()V
return-void
.end method
.method private static b([B)[B
.registers 13
.line 831
array-length v0, p0
.line 834
new-instance v1, Ljava/util/ArrayList;
const/16 v2, 0x14
invoke-direct {v1, v2}, Ljava/util/ArrayList;-><init>(I)V
const/4 v2, 0x0
move v3, v2
move v4, v3
move v5, v4
:goto_c
const/4 v6, 0x4
const/4 v7, 0x1
if-gt v3, v0, :cond_57
add-int/lit8 v8, v3, 0x2
const/4 v9, 0x3
if-ge v8, v0, :cond_25
.line 838
aget-byte v10, p0, v3
if-nez v10, :cond_25
add-int/lit8 v10, v3, 0x1
aget-byte v10, p0, v10
if-nez v10, :cond_25
aget-byte v10, p0, v8
if-ne v10, v7, :cond_25
move v8, v9
goto :goto_3e
:cond_25
add-int/lit8 v10, v3, 0x3
if-ge v10, v0, :cond_3d
.line 840
aget-byte v11, p0, v3
if-nez v11, :cond_3d
add-int/lit8 v11, v3, 0x1
aget-byte v11, p0, v11
if-nez v11, :cond_3d
aget-byte v8, p0, v8
if-nez v8, :cond_3d
aget-byte v8, p0, v10
if-ne v8, v7, :cond_3d
move v8, v6
goto :goto_3e
:cond_3d
move v8, v7
:goto_3e
if-eq v8, v9, :cond_44
if-eq v8, v6, :cond_44
if-ne v3, v0, :cond_55
:cond_44
if-eq v5, v3, :cond_53
const/4 v6, 0x2
new-array v6, v6, [I
aput v5, v6, v2
aput v3, v6, v7
.line 849
invoke-interface {v1, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
sub-int v5, v3, v5
add-int/2addr v4, v5
:cond_53
add-int v5, v3, v8
:cond_55
add-int/2addr v3, v8
goto :goto_c
.line 856
:cond_57
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v0
mul-int/2addr v0, v6
add-int/2addr v4, v0
invoke-static {v4}, Lcom/tencent/liteav/videobase/utils/j;->a(I)[B
move-result-object v0
if-nez v0, :cond_64
return-object p0
.line 861
:cond_64
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
move v3, v2
:goto_69
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_98
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, [I
.line 862
aget v5, v4, v7
aget v8, v4, v2
sub-int/2addr v5, v8
new-array v8, v6, [B
.line 863
invoke-static {v8}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
move-result-object v8
sget-object v9, Ljava/nio/ByteOrder;->BIG_ENDIAN:Ljava/nio/ByteOrder;
invoke-virtual {v8, v9}, Ljava/nio/ByteBuffer;->order(Ljava/nio/ByteOrder;)Ljava/nio/ByteBuffer;
move-result-object v8
.line 864
invoke-virtual {v8, v5}, Ljava/nio/ByteBuffer;->putInt(I)Ljava/nio/ByteBuffer;
.line 865
invoke-virtual {v8}, Ljava/nio/ByteBuffer;->array()[B
move-result-object v8
invoke-static {v8, v2, v0, v3, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 866
aget v4, v4, v2
add-int/2addr v3, v6
invoke-static {p0, v4, v0, v3, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
add-int/2addr v3, v5
goto :goto_69
:cond_98
return-object v0
.end method
.method private g()V
.registers 10
.line 340
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
if-nez v0, :cond_5
return-void
.line 345
:cond_5
:goto_5
new-instance v0, Landroid/media/MediaCodec$BufferInfo;
invoke-direct {v0}, Landroid/media/MediaCodec$BufferInfo;-><init>()V
.line 348
:try_start_a
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v3, 0x4
.line 349
invoke-virtual {v2, v3, v4}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J
move-result-wide v2
invoke-virtual {v1, v0, v2, v3}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
move-result v1
:try_end_18
.catchall {:try_start_a .. :try_end_18} :catchall_186
const/4 v2, -0x1
if-eq v1, v2, :cond_19c
const/4 v2, -0x3
if-ne v1, v2, :cond_26
.line 358
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "encoder output buffers changed"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_5
:cond_26
const/4 v2, -0x2
const/4 v3, 0x1
const/4 v4, 0x0
if-ne v1, v2, :cond_5c
.line 362
:try_start_2b
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
invoke-virtual {v0}, Landroid/media/MediaCodec;->getOutputFormat()Landroid/media/MediaFormat;
move-result-object v0
.line 363
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->e:Lcom/tencent/liteav/videoproducer/encoder/bp$a;
if-eqz v1, :cond_38
.line 364
invoke-virtual {v1, v0}, Lcom/tencent/liteav/videoproducer/encoder/bp$a;->onOutputFormatChanged(Landroid/media/MediaFormat;)V
.line 366
:cond_38
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v2, "encoder output format changed: %s"
new-array v3, v3, [Ljava/lang/Object;
aput-object v0, v3, v4
invoke-static {v1, v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_43
.catchall {:try_start_2b .. :try_end_43} :catchall_44
goto :goto_5
:catchall_44
move-exception v0
.line 369
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "getOutputFormat failed."
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
goto/16 :goto_19c
:cond_5c
if-gez v1, :cond_6d
const-string v0, "dequeueOutputBuffer return "
.line 373
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
goto/16 :goto_19c
.line 377
:cond_6d
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v5
.line 378
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->H:Ljava/util/List;
iget-object v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->G:Ljava/util/concurrent/atomic/AtomicLong;
invoke-virtual {v7, v5, v6}, Ljava/util/concurrent/atomic/AtomicLong;->getAndSet(J)J
move-result-wide v7
sub-long/2addr v5, v7
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
invoke-interface {v2, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 383
:try_start_81
invoke-static {}, Lcom/tencent/liteav/base/system/LiteavSystemInfo;->getSystemOSVersionInt()I
move-result v2
const/16 v5, 0x15
if-lt v2, v5, :cond_90
.line 384
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
invoke-virtual {v2, v1}, Landroid/media/MediaCodec;->getOutputBuffer(I)Ljava/nio/ByteBuffer;
move-result-object v2
goto :goto_98
.line 386
:cond_90
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
invoke-virtual {v2}, Landroid/media/MediaCodec;->getOutputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v2
aget-object v2, v2, v1
:try_end_98
.catchall {:try_start_81 .. :try_end_98} :catchall_16f
:goto_98
if-eqz v2, :cond_14c
.line 393
iget v5, v0, Landroid/media/MediaCodec$BufferInfo;->size:I
if-nez v5, :cond_a6
iget v5, v0, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/lit8 v5, v5, 0x4
if-nez v5, :cond_a6
goto/16 :goto_14c
.line 1732
:cond_a6
iget v5, v0, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-static {v5}, Lcom/tencent/liteav/videobase/utils/j;->a(I)[B
move-result-object v5
if-nez v5, :cond_b0
const/4 v2, 0x0
goto :goto_d0
.line 1736
:cond_b0
iget v6, v0, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v2, v6}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
.line 1737
iget v6, v0, Landroid/media/MediaCodec$BufferInfo;->offset:I
iget v7, v0, Landroid/media/MediaCodec$BufferInfo;->size:I
add-int/2addr v6, v7
invoke-virtual {v2, v6}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
.line 1738
invoke-virtual {v2, v5}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;
.line 1740
invoke-static {v5}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a([B)[B
move-result-object v2
.line 1741
iget-object v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
if-eqz v5, :cond_d0
iget-boolean v5, v5, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->annexb:Z
if-nez v5, :cond_d0
.line 1742
invoke-static {v2}, Lcom/tencent/liteav/videoproducer/encoder/ak;->b([B)[B
move-result-object v2
:cond_d0
:goto_d0
if-nez v2, :cond_d9
const-string v0, "modifyEncodedData return null byte array"
.line 1428
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
goto/16 :goto_151
.line 1431
:cond_d9
iget v5, v0, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/lit8 v5, v5, 0x2
if-lez v5, :cond_e1
move v5, v3
goto :goto_e2
:cond_e1
move v5, v4
.line 1432
:goto_e2
iget v6, v0, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/2addr v6, v3
if-lez v6, :cond_e9
move v6, v3
goto :goto_ea
:cond_e9
move v6, v4
:goto_ea
if-eqz v5, :cond_110
if-eqz v6, :cond_110
.line 1434
iget-object v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
if-eqz v5, :cond_fb
iget-object v5, v5, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->codecType:Lcom/tencent/liteav/videobase/common/CodecType;
sget-object v6, Lcom/tencent/liteav/videobase/common/CodecType;->b:Lcom/tencent/liteav/videobase/common/CodecType;
if-ne v5, v6, :cond_f9
goto :goto_fb
:cond_f9
move v5, v4
goto :goto_fc
:cond_fb
:goto_fb
move v5, v3
.line 1436
:goto_fc
iget-object v6, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
if-eqz v6, :cond_106
iget-boolean v6, v6, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->annexb:Z
if-eqz v6, :cond_105
goto :goto_106
:cond_105
move v3, v4
.line 1437
:cond_106
:goto_106
invoke-static {v2, v5, v3}, Lcom/tencent/liteav/videoconsumer/decoder/SpsInfo;->nativeGetSpsPps([BZZ)[B
move-result-object v3
iput-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->m:[B
.line 1438
invoke-direct {p0, v2, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a([BLandroid/media/MediaCodec$BufferInfo;)V
goto :goto_151
:cond_110
if-eqz v5, :cond_11b
.line 1440
invoke-virtual {v2}, [B->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, [B
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->m:[B
goto :goto_151
.line 1442
:cond_11b
iget-boolean v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->n:Z
if-eqz v3, :cond_148
if-eqz v6, :cond_148
.line 1443
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->m:[B
if-eqz v3, :cond_143
.line 2455
array-length v3, v3
array-length v5, v2
add-int/2addr v3, v5
invoke-static {v3}, Lcom/tencent/liteav/videobase/utils/j;->a(I)[B
move-result-object v3
if-eqz v3, :cond_13d
.line 2457
iget-object v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->m:[B
array-length v6, v5
invoke-static {v5, v4, v3, v4, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 2458
iget-object v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->m:[B
array-length v5, v5
array-length v6, v2
invoke-static {v2, v4, v3, v5, v6}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
move-object v2, v3
goto :goto_148
:cond_13d
const-string v3, "add spspps for I frame, allocate buffer failed."
.line 2461
invoke-virtual {p0, v3}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
goto :goto_148
:cond_143
const-string v3, "mSpsPps is null."
.line 1446
invoke-virtual {p0, v3}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
.line 1449
:cond_148
:goto_148
invoke-direct {p0, v2, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a([BLandroid/media/MediaCodec$BufferInfo;)V
goto :goto_151
:cond_14c
:goto_14c
const-string v0, "size is zero, but it isn\'t end of stream"
.line 396
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
.line 402
:goto_151
:try_start_151
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
invoke-virtual {v0, v1, v4}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
:try_end_156
.catchall {:try_start_151 .. :try_end_156} :catchall_158
goto/16 :goto_5
:catchall_158
move-exception v0
.line 404
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "releaseOutputBuffer failed."
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
goto :goto_19c
:catchall_16f
move-exception v0
.line 389
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "getOutputBuffer failed."
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
goto :goto_19c
:catchall_186
move-exception v0
.line 351
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "dequeueOutputBuffer failed."
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Ljava/lang/String;)V
.line 3413
:cond_19c
:goto_19c
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
monitor-enter v0
.line 3414
:try_start_19f
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
invoke-interface {v1}, Ljava/util/Deque;->isEmpty()Z
move-result v1
if-eqz v1, :cond_1a9
.line 3415
monitor-exit v0
return-void
.line 3417
:cond_1a9
monitor-exit v0
:try_end_1aa
.catchall {:try_start_19f .. :try_end_1aa} :catchall_1ca
.line 3418
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fps:I
const/16 v1, 0xa
if-eqz v0, :cond_1ba
const/16 v0, 0x1f4
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v2, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fps:I
div-int/2addr v0, v2
goto :goto_1bb
:cond_1ba
move v0, v1
.line 3420
:goto_1bb
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-virtual {v2, v1}, Lcom/tencent/liteav/base/util/CustomHandler;->hasMessages(I)Z
move-result v2
if-nez v2, :cond_1c9
.line 3421
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
int-to-long v3, v0
invoke-virtual {v2, v1, v3, v4}, Lcom/tencent/liteav/base/util/CustomHandler;->sendEmptyMessageDelayed(IJ)Z
:cond_1c9
return-void
:catchall_1ca
move-exception v1
.line 3417
:try_start_1cb
monitor-exit v0
:try_end_1cc
.catchall {:try_start_1cb .. :try_end_1cc} :catchall_1ca
throw v1
.end method
.method private h()V
.registers 10
.line 553
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
.line 554
iget-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->z:J
sget-object v4, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v5, 0x2
invoke-virtual {v4, v5, v6}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v4
add-long/2addr v2, v4
cmp-long v2, v0, v2
const-wide/16 v3, 0x1
if-gtz v2, :cond_1b
.line 555
iget-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->A:J
add-long/2addr v0, v3
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->A:J
return-void
.line 559
:cond_1b
iget-wide v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->A:J
long-to-double v5, v5
const-wide v7, 0x408f400000000000L # 1000.0
mul-double/2addr v5, v7
iget-wide v7, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->z:J
sub-long v7, v0, v7
long-to-double v7, v7
div-double/2addr v5, v7
iput-wide v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->y:D
.line 560
iput-wide v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->A:J
.line 561
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->z:J
const-wide/16 v0, -0x1
.line 565
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->H:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
:cond_38
:goto_38
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v3
if-eqz v3, :cond_4e
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/Long;
invoke-virtual {v3}, Ljava/lang/Long;->longValue()J
move-result-wide v3
cmp-long v5, v0, v3
if-gez v5, :cond_38
move-wide v0, v3
goto :goto_38
.line 570
:cond_4e
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->I:Ljava/util/concurrent/atomic/AtomicLong;
invoke-virtual {v2, v0, v1}, Ljava/util/concurrent/atomic/AtomicLong;->set(J)V
.line 571
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->H:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->clear()V
return-void
.end method
.method private i()J
.registers 4
.line 762
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
monitor-enter v0
.line 763
:try_start_3
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
invoke-interface {v1}, Ljava/util/Deque;->pollFirst()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/Long;
if-nez v1, :cond_10
const-wide/16 v1, 0x0
goto :goto_14
.line 764
:cond_10
invoke-virtual {v1}, Ljava/lang/Long;->longValue()J
move-result-wide v1
:goto_14
monitor-exit v0
return-wide v1
:catchall_16
move-exception v1
.line 765
monitor-exit v0
:try_end_18
.catchall {:try_start_3 .. :try_end_18} :catchall_16
throw v1
.end method
.method private j()V
.registers 6
.line 773
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->E:Ljava/util/Deque;
invoke-interface {v0}, Ljava/util/Deque;->isEmpty()Z
move-result v0
if-eqz v0, :cond_9
return-void
.line 777
:cond_9
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fps:I
int-to-double v0, v0
iget-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->y:D
sub-double/2addr v0, v2
double-to-float v0, v0
.line 778
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v1, v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fps:I
int-to-float v1, v1
const/high16 v2, 0x40000000 # 2.0f
div-float/2addr v1, v2
const/high16 v2, 0x40a00000 # 5.0f
invoke-static {v1, v2}, Ljava/lang/Math;->max(FF)F
move-result v1
cmpl-float v0, v0, v1
if-lez v0, :cond_25
return-void
.line 784
:cond_25
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->E:Ljava/util/Deque;
invoke-interface {v0}, Ljava/util/Deque;->peekFirst()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Long;
if-eqz v0, :cond_88
.line 785
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v1
invoke-virtual {v0}, Ljava/lang/Long;->longValue()J
move-result-wide v3
cmp-long v0, v1, v3
if-lez v0, :cond_88
.line 786
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->E:Ljava/util/Deque;
invoke-interface {v0}, Ljava/util/Deque;->removeFirst()Ljava/lang/Object;
.line 787
iget v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->F:I
int-to-long v0, v0
iget-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->B:J
sub-long/2addr v0, v2
.line 788
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v2, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->bitrate:I
div-int/lit8 v2, v2, 0x2
const/16 v3, 0x64
invoke-static {v2, v3}, Ljava/lang/Math;->max(II)I
move-result v2
int-to-long v2, v2
cmp-long v0, v0, v2
if-lez v0, :cond_88
.line 791
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "restart hardware encoder because real bitrate is too low.expectBitrate: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->F:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, ", realBitrate="
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->B:J
invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 794
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->b:Landroid/os/Bundle;
const/4 v1, 0x1
const-string v2, "need_restart_when_down_bitrate"
invoke-virtual {v0, v2, v1}, Landroid/os/Bundle;->putBoolean(Ljava/lang/String;Z)V
.line 795
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->j:Ljava/lang/Runnable;
invoke-interface {v0}, Ljava/lang/Runnable;->run()V
.line 796
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->E:Ljava/util/Deque;
invoke-interface {v0}, Ljava/util/Deque;->clear()V
:cond_88
return-void
.end method
# virtual methods
.method public final a(Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;Lcom/tencent/liteav/videoproducer/encoder/bp$a;)Landroid/util/Pair;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;",
"Lcom/tencent/liteav/videoproducer/encoder/bp$a;",
")",
"Landroid/util/Pair<",
"Landroid/view/Surface;",
"Lcom/tencent/liteav/base/util/Size;",
">;"
}
.end annotation
.line 160
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "start"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 v0, 0x1
new-array v0, v0, [Landroid/view/Surface;
.line 162
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0, p2, v0, p1}, Lcom/tencent/liteav/videoproducer/encoder/an;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;Lcom/tencent/liteav/videoproducer/encoder/bp$a;[Landroid/view/Surface;Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;)Ljava/lang/Runnable;
move-result-object p1
const-wide/16 v2, 0x1388
invoke-virtual {v1, p1, v2, v3}, Lcom/tencent/liteav/base/util/CustomHandler;->runAndWaitDone(Ljava/lang/Runnable;J)Z
move-result p1
.line 166
iget-object p2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
invoke-static {p1}, Ljava/lang/String;->valueOf(Z)Ljava/lang/String;
move-result-object p1
const-string v1, "startCodecInternal success: "
invoke-virtual {v1, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-static {p2, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 167
new-instance p1, Lcom/tencent/liteav/base/util/Size;
const/16 p2, 0x2d0
const/16 v1, 0x500
invoke-direct {p1, p2, v1}, Lcom/tencent/liteav/base/util/Size;-><init>(II)V
.line 168
iget-object p2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
if-eqz p2, :cond_3b
.line 169
iget p2, p2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->width:I
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v1, v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->height:I
invoke-virtual {p1, p2, v1}, Lcom/tencent/liteav/base/util/Size;->set(II)V
.line 171
:cond_3b
new-instance p2, Landroid/util/Pair;
const/4 v1, 0x0
aget-object v0, v0, v1
invoke-direct {p2, v0, p1}, Landroid/util/Pair;-><init>(Ljava/lang/Object;Ljava/lang/Object;)V
return-object p2
.end method
.method final a(Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;)Landroid/view/Surface;
.registers 10
.line 587
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->g:J
const-wide/high16 v0, -0x8000000000000000L
.line 588
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->w:J
.line 589
iget v0, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->bitrate:I
if-nez v0, :cond_27
.line 590
iget v0, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->width:I
iget v1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->width:I
mul-int/2addr v0, v1
iget v1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->height:I
iget v2, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->height:I
mul-int/2addr v1, v2
add-int/2addr v0, v1
int-to-double v0, v0
.line 591
invoke-static {v0, v1}, Ljava/lang/Math;->sqrt(D)D
move-result-wide v0
const-wide v2, 0x3ff3333333333333L # 1.2
mul-double/2addr v0, v2
double-to-int v0, v0
iput v0, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->bitrate:I
.line 594
:cond_27
new-instance v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
invoke-direct {v0, p1}, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;-><init>(Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;)V
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
.line 595
iget-wide v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->baseFrameIndex:J
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->o:J
.line 596
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-wide v0, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->baseGopIndex:J
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->p:J
const-wide/16 v0, 0x0
.line 597
iput-wide v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->q:J
.line 602
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object p1, p1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->codecType:Lcom/tencent/liteav/videobase/common/CodecType;
sget-object v0, Lcom/tencent/liteav/videobase/common/CodecType;->c:Lcom/tencent/liteav/videobase/common/CodecType;
if-ne p1, v0, :cond_47
const-string p1, "video/hevc"
goto :goto_49
:cond_47
const-string p1, "video/avc"
.line 3666
:goto_49
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->b:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
if-ne v0, v1, :cond_57
.line 3669
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->c:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
iput-object v1, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
.line 3674
:cond_57
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->c:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
if-eq v0, v1, :cond_67
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->b:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
if-ne v0, v1, :cond_78
.line 3678
:cond_67
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->i:Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;
if-eqz v0, :cond_78
invoke-virtual {v0}, Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;->isHardwareEncoderHighProfileAllowed()Z
move-result v0
if-eqz v0, :cond_72
goto :goto_78
.line 3681
:cond_72
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->a:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
iput-object v1, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
.line 3686
:cond_78
:goto_78
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->c:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
if-eq v0, v1, :cond_88
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->b:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
if-ne v0, v1, :cond_b9
.line 3690
:cond_88
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-boolean v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->enableBFrame:Z
if-nez v0, :cond_b9
.line 3693
new-instance v0, Lcom/tencent/liteav/base/storage/PersistStorage;
const-string v1, "com.liteav.storage.global"
invoke-direct {v0, v1}, Lcom/tencent/liteav/base/storage/PersistStorage;-><init>(Ljava/lang/String;)V
const-string v1, "Liteav.Video.android.local.rtc.enable.high.profile"
.line 3695
invoke-virtual {v0, v1}, Lcom/tencent/liteav/base/storage/PersistStorage;->getInt(Ljava/lang/String;)Ljava/lang/Integer;
move-result-object v0
.line 3696
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
invoke-static {v0}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
const-string v3, "enable high profile from persist storage:"
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
if-eqz v0, :cond_b9
.line 3697
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
if-eqz v0, :cond_b3
goto :goto_b9
.line 3700
:cond_b3
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
sget-object v1, Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;->a:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
iput-object v1, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->encoderProfile:Lcom/tencent/liteav/videoproducer/encoder/VideoEncoderDef$EncoderProfile;
:cond_b9
:goto_b9
const/4 v0, 0x0
.line 614
:try_start_ba
invoke-direct {p0, p1}, Lcom/tencent/liteav/videoproducer/encoder/ak;->b(Ljava/lang/String;)Landroid/media/MediaCodec;
move-result-object v1
:try_end_be
.catchall {:try_start_ba .. :try_end_be} :catchall_16e
.line 615
:try_start_be
new-instance v2, Lcom/tencent/liteav/videoproducer/encoder/v;
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-object v4, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->i:Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;
invoke-direct {v2, v1, p1, v3, v4}, Lcom/tencent/liteav/videoproducer/encoder/v;-><init>(Landroid/media/MediaCodec;Ljava/lang/String;Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;)V
const/4 p1, 0x1
.line 4064
iput-boolean p1, v2, Lcom/tencent/liteav/videoproducer/encoder/v;->a:Z
.line 618
invoke-virtual {v2}, Lcom/tencent/liteav/videoproducer/encoder/v;->a()Landroid/media/MediaFormat;
move-result-object v3
.line 617
invoke-direct {p0, v1, v3}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Landroid/media/MediaCodec;Landroid/media/MediaFormat;)Z
move-result v4
const/4 v5, 0x0
if-nez v4, :cond_e3
.line 4075
iput-boolean v5, v2, Lcom/tencent/liteav/videoproducer/encoder/v;->b:Z
.line 620
invoke-virtual {v2}, Lcom/tencent/liteav/videoproducer/encoder/v;->a()Landroid/media/MediaFormat;
move-result-object v3
.line 619
invoke-direct {p0, v1, v3}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Landroid/media/MediaCodec;Landroid/media/MediaFormat;)Z
move-result v2
if-eqz v2, :cond_e2
goto :goto_e3
:cond_e2
move p1, v5
:cond_e3
:goto_e3
if-eqz p1, :cond_162
.line 624
invoke-virtual {v1}, Landroid/media/MediaCodec;->createInputSurface()Landroid/view/Surface;
move-result-object p1
:try_end_e9
.catchall {:try_start_be .. :try_end_e9} :catchall_16a
.line 625
:try_start_e9
invoke-virtual {v1}, Landroid/media/MediaCodec;->start()V
:try_end_ec
.catchall {:try_start_e9 .. :try_end_ec} :catchall_15c
.line 628
:try_start_ec
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
const-string/jumbo v4, "width"
invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v4
iput v4, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->width:I
.line 629
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
const-string v4, "height"
invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v4
iput v4, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->height:I
.line 630
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
const-string v4, "bitrate"
invoke-virtual {v3, v4}, Landroid/media/MediaFormat;->getInteger(Ljava/lang/String;)I
move-result v3
div-int/lit16 v3, v3, 0x400
iput v3, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->bitrate:I
.line 631
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget v2, v2, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->bitrate:I
if-eqz v1, :cond_144
.line 4275
invoke-static {}, Lcom/tencent/liteav/base/system/LiteavSystemInfo;->getSystemOSVersionInt()I
move-result v3
const/16 v4, 0x1e
if-le v3, v4, :cond_144
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->b:Landroid/os/Bundle;
const-string v4, "need_restart_when_down_bitrate"
.line 4276
invoke-virtual {v3, v4, v5}, Landroid/os/Bundle;->getBoolean(Ljava/lang/String;Z)Z
move-result v3
if-eqz v3, :cond_126
goto :goto_144
.line 4279
:cond_126
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v4, "resetBitrateAfterApiLevel30,bitrate="
invoke-static {v2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
invoke-static {v3, v4}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 4280
invoke-virtual {p0, v2}, Lcom/tencent/liteav/videoproducer/encoder/ak;->b(I)V
.line 4281
invoke-virtual {p0, v1, v2}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Landroid/media/MediaCodec;I)V
:try_end_13b
.catchall {:try_start_ec .. :try_end_13b} :catchall_13c
goto :goto_144
:catchall_13c
move-exception v2
.line 633
:try_start_13d
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v4, "MediaFormat get key fail"
invoke-static {v3, v4, v2}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 635
:cond_144
:goto_144
iget-object v2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "start MediaCodec with encode params:"
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v4, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
:try_end_159
.catchall {:try_start_13d .. :try_end_159} :catchall_15c
.line 660
iput-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
return-object p1
:catchall_15c
move-exception v2
move-object v7, v1
move-object v1, p1
move-object p1, v2
move-object v2, v7
goto :goto_171
.line 622
:cond_162
:try_start_162
new-instance p1, Ljava/io/IOException;
const-string v2, "configure encoder failed."
invoke-direct {p1, v2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
:try_end_16a
.catchall {:try_start_162 .. :try_end_16a} :catchall_16a
:catchall_16a
move-exception p1
move-object v2, v1
move-object v1, v0
goto :goto_171
:catchall_16e
move-exception p1
move-object v1, v0
move-object v2, v1
:goto_171
if-eqz v1, :cond_176
.line 638
invoke-virtual {v1}, Landroid/view/Surface;->release()V
.line 640
:cond_176
invoke-virtual {p0, v2}, Lcom/tencent/liteav/videoproducer/encoder/ak;->a(Landroid/media/MediaCodec;)V
.line 641
sget-object v1, Lcom/tencent/liteav/videobase/videobase/h$c;->c:Lcom/tencent/liteav/videobase/videobase/h$c;
.line 642
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Start encoder failed:"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 643
invoke-static {}, Lcom/tencent/liteav/base/system/LiteavSystemInfo;->getSystemOSVersionInt()I
move-result v3
const/16 v4, 0x17
if-lt v3, v4, :cond_1b8
instance-of v3, p1, Landroid/media/MediaCodec$CodecException;
if-eqz v3, :cond_1b8
.line 645
move-object v3, p1
check-cast v3, Landroid/media/MediaCodec$CodecException;
.line 646
invoke-virtual {v3}, Landroid/media/MediaCodec$CodecException;->getErrorCode()I
move-result v3
const/16 v4, 0x44c
if-ne v3, v4, :cond_1b8
.line 648
sget-object v1, Lcom/tencent/liteav/videobase/videobase/h$c;->b:Lcom/tencent/liteav/videobase/videobase/h$c;
.line 650
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Insufficient resource, Start encoder failed:"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 653
:cond_1b8
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->k:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
sget-object v4, Lcom/tencent/liteav/videobase/videobase/i;->z:Lcom/tencent/liteav/videobase/videobase/i;
iget-object v5, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->l:Lcom/tencent/liteav/videoproducer/producer/VideoProducerDef$StreamType;
.line 5020
iget v5, v5, Lcom/tencent/liteav/videoproducer/producer/VideoProducerDef$StreamType;->mValue:I
.line 5213
iget v6, v1, Lcom/tencent/liteav/videobase/videobase/h$c;->mValue:I
.line 654
invoke-static {v6}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v6
.line 653
invoke-interface {v3, v4, v5, v6}, Lcom/tencent/liteav/videobase/videobase/IVideoReporter;->updateStatus(Lcom/tencent/liteav/videobase/videobase/i;ILjava/lang/Object;)V
.line 655
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->k:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
invoke-interface {v3, v1, v2}, Lcom/tencent/liteav/videobase/videobase/IVideoReporter;->notifyWarning(Lcom/tencent/liteav/videobase/videobase/h$c;Ljava/lang/String;)V
.line 656
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "Start MediaCodec failed,encode params:"
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
return-object v0
.end method
.method public final a()V
.registers 3
.line 140
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "initialize"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 141
new-instance v0, Landroid/os/HandlerThread;
const-string v1, "hw-video-encoder"
invoke-direct {v0, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
.line 142
invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V
.line 143
new-instance v1, Lcom/tencent/liteav/videoproducer/encoder/ak$1;
invoke-virtual {v0}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;
move-result-object v0
invoke-direct {v1, p0, v0}, Lcom/tencent/liteav/videoproducer/encoder/ak$1;-><init>(Lcom/tencent/liteav/videoproducer/encoder/ak;Landroid/os/Looper;)V
iput-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
return-void
.end method
.method public final a(I)V
.registers 3
.line 200
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0, p1}, Lcom/tencent/liteav/videoproducer/encoder/ap;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;I)Ljava/lang/Runnable;
move-result-object p1
invoke-virtual {v0, p1}, Lcom/tencent/liteav/base/util/CustomHandler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public final a(J)V
.registers 7
.line 181
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->f:Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;
iget-boolean v0, v0, Lcom/tencent/liteav/videoproducer/encoder/VideoEncodeParams;->fullIFrame:Z
if-eqz v0, :cond_f
.line 182
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0}, Lcom/tencent/liteav/videoproducer/encoder/ao;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;)Ljava/lang/Runnable;
move-result-object v1
invoke-virtual {v0, v1}, Lcom/tencent/liteav/base/util/CustomHandler;->runAndWaitDone(Ljava/lang/Runnable;)Z
.line 189
:cond_f
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
monitor-enter v0
.line 190
:try_start_12
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
invoke-interface {v1}, Ljava/util/Deque;->isEmpty()Z
move-result v1
if-eqz v1, :cond_23
.line 191
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->G:Ljava/util/concurrent/atomic/AtomicLong;
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v2
invoke-virtual {v1, v2, v3}, Ljava/util/concurrent/atomic/AtomicLong;->set(J)V
.line 193
:cond_23
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->s:Ljava/util/Deque;
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p1
invoke-interface {v1, p1}, Ljava/util/Deque;->addLast(Ljava/lang/Object;)V
.line 194
monitor-exit v0
:try_end_2d
.catchall {:try_start_12 .. :try_end_2d} :catchall_37
.line 195
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
const/16 p2, 0xa
const-wide/16 v0, 0xa
invoke-virtual {p1, p2, v0, v1}, Lcom/tencent/liteav/base/util/CustomHandler;->sendEmptyMessageDelayed(IJ)Z
return-void
:catchall_37
move-exception p1
.line 194
:try_start_38
monitor-exit v0
:try_end_39
.catchall {:try_start_38 .. :try_end_39} :catchall_37
throw p1
.end method
.method final a(Landroid/media/MediaCodec;)V
.registers 5
if-eqz p1, :cond_21
.line 903
:try_start_2
invoke-virtual {p1}, Landroid/media/MediaCodec;->stop()V
:try_end_5
.catchall {:try_start_2 .. :try_end_5} :catchall_6
goto :goto_e
:catchall_6
move-exception v0
.line 905
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v2, "destroy mediaCodec stop failed."
invoke-static {v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 908
:goto_e
:try_start_e
invoke-virtual {p1}, Landroid/media/MediaCodec;->release()V
:try_end_11
.catchall {:try_start_e .. :try_end_11} :catchall_12
goto :goto_1a
:catchall_12
move-exception p1
.line 910
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "destroy mediaCodec release failed."
invoke-static {v0, v1, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 912
:goto_1a
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v0, "destroy mediaCodec"
invoke-static {p1, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
:cond_21
return-void
.end method
.method final a(Landroid/media/MediaCodec;I)V
.registers 5
if-eqz p1, :cond_23
.line 254
invoke-static {}, Lcom/tencent/liteav/base/system/LiteavSystemInfo;->getSystemOSVersionInt()I
move-result v0
const/16 v1, 0x13
if-ge v0, v1, :cond_b
goto :goto_23
.line 258
:cond_b
:try_start_b
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
const-string v1, "video-bitrate"
mul-int/lit16 p2, p2, 0x400
.line 259
invoke-virtual {v0, v1, p2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V
.line 260
invoke-virtual {p1, v0}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
:try_end_1a
.catchall {:try_start_b .. :try_end_1a} :catchall_1b
return-void
:catchall_1b
move-exception p1
.line 262
iget-object p2, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v0, "updateBitrateToMediaCodec failed."
invoke-static {p2, v0, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_23
:goto_23
return-void
.end method
.method public final a(Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;)V
.registers 3
.line 155
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0, p1}, Lcom/tencent/liteav/videoproducer/encoder/am;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;Lcom/tencent/liteav/videoproducer/producer/ServerVideoProducerConfig;)Ljava/lang/Runnable;
move-result-object p1
invoke-virtual {v0, p1}, Lcom/tencent/liteav/base/util/CustomHandler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public final a(Ljava/lang/String;)V
.registers 4
.line 303
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
const-string v1, "notifyEncodeError message = "
invoke-virtual {v1, p1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 304
iget-object p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0}, Lcom/tencent/liteav/videoproducer/encoder/ar;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;)Ljava/lang/Runnable;
move-result-object v0
invoke-virtual {p1, v0}, Lcom/tencent/liteav/base/util/CustomHandler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method public final b()V
.registers 3
.line 286
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0}, Lcom/tencent/liteav/videoproducer/encoder/aq;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;)Ljava/lang/Runnable;
move-result-object v1
invoke-virtual {v0, v1}, Lcom/tencent/liteav/base/util/CustomHandler;->post(Ljava/lang/Runnable;)Z
return-void
.end method
.method final b(I)V
.registers 8
.line 244
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
const/4 v2, 0x1
:goto_5
const/4 v3, 0x3
if-gt v2, v3, :cond_18
.line 246
iget-object v3, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->E:Ljava/util/Deque;
mul-int/lit16 v4, v2, 0x7d0
int-to-long v4, v4
add-long/2addr v4, v0
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
invoke-interface {v3, v4}, Ljava/util/Deque;->addLast(Ljava/lang/Object;)V
add-int/lit8 v2, v2, 0x1
goto :goto_5
.line 248
:cond_18
iput p1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->F:I
return-void
.end method
.method public final c()V
.registers 5
.line 312
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "stopSync"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 313
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-static {p0}, Lcom/tencent/liteav/videoproducer/encoder/as;->a(Lcom/tencent/liteav/videoproducer/encoder/ak;)Ljava/lang/Runnable;
move-result-object v1
const-wide/16 v2, 0x7d0
invoke-virtual {v0, v1, v2, v3}, Lcom/tencent/liteav/base/util/CustomHandler;->runAndWaitDone(Ljava/lang/Runnable;J)Z
return-void
.end method
.method public final d()V
.registers 3
.line 326
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "uninitialize"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 327
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->c:Lcom/tencent/liteav/base/util/CustomHandler;
invoke-virtual {v0}, Lcom/tencent/liteav/base/util/CustomHandler;->quitLooper()V
return-void
.end method
.method final e()V
.registers 3
.line 331
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->h:Lcom/tencent/liteav/base/util/w;
if-eqz v0, :cond_13
.line 332
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v1, "stopEosTimer"
invoke-static {v0, v1}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 333
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->h:Lcom/tencent/liteav/base/util/w;
invoke-virtual {v0}, Lcom/tencent/liteav/base/util/w;->a()V
const/4 v0, 0x0
.line 334
iput-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->h:Lcom/tencent/liteav/base/util/w;
:cond_13
return-void
.end method
.method final f()V
.registers 4
.line 749
invoke-static {}, Lcom/tencent/liteav/base/system/LiteavSystemInfo;->getSystemOSVersionInt()I
move-result v0
const/16 v1, 0x13
if-lt v0, v1, :cond_25
iget-object v0, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
if-eqz v0, :cond_25
.line 752
:try_start_c
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
const-string v1, "request-sync"
const/4 v2, 0x0
.line 753
invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V
.line 754
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->d:Landroid/media/MediaCodec;
invoke-virtual {v1, v0}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
:try_end_1c
.catchall {:try_start_c .. :try_end_1c} :catchall_1d
return-void
:catchall_1d
move-exception v0
.line 756
iget-object v1, p0, Lcom/tencent/liteav/videoproducer/encoder/ak;->a:Ljava/lang/String;
const-string v2, "requestSyncFrame failed."
invoke-static {v1, v2, v0}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:cond_25
return-void
.end method