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