EglRenderer.smali

.class public Lorg/webrtc/ali/EglRenderer;
.super Ljava/lang/Object;
.source "EglRenderer.java"

# interfaces
.implements Lorg/webrtc/ali/VideoRenderer$Callbacks;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;,
        Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;,
        Lorg/webrtc/ali/EglRenderer$FrameListener;
    }
.end annotation


# static fields
.field private static final LOG_INTERVAL_SEC:J = 0x4L

.field private static final MAX_SURFACE_CLEAR_COUNT:I

.field private static final TAG:Ljava/lang/String; = "EglRenderer"


# instance fields
.field private bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

.field private drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

.field private eglBase:Lorg/webrtc/ali/EglBase;

.field private final eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

.field private final fpsReductionLock:Ljava/lang/Object;

.field private final frameListeners:Ljava/util/ArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/ArrayList<",
            "Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;",
            ">;"
        }
    .end annotation
.end field

.field private final frameLock:Ljava/lang/Object;

.field private framesDropped:I

.field private framesReceived:I

.field private framesRendered:I

.field private final handlerLock:Ljava/lang/Object;

.field private layoutAspectRatio:F

.field private final layoutLock:Ljava/lang/Object;

.field private final logStatisticsRunnable:Ljava/lang/Runnable;

.field private minRenderPeriodNs:J

.field private mirror:Z

.field private final name:Ljava/lang/String;

.field private nextFrameTimeNs:J

.field private pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

.field private final renderFrameRunnable:Ljava/lang/Runnable;

.field private renderSwapBufferTimeNs:J

.field private renderThreadHandler:Landroid/os/Handler;

.field private renderTimeNs:J

.field private final statisticsLock:Ljava/lang/Object;

.field private statisticsStartTimeNs:J

.field private final yuvUploader:Lorg/webrtc/ali/RendererCommon$YuvUploader;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    const v0, 0x156c

    invoke-static {v0}, Lnp/NPFog;->d(I)I

    move-result v0

    sput v0, Lorg/webrtc/ali/EglRenderer;->MAX_SURFACE_CLEAR_COUNT:I

    return-void
.end method

.method public constructor <init>(Ljava/lang/String;)V
    .registers 4
    .param p1, "name"    # Ljava/lang/String;

    .line 158
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 82
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    .line 85
    new-instance v0, Ljava/util/ArrayList;

    invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->frameListeners:Ljava/util/ArrayList;

    .line 88
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->fpsReductionLock:Ljava/lang/Object;

    .line 98
    new-instance v0, Lorg/webrtc/ali/RendererCommon$YuvUploader;

    invoke-direct {v0}, Lorg/webrtc/ali/RendererCommon$YuvUploader;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->yuvUploader:Lorg/webrtc/ali/RendererCommon$YuvUploader;

    .line 102
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->frameLock:Ljava/lang/Object;

    .line 106
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->layoutLock:Ljava/lang/Object;

    .line 112
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->statisticsLock:Ljava/lang/Object;

    .line 131
    new-instance v0, Lorg/webrtc/ali/EglRenderer$1;

    invoke-direct {v0, p0}, Lorg/webrtc/ali/EglRenderer$1;-><init>(Lorg/webrtc/ali/EglRenderer;)V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->renderFrameRunnable:Ljava/lang/Runnable;

    .line 138
    new-instance v0, Lorg/webrtc/ali/EglRenderer$2;

    invoke-direct {v0, p0}, Lorg/webrtc/ali/EglRenderer$2;-><init>(Lorg/webrtc/ali/EglRenderer;)V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;

    .line 152
    new-instance v0, Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    const/4 v1, 0x0

    invoke-direct {v0, p0, v1}, Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;-><init>(Lorg/webrtc/ali/EglRenderer;Lorg/webrtc/ali/EglRenderer$1;)V

    iput-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    .line 159
    iput-object p1, p0, Lorg/webrtc/ali/EglRenderer;->name:Ljava/lang/String;

    .line 160
    return-void
.end method

.method static synthetic access$000(Lorg/webrtc/ali/EglRenderer;)Lorg/webrtc/ali/EglBase;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    return-object v0
.end method

.method static synthetic access$002(Lorg/webrtc/ali/EglRenderer;Lorg/webrtc/ali/EglBase;)Lorg/webrtc/ali/EglBase;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;
    .param p1, "x1"    # Lorg/webrtc/ali/EglBase;

    .line 32
    iput-object p1, p0, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    return-object p1
.end method

.method static synthetic access$100(Lorg/webrtc/ali/EglRenderer;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    invoke-direct {p0}, Lorg/webrtc/ali/EglRenderer;->renderFrameOnRenderThread()V

    return-void
.end method

.method static synthetic access$1000(Lorg/webrtc/ali/EglRenderer;)Lorg/webrtc/ali/GlTextureFrameBuffer;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    return-object v0
.end method

.method static synthetic access$1002(Lorg/webrtc/ali/EglRenderer;Lorg/webrtc/ali/GlTextureFrameBuffer;)Lorg/webrtc/ali/GlTextureFrameBuffer;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;
    .param p1, "x1"    # Lorg/webrtc/ali/GlTextureFrameBuffer;

    .line 32
    iput-object p1, p0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    return-object p1
.end method

.method static synthetic access$1100(Lorg/webrtc/ali/EglRenderer;)Ljava/util/ArrayList;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->frameListeners:Ljava/util/ArrayList;

    return-object v0
.end method

.method static synthetic access$1200(Lorg/webrtc/ali/EglRenderer;FFFF)V
    .registers 5
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;
    .param p1, "x1"    # F
    .param p2, "x2"    # F
    .param p3, "x3"    # F
    .param p4, "x4"    # F

    .line 32
    invoke-direct {p0, p1, p2, p3, p4}, Lorg/webrtc/ali/EglRenderer;->clearSurfaceOnRenderThread(FFFF)V

    return-void
.end method

.method static synthetic access$200(Lorg/webrtc/ali/EglRenderer;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    invoke-direct {p0}, Lorg/webrtc/ali/EglRenderer;->logStatistics()V

    return-void
.end method

.method static synthetic access$300(Lorg/webrtc/ali/EglRenderer;)Ljava/lang/Object;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    return-object v0
.end method

.method static synthetic access$400(Lorg/webrtc/ali/EglRenderer;)Landroid/os/Handler;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    return-object v0
.end method

.method static synthetic access$500(Lorg/webrtc/ali/EglRenderer;)Ljava/lang/Runnable;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;

    return-object v0
.end method

.method static synthetic access$700(Lorg/webrtc/ali/EglRenderer;Ljava/lang/String;)V
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;
    .param p1, "x1"    # Ljava/lang/String;

    .line 32
    invoke-direct {p0, p1}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    return-void
.end method

.method static synthetic access$800(Lorg/webrtc/ali/EglRenderer;)Lorg/webrtc/ali/RendererCommon$GlDrawer;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    return-object v0
.end method

.method static synthetic access$802(Lorg/webrtc/ali/EglRenderer;Lorg/webrtc/ali/RendererCommon$GlDrawer;)Lorg/webrtc/ali/RendererCommon$GlDrawer;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;
    .param p1, "x1"    # Lorg/webrtc/ali/RendererCommon$GlDrawer;

    .line 32
    iput-object p1, p0, Lorg/webrtc/ali/EglRenderer;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    return-object p1
.end method

.method static synthetic access$900(Lorg/webrtc/ali/EglRenderer;)Lorg/webrtc/ali/RendererCommon$YuvUploader;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/EglRenderer;

    .line 32
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->yuvUploader:Lorg/webrtc/ali/RendererCommon$YuvUploader;

    return-object v0
.end method

.method private averageTimeAsString(JI)Ljava/lang/String;
    .registers 8
    .param p1, "sumTimeNs"    # J
    .param p3, "count"    # I

    .line 713
    if-gtz p3, :cond_5

    const-string v0, "NA"

    goto :goto_1f

    :cond_5
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    sget-object v1, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    int-to-long v2, p3

    div-long v2, p1, v2

    invoke-virtual {v1, v2, v3}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J

    move-result-wide v1

    invoke-virtual {v0, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v1, " \u03bcs"

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    :goto_1f
    return-object v0
.end method

.method private clearSurfaceOnRenderThread(FFFF)V
    .registers 6
    .param p1, "r"    # F
    .param p2, "g"    # F
    .param p3, "b"    # F
    .param p4, "a"    # F

    .line 504
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    if-eqz v0, :cond_1c

    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->hasSurface()Z

    move-result v0

    if-eqz v0, :cond_1c

    .line 505
    const-string v0, "clearSurface"

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 506
    invoke-static {p1, p2, p3, p4}, Landroid/opengl/GLES20;->glClearColor(FFFF)V

    .line 507
    const/16 v0, 0x4000

    invoke-static {v0}, Landroid/opengl/GLES20;->glClear(I)V

    .line 508
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->swapBuffers()V

    .line 510
    :cond_1c
    return-void
.end method

.method private createEglSurfaceInternal(Ljava/lang/Object;)V
    .registers 3
    .param p1, "surface"    # Ljava/lang/Object;

    .line 215
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    invoke-virtual {v0, p1}, Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;->setSurface(Ljava/lang/Object;)V

    .line 216
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->postToRenderThread(Ljava/lang/Runnable;)V

    .line 217
    return-void
.end method

.method private logD(Ljava/lang/String;)V
    .registers 4
    .param p1, "string"    # Ljava/lang/String;

    .line 737
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->name:Ljava/lang/String;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    const-string v1, "EglRenderer"

    invoke-static {v1, v0}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 738
    return-void
.end method

.method private logStatistics()V
    .registers 13

    .line 717
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v0

    .line 718
    .local v0, "currentTimeNs":J
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->statisticsLock:Ljava/lang/Object;

    monitor-enter v2

    .line 719
    :try_start_7
    iget-wide v3, p0, Lorg/webrtc/ali/EglRenderer;->statisticsStartTimeNs:J

    sub-long v3, v0, v3

    .line 720
    .local v3, "elapsedTimeNs":J
    const-wide/16 v5, 0x0

    cmp-long v7, v3, v5

    if-gtz v7, :cond_13

    .line 721
    monitor-exit v2

    return-void

    .line 723
    :cond_13
    iget v5, p0, Lorg/webrtc/ali/EglRenderer;->framesRendered:I

    int-to-long v5, v5

    sget-object v7, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;

    const-wide/16 v8, 0x1

    invoke-virtual {v7, v8, v9}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J

    move-result-wide v7

    mul-long v5, v5, v7

    long-to-float v5, v5

    long-to-float v6, v3

    div-float/2addr v5, v6

    .line 724
    .local v5, "renderFps":F
    new-instance v6, Ljava/lang/StringBuilder;

    invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V

    const-string v7, "Duration: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-object v7, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-virtual {v7, v3, v4}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J

    move-result-wide v7

    invoke-virtual {v6, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v7, " ms. Frames received: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v7, p0, Lorg/webrtc/ali/EglRenderer;->framesReceived:I

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v7, ". Dropped: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v7, p0, Lorg/webrtc/ali/EglRenderer;->framesDropped:I

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v7, ". Rendered: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v7, p0, Lorg/webrtc/ali/EglRenderer;->framesRendered:I

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string v7, ". Render fps: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-object v7, Ljava/util/Locale;->US:Ljava/util/Locale;

    const-string v8, "%.1f"

    const/4 v9, 0x1

    new-array v9, v9, [Ljava/lang/Object;

    const/4 v10, 0x0

    .line 728
    invoke-static {v5}, Ljava/lang/Float;->valueOf(F)Ljava/lang/Float;

    move-result-object v11

    aput-object v11, v9, v10

    invoke-static {v7, v8, v9}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v7

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v7, ". Average render time: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-wide v7, p0, Lorg/webrtc/ali/EglRenderer;->renderTimeNs:J

    iget v9, p0, Lorg/webrtc/ali/EglRenderer;->framesRendered:I

    .line 729
    invoke-direct {p0, v7, v8, v9}, Lorg/webrtc/ali/EglRenderer;->averageTimeAsString(JI)Ljava/lang/String;

    move-result-object v7

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v7, ". Average swapBuffer time: "

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-wide v7, p0, Lorg/webrtc/ali/EglRenderer;->renderSwapBufferTimeNs:J

    iget v9, p0, Lorg/webrtc/ali/EglRenderer;->framesRendered:I

    .line 731
    invoke-direct {p0, v7, v8, v9}, Lorg/webrtc/ali/EglRenderer;->averageTimeAsString(JI)Ljava/lang/String;

    move-result-object v7

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v7, "."

    invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v6

    .line 724
    invoke-direct {p0, v6}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 732
    invoke-direct {p0, v0, v1}, Lorg/webrtc/ali/EglRenderer;->resetStatistics(J)V

    .line 733
    .end local v3    # "elapsedTimeNs":J
    .end local v5    # "renderFps":F
    monitor-exit v2

    .line 734
    return-void

    .line 733
    :catchall_9f
    move-exception v3

    monitor-exit v2
    :try_end_a1
    .catchall {:try_start_7 .. :try_end_a1} :catchall_9f

    throw v3
.end method

.method private notifyCallbacks(Lorg/webrtc/ali/VideoRenderer$I420Frame;[I[FZ)V
    .registers 22
    .param p1, "frame"    # Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .param p2, "yuvTextures"    # [I
    .param p3, "texMatrix"    # [F
    .param p4, "wasRendered"    # Z

    .line 655
    move-object/from16 v0, p0

    move-object/from16 v1, p1

    iget-object v2, v0, Lorg/webrtc/ali/EglRenderer;->frameListeners:Ljava/util/ArrayList;

    invoke-virtual {v2}, Ljava/util/ArrayList;->isEmpty()Z

    move-result v2

    if-eqz v2, :cond_d

    .line 656
    return-void

    .line 658
    :cond_d
    iget-boolean v2, v0, Lorg/webrtc/ali/EglRenderer;->mirror:Z

    if-eqz v2, :cond_16

    .line 660
    invoke-static {}, Lorg/webrtc/ali/RendererCommon;->horizontalFlipMatrix()[F

    move-result-object v2

    goto :goto_1a

    :cond_16
    invoke-static {}, Lorg/webrtc/ali/RendererCommon;->identityMatrix()[F

    move-result-object v2

    .line 659
    :goto_1a
    move-object/from16 v3, p3

    invoke-static {v3, v2}, Lorg/webrtc/ali/RendererCommon;->multiplyMatrices([F[F)[F

    move-result-object v2

    .line 661
    invoke-static {}, Lorg/webrtc/ali/RendererCommon;->verticalFlipMatrix()[F

    move-result-object v4

    .line 658
    invoke-static {v2, v4}, Lorg/webrtc/ali/RendererCommon;->multiplyMatrices([F[F)[F

    move-result-object v2

    .line 663
    .local v2, "bitmapMatrix":[F
    iget-object v4, v0, Lorg/webrtc/ali/EglRenderer;->frameListeners:Ljava/util/ArrayList;

    invoke-virtual {v4}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object v4

    .line 664
    .local v4, "it":Ljava/util/Iterator;, "Ljava/util/Iterator<Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;>;"
    :goto_2e
    invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z

    move-result v5

    if-eqz v5, :cond_10b

    .line 665
    invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v5

    move-object v14, v5

    check-cast v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;

    .line 666
    .local v14, "listenerAndParams":Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;
    if-nez p4, :cond_42

    iget-boolean v5, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->applyFpsReduction:Z

    if-eqz v5, :cond_42

    .line 667
    goto :goto_2e

    .line 669
    :cond_42
    invoke-interface {v4}, Ljava/util/Iterator;->remove()V

    .line 671
    iget v5, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->scale:F

    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v6

    int-to-float v6, v6

    mul-float v5, v5, v6

    float-to-int v15, v5

    .line 672
    .local v15, "scaledWidth":I
    iget v5, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->scale:F

    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v6

    int-to-float v6, v6

    mul-float v5, v5, v6

    float-to-int v13, v5

    .line 674
    .local v13, "scaledHeight":I
    if-eqz v15, :cond_100

    if-nez v13, :cond_60

    move v5, v13

    goto/16 :goto_101

    .line 679
    :cond_60
    iget-object v5, v0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    if-nez v5, :cond_6d

    .line 680
    new-instance v5, Lorg/webrtc/ali/GlTextureFrameBuffer;

    const/16 v6, 0x1908

    invoke-direct {v5, v6}, Lorg/webrtc/ali/GlTextureFrameBuffer;-><init>(I)V

    iput-object v5, v0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    .line 682
    :cond_6d
    iget-object v5, v0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    invoke-virtual {v5, v15, v13}, Lorg/webrtc/ali/GlTextureFrameBuffer;->setSize(II)V

    .line 684
    iget-object v5, v0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    invoke-virtual {v5}, Lorg/webrtc/ali/GlTextureFrameBuffer;->getFrameBufferId()I

    move-result v5

    const v12, 0x8d40

    invoke-static {v12, v5}, Landroid/opengl/GLES20;->glBindFramebuffer(II)V

    .line 685
    const v5, 0x8ce0

    const/16 v6, 0xde1

    iget-object v7, v0, Lorg/webrtc/ali/EglRenderer;->bitmapTextureFramebuffer:Lorg/webrtc/ali/GlTextureFrameBuffer;

    .line 686
    invoke-virtual {v7}, Lorg/webrtc/ali/GlTextureFrameBuffer;->getTextureId()I

    move-result v7

    .line 685
    const/4 v11, 0x0

    invoke-static {v12, v5, v6, v7, v11}, Landroid/opengl/GLES20;->glFramebufferTexture2D(IIIII)V

    .line 688
    const/4 v5, 0x0

    invoke-static {v5, v5, v5, v5}, Landroid/opengl/GLES20;->glClearColor(FFFF)V

    .line 689
    const/16 v5, 0x4000

    invoke-static {v5}, Landroid/opengl/GLES20;->glClear(I)V

    .line 690
    iget-boolean v5, v1, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvFrame:Z

    if-eqz v5, :cond_b3

    .line 691
    iget-object v5, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v8

    .line 692
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v9

    const/4 v10, 0x0

    const/16 v16, 0x0

    .line 691
    move-object/from16 v6, p2

    move-object v7, v2

    move/from16 v11, v16

    move v12, v15

    move/from16 v16, v13

    .end local v13    # "scaledHeight":I
    .local v16, "scaledHeight":I
    invoke-interface/range {v5 .. v13}, Lorg/webrtc/ali/RendererCommon$GlDrawer;->drawYuv([I[FIIIIII)V

    goto :goto_c8

    .line 694
    .end local v16    # "scaledHeight":I
    .restart local v13    # "scaledHeight":I
    :cond_b3
    move/from16 v16, v13

    .end local v13    # "scaledHeight":I
    .restart local v16    # "scaledHeight":I
    iget-object v5, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    iget v6, v1, Lorg/webrtc/ali/VideoRenderer$I420Frame;->textureId:I

    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v8

    .line 695
    invoke-virtual/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v9

    const/4 v10, 0x0

    const/4 v11, 0x0

    .line 694
    move-object v7, v2

    move v12, v15

    invoke-interface/range {v5 .. v13}, Lorg/webrtc/ali/RendererCommon$GlDrawer;->drawOes(I[FIIIIII)V

    .line 698
    :goto_c8
    move/from16 v5, v16

    .end local v16    # "scaledHeight":I
    .local v5, "scaledHeight":I
    mul-int v13, v15, v5

    mul-int/lit8 v13, v13, 0x4

    invoke-static {v13}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;

    move-result-object v13

    .line 699
    .local v13, "bitmapBuffer":Ljava/nio/ByteBuffer;
    const/4 v12, 0x0

    invoke-static {v12, v12, v15, v5}, Landroid/opengl/GLES20;->glViewport(IIII)V

    .line 700
    const/4 v6, 0x0

    const/4 v7, 0x0

    const/16 v10, 0x1908

    const/16 v11, 0x1401

    move v8, v15

    move v9, v5

    const/4 v0, 0x0

    move-object v12, v13

    invoke-static/range {v6 .. v12}, Landroid/opengl/GLES20;->glReadPixels(IIIIIILjava/nio/Buffer;)V

    .line 703
    const v6, 0x8d40

    invoke-static {v6, v0}, Landroid/opengl/GLES20;->glBindFramebuffer(II)V

    .line 704
    const-string v0, "EglRenderer.notifyCallbacks"

    invoke-static {v0}, Lorg/webrtc/ali/GlUtil;->checkNoGLES2Error(Ljava/lang/String;)V

    .line 706
    sget-object v0, Landroid/graphics/Bitmap$Config;->ARGB_8888:Landroid/graphics/Bitmap$Config;

    invoke-static {v15, v5, v0}, Landroid/graphics/Bitmap;->createBitmap(IILandroid/graphics/Bitmap$Config;)Landroid/graphics/Bitmap;

    move-result-object v0

    .line 707
    .local v0, "bitmap":Landroid/graphics/Bitmap;
    invoke-virtual {v0, v13}, Landroid/graphics/Bitmap;->copyPixelsFromBuffer(Ljava/nio/Buffer;)V

    .line 708
    iget-object v6, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->listener:Lorg/webrtc/ali/EglRenderer$FrameListener;

    invoke-interface {v6, v0}, Lorg/webrtc/ali/EglRenderer$FrameListener;->onFrame(Landroid/graphics/Bitmap;)V

    .line 709
    .end local v0    # "bitmap":Landroid/graphics/Bitmap;
    .end local v5    # "scaledHeight":I
    .end local v13    # "bitmapBuffer":Ljava/nio/ByteBuffer;
    .end local v14    # "listenerAndParams":Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;
    .end local v15    # "scaledWidth":I
    move-object/from16 v0, p0

    goto/16 :goto_2e

    .line 674
    .local v13, "scaledHeight":I
    .restart local v14    # "listenerAndParams":Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;
    .restart local v15    # "scaledWidth":I
    :cond_100
    move v5, v13

    .line 675
    .end local v13    # "scaledHeight":I
    .restart local v5    # "scaledHeight":I
    :goto_101
    iget-object v0, v14, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->listener:Lorg/webrtc/ali/EglRenderer$FrameListener;

    const/4 v6, 0x0

    invoke-interface {v0, v6}, Lorg/webrtc/ali/EglRenderer$FrameListener;->onFrame(Landroid/graphics/Bitmap;)V

    .line 676
    move-object/from16 v0, p0

    goto/16 :goto_2e

    .line 710
    .end local v5    # "scaledHeight":I
    .end local v14    # "listenerAndParams":Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;
    .end local v15    # "scaledWidth":I
    :cond_10b
    return-void
.end method

.method private postToRenderThread(Ljava/lang/Runnable;)V
    .registers 4
    .param p1, "runnable"    # Ljava/lang/Runnable;

    .line 496
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v0

    .line 497
    :try_start_3
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-eqz v1, :cond_c

    .line 498
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    invoke-virtual {v1, p1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    .line 500
    :cond_c
    monitor-exit v0

    .line 501
    return-void

    .line 500
    :catchall_e
    move-exception v1

    monitor-exit v0
    :try_end_10
    .catchall {:try_start_3 .. :try_end_10} :catchall_e

    throw v1
.end method

.method private renderFrameOnRenderThread()V
    .registers 25

    .line 542
    move-object/from16 v1, p0

    iget-object v2, v1, Lorg/webrtc/ali/EglRenderer;->frameLock:Ljava/lang/Object;

    monitor-enter v2

    .line 543
    :try_start_5
    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    if-nez v0, :cond_b

    .line 544
    monitor-exit v2

    return-void

    .line 546
    :cond_b
    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    move-object v3, v0

    .line 547
    .local v3, "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    const/4 v0, 0x0

    iput-object v0, v1, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    .line 548
    monitor-exit v2
    :try_end_12
    .catchall {:try_start_5 .. :try_end_12} :catchall_19c

    .line 549
    iget-object v2, v1, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    if-eqz v2, :cond_193

    invoke-virtual {v2}, Lorg/webrtc/ali/EglBase;->hasSurface()Z

    move-result v2

    if-nez v2, :cond_1e

    goto/16 :goto_193

    .line 556
    :cond_1e
    iget-object v2, v1, Lorg/webrtc/ali/EglRenderer;->fpsReductionLock:Ljava/lang/Object;

    monitor-enter v2

    .line 557
    :try_start_21
    iget-wide v4, v1, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    const-wide v6, 0x7fffffffffffffffL

    cmp-long v8, v4, v6

    if-nez v8, :cond_2e

    .line 559
    const/4 v4, 0x0

    .local v4, "shouldRenderFrame":Z
    goto :goto_59

    .line 560
    .end local v4    # "shouldRenderFrame":Z
    :cond_2e
    iget-wide v4, v1, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    const-wide/16 v6, 0x0

    cmp-long v8, v4, v6

    if-gtz v8, :cond_38

    .line 562
    const/4 v4, 0x1

    .restart local v4    # "shouldRenderFrame":Z
    goto :goto_59

    .line 564
    .end local v4    # "shouldRenderFrame":Z
    :cond_38
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v4

    .line 565
    .local v4, "currentTimeNs":J
    iget-wide v6, v1, Lorg/webrtc/ali/EglRenderer;->nextFrameTimeNs:J

    cmp-long v8, v4, v6

    if-gez v8, :cond_4a

    .line 566
    const-string v6, "Skipping frame rendering - fps reduction is active."

    invoke-direct {v1, v6}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 567
    const/4 v6, 0x0

    move v4, v6

    .local v6, "shouldRenderFrame":Z
    goto :goto_59

    .line 569
    .end local v6    # "shouldRenderFrame":Z
    :cond_4a
    iget-wide v6, v1, Lorg/webrtc/ali/EglRenderer;->nextFrameTimeNs:J

    iget-wide v8, v1, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    add-long/2addr v6, v8

    iput-wide v6, v1, Lorg/webrtc/ali/EglRenderer;->nextFrameTimeNs:J

    .line 571
    invoke-static {v6, v7, v4, v5}, Ljava/lang/Math;->max(JJ)J

    move-result-wide v6

    iput-wide v6, v1, Lorg/webrtc/ali/EglRenderer;->nextFrameTimeNs:J

    .line 572
    const/4 v6, 0x1

    move v4, v6

    .line 575
    .local v4, "shouldRenderFrame":Z
    :goto_59
    monitor-exit v2
    :try_end_5a
    .catchall {:try_start_21 .. :try_end_5a} :catchall_190

    .line 577
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v5

    .line 578
    .local v5, "startTimeNs":J
    iget-object v2, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->samplingMatrix:[F

    iget v7, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotationDegree:I

    int-to-float v7, v7

    .line 579
    invoke-static {v2, v7}, Lorg/webrtc/ali/RendererCommon;->rotateTextureMatrix([FF)[F

    move-result-object v7

    .line 587
    .local v7, "texMatrix":[F
    iget-object v8, v1, Lorg/webrtc/ali/EglRenderer;->layoutLock:Ljava/lang/Object;

    monitor-enter v8

    .line 589
    :try_start_6a
    iget v2, v1, Lorg/webrtc/ali/EglRenderer;->layoutAspectRatio:F

    const/4 v9, 0x0

    cmpl-float v2, v2, v9

    if-lez v2, :cond_aa

    .line 590
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v2

    int-to-float v2, v2

    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v10

    int-to-float v10, v10

    div-float/2addr v2, v10

    .line 591
    .local v2, "frameAspectRatio":F
    iget-boolean v10, v1, Lorg/webrtc/ali/EglRenderer;->mirror:Z

    iget v11, v1, Lorg/webrtc/ali/EglRenderer;->layoutAspectRatio:F

    invoke-static {v10, v2, v11}, Lorg/webrtc/ali/RendererCommon;->getLayoutMatrix(ZFF)[F

    move-result-object v10

    .line 592
    .local v10, "layoutMatrix":[F
    iget v11, v1, Lorg/webrtc/ali/EglRenderer;->layoutAspectRatio:F

    cmpl-float v11, v2, v11

    if-lez v11, :cond_99

    .line 593
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v11

    int-to-float v11, v11

    iget v12, v1, Lorg/webrtc/ali/EglRenderer;->layoutAspectRatio:F

    mul-float v11, v11, v12

    float-to-int v11, v11

    .line 594
    .local v11, "drawnFrameWidth":I
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v12

    .local v12, "drawnFrameHeight":I
    goto :goto_a6

    .line 596
    .end local v11    # "drawnFrameWidth":I
    .end local v12    # "drawnFrameHeight":I
    :cond_99
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v11

    .line 597
    .restart local v11    # "drawnFrameWidth":I
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v12

    int-to-float v12, v12

    iget v13, v1, Lorg/webrtc/ali/EglRenderer;->layoutAspectRatio:F

    div-float/2addr v12, v13

    float-to-int v12, v12

    .line 599
    .end local v2    # "frameAspectRatio":F
    .restart local v12    # "drawnFrameHeight":I
    :goto_a6
    move v2, v11

    move/from16 v23, v12

    goto :goto_c5

    .line 600
    .end local v10    # "layoutMatrix":[F
    .end local v11    # "drawnFrameWidth":I
    .end local v12    # "drawnFrameHeight":I
    :cond_aa
    iget-boolean v2, v1, Lorg/webrtc/ali/EglRenderer;->mirror:Z

    if-eqz v2, :cond_b3

    .line 601
    invoke-static {}, Lorg/webrtc/ali/RendererCommon;->horizontalFlipMatrix()[F

    move-result-object v2

    goto :goto_b7

    :cond_b3
    invoke-static {}, Lorg/webrtc/ali/RendererCommon;->identityMatrix()[F

    move-result-object v2

    :goto_b7
    move-object v10, v2

    .line 602
    .restart local v10    # "layoutMatrix":[F
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedWidth()I

    move-result v2

    move v11, v2

    .line 603
    .restart local v11    # "drawnFrameWidth":I
    invoke-virtual {v3}, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotatedHeight()I

    move-result v2

    move v12, v2

    move v2, v11

    move/from16 v23, v12

    .line 605
    .end local v11    # "drawnFrameWidth":I
    .local v2, "drawnFrameWidth":I
    .local v23, "drawnFrameHeight":I
    :goto_c5
    invoke-static {v7, v10}, Lorg/webrtc/ali/RendererCommon;->multiplyMatrices([F[F)[F

    move-result-object v13

    .line 606
    .end local v10    # "layoutMatrix":[F
    .local v13, "drawMatrix":[F
    monitor-exit v8
    :try_end_ca
    .catchall {:try_start_6a .. :try_end_ca} :catchall_18d

    .line 608
    const/4 v8, 0x0

    .line 609
    .local v8, "shouldUploadYuvTextures":Z
    iget-boolean v10, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvFrame:Z

    if-eqz v10, :cond_f3

    .line 610
    move v8, v4

    .line 613
    if-nez v8, :cond_f3

    .line 614
    iget-object v10, v1, Lorg/webrtc/ali/EglRenderer;->frameListeners:Ljava/util/ArrayList;

    invoke-virtual {v10}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object v10

    :goto_d8
    invoke-interface {v10}, Ljava/util/Iterator;->hasNext()Z

    move-result v11

    if-eqz v11, :cond_f3

    invoke-interface {v10}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v11

    check-cast v11, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;

    .line 615
    .local v11, "listenerAndParams":Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;
    iget v12, v11, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->scale:F

    cmpl-float v12, v12, v9

    if-eqz v12, :cond_f2

    if-nez v4, :cond_f0

    iget-boolean v12, v11, Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;->applyFpsReduction:Z

    if-nez v12, :cond_f2

    .line 617
    :cond_f0
    const/4 v8, 0x1

    .line 618
    goto :goto_f3

    .line 620
    .end local v11    # "listenerAndParams":Lorg/webrtc/ali/EglRenderer$FrameListenerAndParams;
    :cond_f2
    goto :goto_d8

    .line 623
    :cond_f3
    :goto_f3
    if-eqz v8, :cond_104

    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->yuvUploader:Lorg/webrtc/ali/RendererCommon$YuvUploader;

    iget v10, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->width:I

    iget v11, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->height:I

    iget-object v12, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvStrides:[I

    iget-object v14, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvPlanes:[Ljava/nio/ByteBuffer;

    .line 624
    invoke-virtual {v0, v10, v11, v12, v14}, Lorg/webrtc/ali/RendererCommon$YuvUploader;->uploadYuvData(II[I[Ljava/nio/ByteBuffer;)[I

    move-result-object v0

    goto :goto_105

    :cond_104
    nop

    :goto_105
    move-object v10, v0

    .line 627
    .local v10, "yuvTextures":[I
    if-eqz v4, :cond_180

    .line 628
    invoke-static {v9, v9, v9, v9}, Landroid/opengl/GLES20;->glClearColor(FFFF)V

    .line 629
    const/16 v0, 0x4000

    invoke-static {v0}, Landroid/opengl/GLES20;->glClear(I)V

    .line 630
    iget-boolean v0, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvFrame:Z

    if-eqz v0, :cond_12e

    .line 631
    iget-object v11, v1, Lorg/webrtc/ali/EglRenderer;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    const/16 v16, 0x0

    const/16 v17, 0x0

    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    .line 632
    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->surfaceWidth()I

    move-result v18

    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->surfaceHeight()I

    move-result v19

    .line 631
    move-object v12, v10

    move v14, v2

    move/from16 v15, v23

    invoke-interface/range {v11 .. v19}, Lorg/webrtc/ali/RendererCommon$GlDrawer;->drawYuv([I[FIIIIII)V

    goto :goto_14b

    .line 634
    :cond_12e
    iget-object v14, v1, Lorg/webrtc/ali/EglRenderer;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    iget v15, v3, Lorg/webrtc/ali/VideoRenderer$I420Frame;->textureId:I

    const/16 v19, 0x0

    const/16 v20, 0x0

    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    .line 635
    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->surfaceWidth()I

    move-result v21

    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->surfaceHeight()I

    move-result v22

    .line 634
    move-object/from16 v16, v13

    move/from16 v17, v2

    move/from16 v18, v23

    invoke-interface/range {v14 .. v22}, Lorg/webrtc/ali/RendererCommon$GlDrawer;->drawOes(I[FIIIIII)V

    .line 638
    :goto_14b
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v11

    .line 639
    .local v11, "swapBuffersStartTimeNs":J
    iget-object v0, v1, Lorg/webrtc/ali/EglRenderer;->eglBase:Lorg/webrtc/ali/EglBase;

    invoke-virtual {v0}, Lorg/webrtc/ali/EglBase;->swapBuffers()V

    .line 641
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v14

    .line 642
    .local v14, "currentTimeNs":J
    iget-object v9, v1, Lorg/webrtc/ali/EglRenderer;->statisticsLock:Ljava/lang/Object;

    monitor-enter v9

    .line 643
    :try_start_15b
    iget v0, v1, Lorg/webrtc/ali/EglRenderer;->framesRendered:I

    add-int/lit8 v0, v0, 0x1

    iput v0, v1, Lorg/webrtc/ali/EglRenderer;->framesRendered:I
    :try_end_161
    .catchall {:try_start_15b .. :try_end_161} :catchall_177

    .line 644
    move/from16 v17, v2

    move-object/from16 v16, v3

    .end local v2    # "drawnFrameWidth":I
    .end local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .local v16, "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .local v17, "drawnFrameWidth":I
    :try_start_165
    iget-wide v2, v1, Lorg/webrtc/ali/EglRenderer;->renderTimeNs:J

    sub-long v18, v14, v5

    add-long v2, v2, v18

    iput-wide v2, v1, Lorg/webrtc/ali/EglRenderer;->renderTimeNs:J

    .line 645
    iget-wide v2, v1, Lorg/webrtc/ali/EglRenderer;->renderSwapBufferTimeNs:J

    sub-long v18, v14, v11

    add-long v2, v2, v18

    iput-wide v2, v1, Lorg/webrtc/ali/EglRenderer;->renderSwapBufferTimeNs:J

    .line 646
    monitor-exit v9

    goto :goto_184

    .end local v16    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .end local v17    # "drawnFrameWidth":I
    .restart local v2    # "drawnFrameWidth":I
    .restart local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    :catchall_177
    move-exception v0

    move/from16 v17, v2

    move-object/from16 v16, v3

    .end local v2    # "drawnFrameWidth":I
    .end local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .restart local v16    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .restart local v17    # "drawnFrameWidth":I
    :goto_17c
    monitor-exit v9
    :try_end_17d
    .catchall {:try_start_165 .. :try_end_17d} :catchall_17e

    throw v0

    :catchall_17e
    move-exception v0

    goto :goto_17c

    .line 627
    .end local v11    # "swapBuffersStartTimeNs":J
    .end local v14    # "currentTimeNs":J
    .end local v16    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .end local v17    # "drawnFrameWidth":I
    .restart local v2    # "drawnFrameWidth":I
    .restart local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    :cond_180
    move/from16 v17, v2

    move-object/from16 v16, v3

    .line 649
    .end local v2    # "drawnFrameWidth":I
    .end local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .restart local v16    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .restart local v17    # "drawnFrameWidth":I
    :goto_184
    move-object/from16 v3, v16

    .end local v16    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    .restart local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    invoke-direct {v1, v3, v10, v7, v4}, Lorg/webrtc/ali/EglRenderer;->notifyCallbacks(Lorg/webrtc/ali/VideoRenderer$I420Frame;[I[FZ)V

    .line 650
    invoke-static {v3}, Lorg/webrtc/ali/VideoRenderer;->renderFrameDone(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    .line 651
    return-void

    .line 606
    .end local v8    # "shouldUploadYuvTextures":Z
    .end local v10    # "yuvTextures":[I
    .end local v13    # "drawMatrix":[F
    .end local v17    # "drawnFrameWidth":I
    .end local v23    # "drawnFrameHeight":I
    :catchall_18d
    move-exception v0

    :try_start_18e
    monitor-exit v8
    :try_end_18f
    .catchall {:try_start_18e .. :try_end_18f} :catchall_18d

    throw v0

    .line 575
    .end local v4    # "shouldRenderFrame":Z
    .end local v5    # "startTimeNs":J
    .end local v7    # "texMatrix":[F
    :catchall_190
    move-exception v0

    :try_start_191
    monitor-exit v2
    :try_end_192
    .catchall {:try_start_191 .. :try_end_192} :catchall_190

    throw v0

    .line 550
    :cond_193
    :goto_193
    const-string v0, "Dropping frame - No surface"

    invoke-direct {v1, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 551
    invoke-static {v3}, Lorg/webrtc/ali/VideoRenderer;->renderFrameDone(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    .line 552
    return-void

    .line 548
    .end local v3    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    :catchall_19c
    move-exception v0

    :try_start_19d
    monitor-exit v2
    :try_end_19e
    .catchall {:try_start_19d .. :try_end_19e} :catchall_19c

    goto :goto_1a0

    :goto_19f
    throw v0

    :goto_1a0
    goto :goto_19f
.end method

.method private resetStatistics(J)V
    .registers 6
    .param p1, "currentTimeNs"    # J

    .line 283
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->statisticsLock:Ljava/lang/Object;

    monitor-enter v0

    .line 284
    :try_start_3
    iput-wide p1, p0, Lorg/webrtc/ali/EglRenderer;->statisticsStartTimeNs:J

    .line 285
    const/4 v1, 0x0

    iput v1, p0, Lorg/webrtc/ali/EglRenderer;->framesReceived:I

    .line 286
    iput v1, p0, Lorg/webrtc/ali/EglRenderer;->framesDropped:I

    .line 287
    iput v1, p0, Lorg/webrtc/ali/EglRenderer;->framesRendered:I

    .line 288
    const-wide/16 v1, 0x0

    iput-wide v1, p0, Lorg/webrtc/ali/EglRenderer;->renderTimeNs:J

    .line 289
    iput-wide v1, p0, Lorg/webrtc/ali/EglRenderer;->renderSwapBufferTimeNs:J

    .line 290
    monitor-exit v0

    .line 291
    return-void

    .line 290
    :catchall_14
    move-exception v1

    monitor-exit v0
    :try_end_16
    .catchall {:try_start_3 .. :try_end_16} :catchall_14

    throw v1
.end method


# virtual methods
.method public addFrameListener(Lorg/webrtc/ali/EglRenderer$FrameListener;F)V
    .registers 5
    .param p1, "listener"    # Lorg/webrtc/ali/EglRenderer$FrameListener;
    .param p2, "scale"    # F

    .line 370
    const/4 v0, 0x0

    const/4 v1, 0x0

    invoke-virtual {p0, p1, p2, v0, v1}, Lorg/webrtc/ali/EglRenderer;->addFrameListener(Lorg/webrtc/ali/EglRenderer$FrameListener;FLorg/webrtc/ali/RendererCommon$GlDrawer;Z)V

    .line 371
    return-void
.end method

.method public addFrameListener(Lorg/webrtc/ali/EglRenderer$FrameListener;FLorg/webrtc/ali/RendererCommon$GlDrawer;)V
    .registers 5
    .param p1, "listener"    # Lorg/webrtc/ali/EglRenderer$FrameListener;
    .param p2, "scale"    # F
    .param p3, "drawerParam"    # Lorg/webrtc/ali/RendererCommon$GlDrawer;

    .line 384
    const/4 v0, 0x0

    invoke-virtual {p0, p1, p2, p3, v0}, Lorg/webrtc/ali/EglRenderer;->addFrameListener(Lorg/webrtc/ali/EglRenderer$FrameListener;FLorg/webrtc/ali/RendererCommon$GlDrawer;Z)V

    .line 385
    return-void
.end method

.method public addFrameListener(Lorg/webrtc/ali/EglRenderer$FrameListener;FLorg/webrtc/ali/RendererCommon$GlDrawer;Z)V
    .registers 12
    .param p1, "listener"    # Lorg/webrtc/ali/EglRenderer$FrameListener;
    .param p2, "scale"    # F
    .param p3, "drawerParam"    # Lorg/webrtc/ali/RendererCommon$GlDrawer;
    .param p4, "applyFpsReduction"    # Z

    .line 400
    new-instance v6, Lorg/webrtc/ali/EglRenderer$6;

    move-object v0, v6

    move-object v1, p0

    move-object v2, p3

    move-object v3, p1

    move v4, p2

    move v5, p4

    invoke-direct/range {v0 .. v5}, Lorg/webrtc/ali/EglRenderer$6;-><init>(Lorg/webrtc/ali/EglRenderer;Lorg/webrtc/ali/RendererCommon$GlDrawer;Lorg/webrtc/ali/EglRenderer$FrameListener;FZ)V

    invoke-direct {p0, v6}, Lorg/webrtc/ali/EglRenderer;->postToRenderThread(Ljava/lang/Runnable;)V

    .line 408
    return-void
.end method

.method public clearImage()V
    .registers 2

    .line 516
    const/4 v0, 0x0

    invoke-virtual {p0, v0, v0, v0, v0}, Lorg/webrtc/ali/EglRenderer;->clearImage(FFFF)V

    .line 517
    return-void
.end method

.method public clearImage(FFFF)V
    .registers 14
    .param p1, "r"    # F
    .param p2, "g"    # F
    .param p3, "b"    # F
    .param p4, "a"    # F

    .line 523
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v0

    .line 524
    :try_start_3
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-nez v1, :cond_9

    .line 525
    monitor-exit v0

    return-void

    .line 527
    :cond_9
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    new-instance v8, Lorg/webrtc/ali/EglRenderer$9;

    move-object v2, v8

    move-object v3, p0

    move v4, p1

    move v5, p2

    move v6, p3

    move v7, p4

    invoke-direct/range {v2 .. v7}, Lorg/webrtc/ali/EglRenderer$9;-><init>(Lorg/webrtc/ali/EglRenderer;FFFF)V

    invoke-virtual {v1, v8}, Landroid/os/Handler;->postAtFrontOfQueue(Ljava/lang/Runnable;)Z

    .line 533
    monitor-exit v0

    .line 534
    return-void

    .line 533
    :catchall_1b
    move-exception v1

    monitor-exit v0
    :try_end_1d
    .catchall {:try_start_3 .. :try_end_1d} :catchall_1b

    throw v1
.end method

.method public createEglSurface(Landroid/graphics/SurfaceTexture;)V
    .registers 2
    .param p1, "surfaceTexture"    # Landroid/graphics/SurfaceTexture;

    .line 211
    invoke-direct {p0, p1}, Lorg/webrtc/ali/EglRenderer;->createEglSurfaceInternal(Ljava/lang/Object;)V

    .line 212
    return-void
.end method

.method public createEglSurface(Landroid/view/Surface;)V
    .registers 2
    .param p1, "surface"    # Landroid/view/Surface;

    .line 207
    invoke-direct {p0, p1}, Lorg/webrtc/ali/EglRenderer;->createEglSurfaceInternal(Ljava/lang/Object;)V

    .line 208
    return-void
.end method

.method public disableFpsReduction()V
    .registers 2

    .line 353
    const/high16 v0, 0x7f800000    # Float.POSITIVE_INFINITY

    invoke-virtual {p0, v0}, Lorg/webrtc/ali/EglRenderer;->setFpsReduction(F)V

    .line 354
    return-void
.end method

.method public init(Lorg/webrtc/ali/EglBase$Context;[ILorg/webrtc/ali/RendererCommon$GlDrawer;)V
    .registers 13
    .param p1, "sharedContext"    # Lorg/webrtc/ali/EglBase$Context;
    .param p2, "configAttributes"    # [I
    .param p3, "drawer"    # Lorg/webrtc/ali/RendererCommon$GlDrawer;

    .line 170
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v0

    .line 171
    :try_start_3
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-nez v1, :cond_5c

    .line 174
    const-string v1, "Initializing EglRenderer"

    invoke-direct {p0, v1}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 175
    iput-object p3, p0, Lorg/webrtc/ali/EglRenderer;->drawer:Lorg/webrtc/ali/RendererCommon$GlDrawer;

    .line 177
    new-instance v1, Landroid/os/HandlerThread;

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    iget-object v3, p0, Lorg/webrtc/ali/EglRenderer;->name:Ljava/lang/String;

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, "EglRenderer"

    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

    invoke-direct {v1, v2}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V

    .line 178
    .local v1, "renderThread":Landroid/os/HandlerThread;
    invoke-virtual {v1}, Landroid/os/HandlerThread;->start()V

    .line 179
    new-instance v2, Landroid/os/Handler;

    invoke-virtual {v1}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;

    move-result-object v3

    invoke-direct {v2, v3}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V

    iput-object v2, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    .line 183
    new-instance v3, Lorg/webrtc/ali/EglRenderer$3;

    invoke-direct {v3, p0, p1, p2}, Lorg/webrtc/ali/EglRenderer$3;-><init>(Lorg/webrtc/ali/EglRenderer;Lorg/webrtc/ali/EglBase$Context;[I)V

    invoke-static {v2, v3}, Lorg/webrtc/ali/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;Ljava/lang/Runnable;)V

    .line 198
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    iget-object v3, p0, Lorg/webrtc/ali/EglRenderer;->eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    invoke-virtual {v2, v3}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    .line 199
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v2

    .line 200
    .local v2, "currentTimeNs":J
    invoke-direct {p0, v2, v3}, Lorg/webrtc/ali/EglRenderer;->resetStatistics(J)V

    .line 201
    iget-object v4, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    iget-object v5, p0, Lorg/webrtc/ali/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;

    sget-object v6, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;

    const-wide/16 v7, 0x4

    .line 202
    invoke-virtual {v6, v7, v8}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J

    move-result-wide v6

    .line 201
    invoke-virtual {v4, v5, v6, v7}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z

    .line 203
    nop

    .end local v1    # "renderThread":Landroid/os/HandlerThread;
    .end local v2    # "currentTimeNs":J
    monitor-exit v0

    .line 204
    return-void

    .line 172
    :cond_5c
    new-instance v1, Ljava/lang/IllegalStateException;

    new-instance v2, Ljava/lang/StringBuilder;

    invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V

    iget-object v3, p0, Lorg/webrtc/ali/EglRenderer;->name:Ljava/lang/String;

    invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v3, "Already initialized"

    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

    invoke-direct {v1, v2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V

    .end local p1    # "sharedContext":Lorg/webrtc/ali/EglBase$Context;
    .end local p2    # "configAttributes":[I
    .end local p3    # "drawer":Lorg/webrtc/ali/RendererCommon$GlDrawer;
    throw v1

    .line 203
    .restart local p1    # "sharedContext":Lorg/webrtc/ali/EglBase$Context;
    .restart local p2    # "configAttributes":[I
    .restart local p3    # "drawer":Lorg/webrtc/ali/RendererCommon$GlDrawer;
    :catchall_75
    move-exception v1

    monitor-exit v0
    :try_end_77
    .catchall {:try_start_3 .. :try_end_77} :catchall_75

    throw v1
.end method

.method public pauseVideo()V
    .registers 2

    .line 357
    const/4 v0, 0x0

    invoke-virtual {p0, v0}, Lorg/webrtc/ali/EglRenderer;->setFpsReduction(F)V

    .line 358
    return-void
.end method

.method public printStackTrace()V
    .registers 8

    .line 294
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v0

    .line 295
    :try_start_3
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-nez v1, :cond_9

    const/4 v1, 0x0

    goto :goto_13

    :cond_9
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    .line 296
    invoke-virtual {v1}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-virtual {v1}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;

    move-result-object v1

    :goto_13
    nop

    .line 297
    .local v1, "renderThread":Ljava/lang/Thread;
    if-eqz v1, :cond_32

    .line 298
    invoke-virtual {v1}, Ljava/lang/Thread;->getStackTrace()[Ljava/lang/StackTraceElement;

    move-result-object v2

    .line 299
    .local v2, "renderStackTrace":[Ljava/lang/StackTraceElement;
    array-length v3, v2

    if-lez v3, :cond_32

    .line 300
    const-string v3, "EglRenderer stack trace:"

    invoke-direct {p0, v3}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 301
    array-length v3, v2

    const/4 v4, 0x0

    :goto_24
    if-ge v4, v3, :cond_32

    aget-object v5, v2, v4

    .line 302
    .local v5, "traceElem":Ljava/lang/StackTraceElement;
    invoke-virtual {v5}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;

    move-result-object v6

    invoke-direct {p0, v6}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 301
    .end local v5    # "traceElem":Ljava/lang/StackTraceElement;
    add-int/lit8 v4, v4, 0x1

    goto :goto_24

    .line 306
    .end local v1    # "renderThread":Ljava/lang/Thread;
    .end local v2    # "renderStackTrace":[Ljava/lang/StackTraceElement;
    :cond_32
    monitor-exit v0

    .line 307
    return-void

    .line 306
    :catchall_34
    move-exception v1

    monitor-exit v0
    :try_end_36
    .catchall {:try_start_3 .. :try_end_36} :catchall_34

    goto :goto_38

    :goto_37
    throw v1

    :goto_38
    goto :goto_37
.end method

.method public release()V
    .registers 6

    .line 226
    const-string v0, "Releasing."

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 227
    new-instance v0, Ljava/util/concurrent/CountDownLatch;

    const/4 v1, 0x1

    invoke-direct {v0, v1}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V

    .line 228
    .local v0, "eglCleanupBarrier":Ljava/util/concurrent/CountDownLatch;
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v1

    .line 229
    :try_start_e
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-nez v2, :cond_19

    .line 230
    const-string v2, "Already released"

    invoke-direct {p0, v2}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 231
    monitor-exit v1

    return-void

    .line 233
    :cond_19
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    iget-object v3, p0, Lorg/webrtc/ali/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;

    invoke-virtual {v2, v3}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V

    .line 235
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    new-instance v3, Lorg/webrtc/ali/EglRenderer$4;

    invoke-direct {v3, p0, v0}, Lorg/webrtc/ali/EglRenderer$4;-><init>(Lorg/webrtc/ali/EglRenderer;Ljava/util/concurrent/CountDownLatch;)V

    invoke-virtual {v2, v3}, Landroid/os/Handler;->postAtFrontOfQueue(Ljava/lang/Runnable;)Z

    .line 256
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    invoke-virtual {v2}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;

    move-result-object v2

    .line 258
    .local v2, "renderLooper":Landroid/os/Looper;
    iget-object v3, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    new-instance v4, Lorg/webrtc/ali/EglRenderer$5;

    invoke-direct {v4, p0, v2}, Lorg/webrtc/ali/EglRenderer$5;-><init>(Lorg/webrtc/ali/EglRenderer;Landroid/os/Looper;)V

    invoke-virtual {v3, v4}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    .line 266
    const/4 v3, 0x0

    iput-object v3, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    .line 267
    .end local v2    # "renderLooper":Landroid/os/Looper;
    monitor-exit v1
    :try_end_3e
    .catchall {:try_start_e .. :try_end_3e} :catchall_59

    .line 269
    invoke-static {v0}, Lorg/webrtc/ali/ThreadUtils;->awaitUninterruptibly(Ljava/util/concurrent/CountDownLatch;)V

    .line 270
    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->frameLock:Ljava/lang/Object;

    monitor-enter v2

    .line 271
    :try_start_44
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    if-eqz v1, :cond_4f

    .line 272
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    invoke-static {v1}, Lorg/webrtc/ali/VideoRenderer;->renderFrameDone(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    .line 273
    iput-object v3, p0, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    .line 275
    :cond_4f
    monitor-exit v2
    :try_end_50
    .catchall {:try_start_44 .. :try_end_50} :catchall_56

    .line 276
    const-string v1, "Releasing done."

    invoke-direct {p0, v1}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 277
    return-void

    .line 275
    :catchall_56
    move-exception v1

    :try_start_57
    monitor-exit v2
    :try_end_58
    .catchall {:try_start_57 .. :try_end_58} :catchall_56

    throw v1

    .line 267
    :catchall_59
    move-exception v2

    :try_start_5a
    monitor-exit v1
    :try_end_5b
    .catchall {:try_start_5a .. :try_end_5b} :catchall_59

    throw v2
.end method

.method public releaseEglSurface(Ljava/lang/Runnable;)V
    .registers 5
    .param p1, "completionCallback"    # Ljava/lang/Runnable;

    .line 472
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    const/4 v1, 0x0

    invoke-virtual {v0, v1}, Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;->setSurface(Ljava/lang/Object;)V

    .line 473
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v0

    .line 474
    :try_start_9
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-eqz v1, :cond_20

    .line 475
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    iget-object v2, p0, Lorg/webrtc/ali/EglRenderer;->eglSurfaceCreationRunnable:Lorg/webrtc/ali/EglRenderer$EglSurfaceCreation;

    invoke-virtual {v1, v2}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V

    .line 476
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    new-instance v2, Lorg/webrtc/ali/EglRenderer$8;

    invoke-direct {v2, p0, p1}, Lorg/webrtc/ali/EglRenderer$8;-><init>(Lorg/webrtc/ali/EglRenderer;Ljava/lang/Runnable;)V

    invoke-virtual {v1, v2}, Landroid/os/Handler;->postAtFrontOfQueue(Ljava/lang/Runnable;)Z

    .line 486
    monitor-exit v0

    return-void

    .line 488
    :cond_20
    monitor-exit v0
    :try_end_21
    .catchall {:try_start_9 .. :try_end_21} :catchall_25

    .line 489
    invoke-interface {p1}, Ljava/lang/Runnable;->run()V

    .line 490
    return-void

    .line 488
    :catchall_25
    move-exception v1

    :try_start_26
    monitor-exit v0
    :try_end_27
    .catchall {:try_start_26 .. :try_end_27} :catchall_25

    throw v1
.end method

.method public removeFrameListener(Lorg/webrtc/ali/EglRenderer$FrameListener;)V
    .registers 4
    .param p1, "listener"    # Lorg/webrtc/ali/EglRenderer$FrameListener;

    .line 418
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    invoke-virtual {v1}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-virtual {v1}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;

    move-result-object v1

    if-eq v0, v1, :cond_22

    .line 421
    new-instance v0, Ljava/util/concurrent/CountDownLatch;

    const/4 v1, 0x1

    invoke-direct {v0, v1}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V

    .line 422
    .local v0, "latch":Ljava/util/concurrent/CountDownLatch;
    new-instance v1, Lorg/webrtc/ali/EglRenderer$7;

    invoke-direct {v1, p0, v0, p1}, Lorg/webrtc/ali/EglRenderer$7;-><init>(Lorg/webrtc/ali/EglRenderer;Ljava/util/concurrent/CountDownLatch;Lorg/webrtc/ali/EglRenderer$FrameListener;)V

    invoke-direct {p0, v1}, Lorg/webrtc/ali/EglRenderer;->postToRenderThread(Ljava/lang/Runnable;)V

    .line 434
    invoke-static {v0}, Lorg/webrtc/ali/ThreadUtils;->awaitUninterruptibly(Ljava/util/concurrent/CountDownLatch;)V

    .line 435
    return-void

    .line 419
    .end local v0    # "latch":Ljava/util/concurrent/CountDownLatch;
    :cond_22
    new-instance v0, Ljava/lang/RuntimeException;

    const-string v1, "removeFrameListener must not be called on the render thread."

    invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V

    throw v0
.end method

.method public renderFrame(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V
    .registers 8
    .param p1, "frame"    # Lorg/webrtc/ali/VideoRenderer$I420Frame;

    .line 440
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->statisticsLock:Ljava/lang/Object;

    monitor-enter v0

    .line 441
    :try_start_3
    iget v1, p0, Lorg/webrtc/ali/EglRenderer;->framesReceived:I

    const/4 v2, 0x1

    add-int/2addr v1, v2

    iput v1, p0, Lorg/webrtc/ali/EglRenderer;->framesReceived:I

    .line 442
    monitor-exit v0
    :try_end_a
    .catchall {:try_start_3 .. :try_end_a} :catchall_4d

    .line 444
    iget-object v1, p0, Lorg/webrtc/ali/EglRenderer;->handlerLock:Ljava/lang/Object;

    monitor-enter v1

    .line 445
    :try_start_d
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    if-nez v0, :cond_1b

    .line 446
    const-string v0, "Dropping frame - Not initialized or already released."

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 447
    invoke-static {p1}, Lorg/webrtc/ali/VideoRenderer;->renderFrameDone(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    .line 448
    monitor-exit v1

    return-void

    .line 450
    :cond_1b
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->frameLock:Ljava/lang/Object;

    monitor-enter v0
    :try_end_1e
    .catchall {:try_start_d .. :try_end_1e} :catchall_4a

    .line 451
    :try_start_1e
    iget-object v3, p0, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    if-eqz v3, :cond_24

    const/4 v3, 0x1

    goto :goto_25

    :cond_24
    const/4 v3, 0x0

    .line 452
    .local v3, "dropOldFrame":Z
    :goto_25
    if-eqz v3, :cond_2c

    .line 453
    iget-object v4, p0, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    invoke-static {v4}, Lorg/webrtc/ali/VideoRenderer;->renderFrameDone(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    .line 455
    :cond_2c
    iput-object p1, p0, Lorg/webrtc/ali/EglRenderer;->pendingFrame:Lorg/webrtc/ali/VideoRenderer$I420Frame;

    .line 456
    iget-object v4, p0, Lorg/webrtc/ali/EglRenderer;->renderThreadHandler:Landroid/os/Handler;

    iget-object v5, p0, Lorg/webrtc/ali/EglRenderer;->renderFrameRunnable:Ljava/lang/Runnable;

    invoke-virtual {v4, v5}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    .line 457
    monitor-exit v0
    :try_end_36
    .catchall {:try_start_1e .. :try_end_36} :catchall_47

    .line 458
    :try_start_36
    monitor-exit v1
    :try_end_37
    .catchall {:try_start_36 .. :try_end_37} :catchall_4a

    .line 459
    if-eqz v3, :cond_46

    .line 460
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->statisticsLock:Ljava/lang/Object;

    monitor-enter v0

    .line 461
    :try_start_3c
    iget v1, p0, Lorg/webrtc/ali/EglRenderer;->framesDropped:I

    add-int/2addr v1, v2

    iput v1, p0, Lorg/webrtc/ali/EglRenderer;->framesDropped:I

    .line 462
    monitor-exit v0

    goto :goto_46

    :catchall_43
    move-exception v1

    monitor-exit v0
    :try_end_45
    .catchall {:try_start_3c .. :try_end_45} :catchall_43

    throw v1

    .line 464
    :cond_46
    :goto_46
    return-void

    .line 457
    .end local v3    # "dropOldFrame":Z
    :catchall_47
    move-exception v2

    :try_start_48
    monitor-exit v0
    :try_end_49
    .catchall {:try_start_48 .. :try_end_49} :catchall_47

    .end local p1    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    :try_start_49
    throw v2

    .line 458
    .restart local p1    # "frame":Lorg/webrtc/ali/VideoRenderer$I420Frame;
    :catchall_4a
    move-exception v0

    monitor-exit v1
    :try_end_4c
    .catchall {:try_start_49 .. :try_end_4c} :catchall_4a

    throw v0

    .line 442
    :catchall_4d
    move-exception v1

    :try_start_4e
    monitor-exit v0
    :try_end_4f
    .catchall {:try_start_4e .. :try_end_4f} :catchall_4d

    throw v1
.end method

.method public setFpsReduction(F)V
    .registers 8
    .param p1, "fps"    # F

    .line 337
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "setFpsReduction: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 338
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->fpsReductionLock:Ljava/lang/Object;

    monitor-enter v0

    .line 339
    :try_start_17
    iget-wide v1, p0, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    .line 340
    .local v1, "previousRenderPeriodNs":J
    const/4 v3, 0x0

    cmpg-float v3, p1, v3

    if-gtz v3, :cond_26

    .line 341
    const-wide v3, 0x7fffffffffffffffL

    iput-wide v3, p0, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    goto :goto_33

    .line 343
    :cond_26
    sget-object v3, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;

    const-wide/16 v4, 0x1

    invoke-virtual {v3, v4, v5}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J

    move-result-wide v3

    long-to-float v3, v3

    div-float/2addr v3, p1

    float-to-long v3, v3

    iput-wide v3, p0, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    .line 345
    :goto_33
    iget-wide v3, p0, Lorg/webrtc/ali/EglRenderer;->minRenderPeriodNs:J

    cmp-long v5, v3, v1

    if-eqz v5, :cond_3f

    .line 347
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v3

    iput-wide v3, p0, Lorg/webrtc/ali/EglRenderer;->nextFrameTimeNs:J

    .line 349
    .end local v1    # "previousRenderPeriodNs":J
    :cond_3f
    monitor-exit v0

    .line 350
    return-void

    .line 349
    :catchall_41
    move-exception v1

    monitor-exit v0
    :try_end_43
    .catchall {:try_start_17 .. :try_end_43} :catchall_41

    throw v1
.end method

.method public setLayoutAspectRatio(F)V
    .registers 4
    .param p1, "layoutAspectRatio"    # F

    .line 324
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "setLayoutAspectRatio: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 325
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->layoutLock:Ljava/lang/Object;

    monitor-enter v0

    .line 326
    :try_start_17
    iput p1, p0, Lorg/webrtc/ali/EglRenderer;->layoutAspectRatio:F

    .line 327
    monitor-exit v0

    .line 328
    return-void

    .line 327
    :catchall_1b
    move-exception v1

    monitor-exit v0
    :try_end_1d
    .catchall {:try_start_17 .. :try_end_1d} :catchall_1b

    throw v1
.end method

.method public setMirror(Z)V
    .registers 4
    .param p1, "mirror"    # Z

    .line 313
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "setMirror: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-direct {p0, v0}, Lorg/webrtc/ali/EglRenderer;->logD(Ljava/lang/String;)V

    .line 314
    iget-object v0, p0, Lorg/webrtc/ali/EglRenderer;->layoutLock:Ljava/lang/Object;

    monitor-enter v0

    .line 315
    :try_start_17
    iput-boolean p1, p0, Lorg/webrtc/ali/EglRenderer;->mirror:Z

    .line 316
    monitor-exit v0

    .line 317
    return-void

    .line 316
    :catchall_1b
    move-exception v1

    monitor-exit v0
    :try_end_1d
    .catchall {:try_start_17 .. :try_end_1d} :catchall_1b

    throw v1
.end method