ag.smali
.class final synthetic Lcom/tencent/liteav/videoconsumer/decoder/ag;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field private final a:Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;
.field private final b:J
.field private final c:J
# direct methods
.method private constructor <init>(Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;JJ)V
.registers 6
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/tencent/liteav/videoconsumer/decoder/ag;->a:Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;
iput-wide p2, p0, Lcom/tencent/liteav/videoconsumer/decoder/ag;->b:J
iput-wide p4, p0, Lcom/tencent/liteav/videoconsumer/decoder/ag;->c:J
return-void
.end method
.method public static a(Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;JJ)Ljava/lang/Runnable;
.registers 12
new-instance v6, Lcom/tencent/liteav/videoconsumer/decoder/ag;
move-object v0, v6
move-object v1, p0
move-wide v2, p1
move-wide v4, p3
invoke-direct/range {v0 .. v5}, Lcom/tencent/liteav/videoconsumer/decoder/ag;-><init>(Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;JJ)V
return-object v6
.end method
# virtual methods
.method public final run()V
.registers 19
move-object/from16 v0, p0
iget-object v1, v0, Lcom/tencent/liteav/videoconsumer/decoder/ag;->a:Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;
iget-wide v2, v0, Lcom/tencent/liteav/videoconsumer/decoder/ag;->b:J
iget-wide v4, v0, Lcom/tencent/liteav/videoconsumer/decoder/ag;->c:J
.line 1519
iget-boolean v6, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->k:Z
if-eqz v6, :cond_1cb
.line 1522
iget-object v6, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->s:Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v7, 0x1
invoke-virtual {v6, v7}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
.line 1523
iget-object v6, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->c:Lcom/tencent/liteav/videoconsumer/decoder/e;
.line 1664
iget v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->n:I
if-lez v8, :cond_1d
.line 1665
iget v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->n:I
sub-int/2addr v8, v7
iput v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->n:I
.line 1667
:cond_1d
iget-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->h:J
const-wide/16 v10, 0x0
cmp-long v8, v8, v10
if-nez v8, :cond_2c
.line 1668
iget-object v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->a:Ljava/lang/String;
const-string v9, "decode first frame success"
invoke-static {v8, v9}, Lcom/tencent/liteav/base/util/LiteavLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 1670
:cond_2c
iput-wide v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->h:J
const/4 v2, 0x0
.line 1672
iput v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/e;->p:I
.line 1524
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->o:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v3}, Ljava/util/concurrent/atomic/AtomicInteger;->decrementAndGet()I
.line 1525
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->d:Lcom/tencent/liteav/videoconsumer/decoder/au;
.line 2084
iget-object v6, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->e:Lcom/tencent/liteav/videobase/utils/f;
invoke-virtual {v6}, Lcom/tencent/liteav/videobase/utils/f;->a()V
.line 2085
iget-object v6, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->c:Lcom/tencent/liteav/videoconsumer/decoder/au$a;
.line 2217
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v8
.line 2218
iget-wide v12, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->d:J
sub-long v12, v8, v12
.line 2219
iget-object v14, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->f:Ljava/util/List;
invoke-static {v12, v13}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v15
invoke-interface {v14, v15}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 2220
iput-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->d:J
.line 2221
iget-object v14, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->e:Ljava/util/Deque;
invoke-interface {v14}, Ljava/util/Deque;->isEmpty()Z
move-result v14
if-nez v14, :cond_5f
.line 2222
iget-object v14, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->e:Ljava/util/Deque;
invoke-interface {v14}, Ljava/util/Deque;->removeFirst()Ljava/lang/Object;
.line 2225
:cond_5f
iget-wide v14, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->b:J
sub-long v14, v8, v14
sget-object v2, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v10, 0x1
invoke-virtual {v2, v10, v11}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v16
cmp-long v2, v14, v16
if-ltz v2, :cond_9e
.line 2226
iput-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->b:J
.line 2228
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->f:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v2
const-wide/16 v8, 0x0
:goto_79
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v14
if-eqz v14, :cond_8b
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v14
check-cast v14, Ljava/lang/Long;
invoke-virtual {v14}, Ljava/lang/Long;->longValue()J
move-result-wide v14
add-long/2addr v8, v14
goto :goto_79
.line 2231
:cond_8b
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->f:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
invoke-static {v2, v7}, Ljava/lang/Math;->max(II)I
move-result v2
int-to-long v14, v2
div-long/2addr v8, v14
iput-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->c:J
.line 2232
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->f:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->clear()V
.line 2234
:cond_9e
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->g:Lcom/tencent/liteav/videoconsumer/decoder/au;
.line 3027
iget-object v2, v2, Lcom/tencent/liteav/videoconsumer/decoder/au;->b:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
.line 2234
sget-object v8, Lcom/tencent/liteav/videobase/videobase/i;->D:Lcom/tencent/liteav/videobase/videobase/i;
invoke-static {v12, v13}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v9
invoke-interface {v2, v8, v9}, Lcom/tencent/liteav/videobase/videobase/IVideoReporter;->updateStatus(Lcom/tencent/liteav/videobase/videobase/i;Ljava/lang/Object;)V
.line 3238
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v8
.line 3239
iget-wide v12, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->a:J
const-wide/16 v14, 0x0
cmp-long v2, v12, v14
if-nez v2, :cond_b9
.line 3240
iput-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->a:J
.line 3242
:cond_b9
iget-wide v12, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->a:J
sget-object v2, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v2, v10, v11}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v14
add-long/2addr v12, v14
cmp-long v2, v8, v12
if-ltz v2, :cond_f2
.line 3246
iput-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->a:J
.line 3247
iget-wide v8, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->c:J
.line 3248
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->g:Lcom/tencent/liteav/videoconsumer/decoder/au;
.line 4138
iget-object v2, v2, Lcom/tencent/liteav/videoconsumer/decoder/au;->f:Lcom/tencent/liteav/videoconsumer/decoder/aw$a;
sget-object v12, Lcom/tencent/liteav/videoconsumer/decoder/aw$a;->b:Lcom/tencent/liteav/videoconsumer/decoder/aw$a;
if-ne v2, v12, :cond_d4
move v2, v7
goto :goto_d5
:cond_d4
const/4 v2, 0x0
:goto_d5
if-eqz v2, :cond_e5
.line 3249
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->g:Lcom/tencent/liteav/videoconsumer/decoder/au;
.line 5027
iget-object v2, v2, Lcom/tencent/liteav/videoconsumer/decoder/au;->b:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
.line 3249
sget-object v6, Lcom/tencent/liteav/videobase/videobase/i;->i:Lcom/tencent/liteav/videobase/videobase/i;
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v8
invoke-interface {v2, v6, v8}, Lcom/tencent/liteav/videobase/videobase/IVideoReporter;->updateStatus(Lcom/tencent/liteav/videobase/videobase/i;Ljava/lang/Object;)V
goto :goto_f2
.line 3251
:cond_e5
iget-object v2, v6, Lcom/tencent/liteav/videoconsumer/decoder/au$a;->g:Lcom/tencent/liteav/videoconsumer/decoder/au;
.line 6027
iget-object v2, v2, Lcom/tencent/liteav/videoconsumer/decoder/au;->b:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
.line 3251
sget-object v6, Lcom/tencent/liteav/videobase/videobase/i;->h:Lcom/tencent/liteav/videobase/videobase/i;
invoke-static {v8, v9}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v8
invoke-interface {v2, v6, v8}, Lcom/tencent/liteav/videobase/videobase/IVideoReporter;->updateStatus(Lcom/tencent/liteav/videobase/videobase/i;Ljava/lang/Object;)V
.line 2086
:cond_f2
:goto_f2
iget-object v2, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->d:Lcom/tencent/liteav/videoconsumer/decoder/au$b;
.line 6153
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v8
.line 6154
iget-wide v12, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->b:J
const-wide/16 v14, 0x0
cmp-long v6, v12, v14
if-nez v6, :cond_102
.line 6155
iput-wide v8, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->b:J
.line 6157
:cond_102
iget-wide v12, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->a:J
cmp-long v6, v12, v14
if-nez v6, :cond_10a
.line 6158
iput-wide v8, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->a:J
.line 6162
:cond_10a
iget-wide v12, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->a:J
sget-object v6, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v6, v10, v11}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v14
add-long/2addr v12, v14
cmp-long v6, v8, v12
if-lez v6, :cond_149
iget-wide v12, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->b:J
sget-object v6, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v14, 0x2
.line 6163
invoke-virtual {v6, v14, v15}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v14
add-long/2addr v12, v14
cmp-long v6, v8, v12
if-lez v6, :cond_149
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
.line 6164
iget-wide v12, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->a:J
sub-long v12, v8, v12
.line 6165
invoke-static {v12, v13}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v12
const/4 v13, 0x0
aput-object v12, v6, v13
sget-object v12, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v12, v10, v11}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v10
invoke-static {v10, v11}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v10
aput-object v10, v6, v7
const-string v10, "DecodeSmoothStatistics"
const-string v11, "frame interval [%d] > %d"
.line 6164
invoke-static {v10, v11, v6}, Lcom/tencent/liteav/base/util/LiteavLog;->e(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 6166
iput-wide v8, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->b:J
.line 6168
:cond_149
iput-wide v8, v2, Lcom/tencent/liteav/videoconsumer/decoder/au$b;->a:J
.line 2087
invoke-virtual {v3}, Lcom/tencent/liteav/videoconsumer/decoder/au;->b()V
.line 2089
iget-boolean v2, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->g:Z
if-nez v2, :cond_182
.line 2090
iput-boolean v7, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->g:Z
.line 2091
iget-object v2, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->b:Lcom/tencent/liteav/videobase/videobase/IVideoReporter;
sget-object v6, Lcom/tencent/liteav/videobase/videobase/h$b;->e:Lcom/tencent/liteav/videobase/videobase/h$b;
const/4 v7, 0x0
const-string v8, "first frame decoded"
invoke-interface {v2, v6, v7, v8}, Lcom/tencent/liteav/videobase/videobase/IVideoReporter;->notifyEvent(Lcom/tencent/liteav/videobase/videobase/h$b;Ljava/lang/Object;Ljava/lang/String;)V
.line 2093
iget-object v2, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->a:Ljava/lang/String;
new-instance v6, Ljava/lang/StringBuilder;
const-string v7, "first frame decoded cost time: "
invoke-direct {v6, v7}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 2094
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v7
iget-wide v9, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->h:J
sub-long/2addr v7, v9
invoke-virtual {v6, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v7, ", before decode first frame received: "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v7, v3, Lcom/tencent/liteav/videoconsumer/decoder/au;->i:J
invoke-virtual {v6, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
.line 2093
invoke-static {v2, v3}, Lcom/tencent/liteav/base/util/LiteavLog;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 1527
:cond_182
iget-object v2, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->p:Lcom/tencent/liteav/videobase/utils/m;
invoke-virtual {v2}, Lcom/tencent/liteav/videobase/utils/m;->a()Lcom/tencent/liteav/videobase/frame/PixelFrame;
move-result-object v2
if-eqz v2, :cond_1cb
.line 1532
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->j:Lcom/tencent/liteav/videobase/egl/EGLCore;
if-eqz v3, :cond_1c8
invoke-virtual {v1}, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->h()Z
move-result v3
if-nez v3, :cond_195
goto :goto_1c8
.line 1537
:cond_195
invoke-virtual {v2}, Lcom/tencent/liteav/videobase/frame/PixelFrame;->getGLContext()Ljava/lang/Object;
move-result-object v3
if-nez v3, :cond_1a4
.line 1538
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->j:Lcom/tencent/liteav/videobase/egl/EGLCore;
invoke-virtual {v3}, Lcom/tencent/liteav/videobase/egl/EGLCore;->getEglContext()Ljava/lang/Object;
move-result-object v3
invoke-virtual {v2, v3}, Lcom/tencent/liteav/videobase/frame/PixelFrame;->setGLContext(Ljava/lang/Object;)V
.line 1540
:cond_1a4
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->r:Lcom/tencent/liteav/videobase/utils/n;
invoke-virtual {v2}, Lcom/tencent/liteav/videobase/frame/PixelFrame;->getWidth()I
move-result v6
invoke-virtual {v2}, Lcom/tencent/liteav/videobase/frame/PixelFrame;->getHeight()I
move-result v7
invoke-virtual {v3, v6, v7}, Lcom/tencent/liteav/videobase/utils/n;->a(II)V
.line 1541
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->r:Lcom/tencent/liteav/videobase/utils/n;
invoke-virtual {v3, v2}, Lcom/tencent/liteav/videobase/utils/n;->a(Lcom/tencent/liteav/videobase/frame/PixelFrame;)V
.line 1542
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->t:Lcom/tencent/liteav/videoconsumer/decoder/d;
invoke-virtual {v3, v2}, Lcom/tencent/liteav/videoconsumer/decoder/d;->a(Lcom/tencent/liteav/videobase/frame/PixelFrame;)V
.line 1543
iget-object v3, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->h:Lcom/tencent/liteav/videoconsumer/decoder/ax;
if-eqz v3, :cond_1c4
.line 1544
iget-object v1, v1, Lcom/tencent/liteav/videoconsumer/decoder/VideoDecodeController;->h:Lcom/tencent/liteav/videoconsumer/decoder/ax;
invoke-virtual {v1, v2, v4, v5}, Lcom/tencent/liteav/videoconsumer/decoder/ax;->a(Lcom/tencent/liteav/videobase/frame/PixelFrame;J)V
.line 1546
:cond_1c4
invoke-virtual {v2}, Lcom/tencent/liteav/videobase/frame/PixelFrame;->release()V
goto :goto_1cb
.line 1533
:cond_1c8
:goto_1c8
invoke-virtual {v2}, Lcom/tencent/liteav/videobase/frame/PixelFrame;->release()V
:cond_1cb
:goto_1cb
return-void
.end method