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