VideoFileRenderer.smali

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

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


# static fields
.field private static final TAG:Ljava/lang/String; = "VideoFileRenderer"


# instance fields
.field private eglBase:Lorg/webrtc/ali/EglBase;

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

.field private final outputFileHeight:I

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

.field private final outputFileWidth:I

.field private final outputFrameBuffer:Ljava/nio/ByteBuffer;

.field private final outputFrameSize:I

.field private rawFrames:Ljava/util/ArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/ArrayList<",
            "Ljava/nio/ByteBuffer;",
            ">;"
        }
    .end annotation
.end field

.field private final renderThread:Landroid/os/HandlerThread;

.field private final renderThreadHandler:Landroid/os/Handler;

.field private final videoOutFile:Ljava/io/FileOutputStream;

.field private yuvConverter:Lorg/webrtc/ali/YuvConverter;


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

    .line 27
    return-void
.end method

.method public constructor <init>(Ljava/lang/String;IILorg/webrtc/ali/EglBase$Context;)V
    .registers 8
    .param p1, "outputFile"    # Ljava/lang/String;
    .param p2, "outputFileWidth"    # I
    .param p3, "outputFileHeight"    # I
    .param p4, "sharedContext"    # Lorg/webrtc/ali/EglBase$Context;
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/io/IOException;
        }
    .end annotation

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

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

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

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

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

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

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

    .line 46
    rem-int/lit8 v0, p2, 0x2

    const/4 v1, 0x1

    if-eq v0, v1, :cond_7c

    rem-int/lit8 v0, p3, 0x2

    if-eq v0, v1, :cond_7c

    .line 50
    iput-object p1, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFileName:Ljava/lang/String;

    .line 51
    iput p2, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    .line 52
    iput p3, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    .line 54
    mul-int v0, p2, p3

    mul-int/lit8 v0, v0, 0x3

    div-int/lit8 v0, v0, 0x2

    iput v0, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameSize:I

    .line 55
    invoke-static {v0}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;

    move-result-object v0

    iput-object v0, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    .line 57
    new-instance v0, Ljava/io/FileOutputStream;

    invoke-direct {v0, p1}, Ljava/io/FileOutputStream;-><init>(Ljava/lang/String;)V

    iput-object v0, p0, Lorg/webrtc/ali/VideoFileRenderer;->videoOutFile:Ljava/io/FileOutputStream;

    .line 58
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "YUV4MPEG2 C420 W"

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

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

    const-string v2, " H"

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

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

    const-string v2, " Ip F30:1 A1:1\n"

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

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

    move-result-object v1

    .line 60
    invoke-virtual {v1}, Ljava/lang/String;->getBytes()[B

    move-result-object v1

    .line 58
    invoke-virtual {v0, v1}, Ljava/io/FileOutputStream;->write([B)V

    .line 62
    new-instance v0, Landroid/os/HandlerThread;

    const-string v1, "VideoFileRenderer"

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

    iput-object v0, p0, Lorg/webrtc/ali/VideoFileRenderer;->renderThread:Landroid/os/HandlerThread;

    .line 63
    invoke-virtual {v0}, Landroid/os/HandlerThread;->start()V

    .line 64
    new-instance v0, Landroid/os/Handler;

    iget-object v1, p0, Lorg/webrtc/ali/VideoFileRenderer;->renderThread:Landroid/os/HandlerThread;

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

    move-result-object v1

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

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

    .line 66
    new-instance v1, Lorg/webrtc/ali/VideoFileRenderer$1;

    invoke-direct {v1, p0, p4}, Lorg/webrtc/ali/VideoFileRenderer$1;-><init>(Lorg/webrtc/ali/VideoFileRenderer;Lorg/webrtc/ali/EglBase$Context;)V

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

    .line 75
    return-void

    .line 47
    :cond_7c
    new-instance v0, Ljava/lang/IllegalArgumentException;

    const-string v1, "Does not support uneven width or height"

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

    throw v0
.end method

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

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

    return-object v0
.end method

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

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

    return-object p1
.end method

.method static synthetic access$100(Lorg/webrtc/ali/VideoFileRenderer;)Lorg/webrtc/ali/YuvConverter;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/VideoFileRenderer;

    .line 24
    iget-object v0, p0, Lorg/webrtc/ali/VideoFileRenderer;->yuvConverter:Lorg/webrtc/ali/YuvConverter;

    return-object v0
.end method

.method static synthetic access$102(Lorg/webrtc/ali/VideoFileRenderer;Lorg/webrtc/ali/YuvConverter;)Lorg/webrtc/ali/YuvConverter;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/VideoFileRenderer;
    .param p1, "x1"    # Lorg/webrtc/ali/YuvConverter;

    .line 24
    iput-object p1, p0, Lorg/webrtc/ali/VideoFileRenderer;->yuvConverter:Lorg/webrtc/ali/YuvConverter;

    return-object p1
.end method

.method static synthetic access$200(Lorg/webrtc/ali/VideoFileRenderer;Lorg/webrtc/ali/VideoRenderer$I420Frame;)V
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/VideoFileRenderer;
    .param p1, "x1"    # Lorg/webrtc/ali/VideoRenderer$I420Frame;

    .line 24
    invoke-direct {p0, p1}, Lorg/webrtc/ali/VideoFileRenderer;->renderFrameOnRenderThread(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    return-void
.end method

.method static synthetic access$300(Lorg/webrtc/ali/VideoFileRenderer;)Landroid/os/HandlerThread;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/VideoFileRenderer;

    .line 24
    iget-object v0, p0, Lorg/webrtc/ali/VideoFileRenderer;->renderThread:Landroid/os/HandlerThread;

    return-object v0
.end method

.method public static native nativeCreateNativeByteBuffer(I)Ljava/nio/ByteBuffer;
.end method

.method public static native nativeFreeNativeByteBuffer(Ljava/nio/ByteBuffer;)V
.end method

.method public static native nativeI420Scale(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;ILjava/nio/ByteBuffer;IIILjava/nio/ByteBuffer;II)V
.end method

.method private renderFrameOnRenderThread(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V
    .registers 29
    .param p1, "frame"    # Lorg/webrtc/ali/VideoRenderer$I420Frame;

    .line 88
    move-object/from16 v1, p0

    move-object/from16 v2, p1

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

    move-result v0

    int-to-float v0, v0

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

    move-result v3

    int-to-float v3, v3

    div-float v3, v0, v3

    .line 90
    .local v3, "frameAspectRatio":F
    iget-object v0, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->samplingMatrix:[F

    iget v4, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->rotationDegree:I

    int-to-float v4, v4

    .line 91
    invoke-static {v0, v4}, Lorg/webrtc/ali/RendererCommon;->rotateTextureMatrix([FF)[F

    move-result-object v4

    .line 92
    .local v4, "rotatedSamplingMatrix":[F
    iget v0, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    int-to-float v0, v0

    iget v5, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    int-to-float v5, v5

    div-float/2addr v0, v5

    const/4 v5, 0x0

    invoke-static {v5, v3, v0}, Lorg/webrtc/ali/RendererCommon;->getLayoutMatrix(ZFF)[F

    move-result-object v6

    .line 94
    .local v6, "layoutMatrix":[F
    invoke-static {v4, v6}, Lorg/webrtc/ali/RendererCommon;->multiplyMatrices([F[F)[F

    move-result-object v14

    .line 97
    .local v14, "texMatrix":[F
    :try_start_29
    iget v0, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameSize:I

    invoke-static {v0}, Lorg/webrtc/ali/VideoFileRenderer;->nativeCreateNativeByteBuffer(I)Ljava/nio/ByteBuffer;

    move-result-object v0

    .line 98
    .local v0, "buffer":Ljava/nio/ByteBuffer;
    iget-boolean v7, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvFrame:Z

    const/4 v15, 0x2

    if-nez v7, :cond_87

    .line 99
    iget-object v7, v1, Lorg/webrtc/ali/VideoFileRenderer;->yuvConverter:Lorg/webrtc/ali/YuvConverter;

    iget-object v8, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    iget v9, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    iget v10, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    iget v11, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    iget v12, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->textureId:I

    move-object v13, v14

    invoke-virtual/range {v7 .. v13}, Lorg/webrtc/ali/YuvConverter;->convert(Ljava/nio/ByteBuffer;IIII[F)V

    .line 102
    iget v5, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    .line 103
    .local v5, "stride":I
    iget-object v7, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v7}, Ljava/nio/ByteBuffer;->array()[B

    move-result-object v7

    .line 104
    .local v7, "data":[B
    iget-object v8, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v8}, Ljava/nio/ByteBuffer;->arrayOffset()I

    move-result v8

    .line 107
    .local v8, "offset":I
    iget v9, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    iget v10, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    mul-int v9, v9, v10

    invoke-virtual {v0, v7, v8, v9}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;

    .line 110
    iget v9, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    .local v9, "r":I
    :goto_5d
    iget v10, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    mul-int/lit8 v10, v10, 0x3

    div-int/2addr v10, v15

    if-ge v9, v10, :cond_6f

    .line 111
    mul-int v10, v9, v5

    add-int/2addr v10, v8

    div-int/lit8 v11, v5, 0x2

    invoke-virtual {v0, v7, v10, v11}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;

    .line 110
    add-int/lit8 v9, v9, 0x1

    goto :goto_5d

    .line 115
    .end local v9    # "r":I
    :cond_6f
    iget v9, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    .restart local v9    # "r":I
    :goto_71
    iget v10, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    mul-int/lit8 v10, v10, 0x3

    div-int/2addr v10, v15

    if-ge v9, v10, :cond_86

    .line 116
    mul-int v10, v9, v5

    add-int/2addr v10, v8

    div-int/lit8 v11, v5, 0x2

    add-int/2addr v10, v11

    div-int/lit8 v11, v5, 0x2

    invoke-virtual {v0, v7, v10, v11}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;

    .line 115
    add-int/lit8 v9, v9, 0x1

    goto :goto_71

    .line 118
    .end local v5    # "stride":I
    .end local v7    # "data":[B
    .end local v8    # "offset":I
    .end local v9    # "r":I
    :cond_86
    goto :goto_c8

    .line 119
    :cond_87
    iget-object v7, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->yuvPlanes:[Ljava/nio/ByteBuffer;

    aget-object v16, v7, v5

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

    aget v17, v7, v5

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

    const/4 v7, 0x1

    aget-object v18, v5, v7

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

    aget v19, v5, v7

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

    aget-object v20, v5, v15

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

    aget v21, v5, v15

    iget v5, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->width:I

    iget v7, v2, Lorg/webrtc/ali/VideoRenderer$I420Frame;->height:I

    iget-object v8, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    iget v9, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

    iget v10, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

    move/from16 v22, v5

    move/from16 v23, v7

    move-object/from16 v24, v8

    move/from16 v25, v9

    move/from16 v26, v10

    invoke-static/range {v16 .. v26}, Lorg/webrtc/ali/VideoFileRenderer;->nativeI420Scale(Ljava/nio/ByteBuffer;ILjava/nio/ByteBuffer;ILjava/nio/ByteBuffer;IIILjava/nio/ByteBuffer;II)V

    .line 123
    iget-object v5, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v5}, Ljava/nio/ByteBuffer;->array()[B

    move-result-object v5

    iget-object v7, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameBuffer:Ljava/nio/ByteBuffer;

    invoke-virtual {v7}, Ljava/nio/ByteBuffer;->arrayOffset()I

    move-result v7

    iget v8, v1, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameSize:I

    invoke-virtual {v0, v5, v7, v8}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;

    .line 125
    :goto_c8
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;

    .line 126
    iget-object v5, v1, Lorg/webrtc/ali/VideoFileRenderer;->rawFrames:Ljava/util/ArrayList;

    invoke-virtual {v5, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
    :try_end_d0
    .catchall {:try_start_29 .. :try_end_d0} :catchall_d6

    .line 128
    nop

    .end local v0    # "buffer":Ljava/nio/ByteBuffer;
    invoke-static/range {p1 .. p1}, Lorg/webrtc/ali/VideoRenderer;->renderFrameDone(Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

    .line 129
    nop

    .line 130
    return-void

    .line 128
    :catchall_d6
    move-exception v0

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

    .line 129
    goto :goto_dc

    :goto_db
    throw v0

    :goto_dc
    goto :goto_db
.end method


# virtual methods
.method public release()V
    .registers 7

    .line 136
    const-string v0, "VideoFileRenderer"

    new-instance v1, Ljava/util/concurrent/CountDownLatch;

    const/4 v2, 0x1

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

    .line 137
    .local v1, "cleanupBarrier":Ljava/util/concurrent/CountDownLatch;
    iget-object v2, p0, Lorg/webrtc/ali/VideoFileRenderer;->renderThreadHandler:Landroid/os/Handler;

    new-instance v3, Lorg/webrtc/ali/VideoFileRenderer$3;

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

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

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

    .line 148
    :try_start_15
    iget-object v2, p0, Lorg/webrtc/ali/VideoFileRenderer;->rawFrames:Ljava/util/ArrayList;

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

    move-result-object v2

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

    move-result v3

    if-eqz v3, :cond_42

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

    move-result-object v3

    check-cast v3, Ljava/nio/ByteBuffer;

    .line 149
    .local v3, "buffer":Ljava/nio/ByteBuffer;
    iget-object v4, p0, Lorg/webrtc/ali/VideoFileRenderer;->videoOutFile:Ljava/io/FileOutputStream;

    const-string v5, "FRAME\n"

    invoke-virtual {v5}, Ljava/lang/String;->getBytes()[B

    move-result-object v5

    invoke-virtual {v4, v5}, Ljava/io/FileOutputStream;->write([B)V

    .line 151
    iget v4, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFrameSize:I

    new-array v4, v4, [B

    .line 152
    .local v4, "data":[B
    invoke-virtual {v3, v4}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;

    .line 154
    iget-object v5, p0, Lorg/webrtc/ali/VideoFileRenderer;->videoOutFile:Ljava/io/FileOutputStream;

    invoke-virtual {v5, v4}, Ljava/io/FileOutputStream;->write([B)V

    .line 156
    invoke-static {v3}, Lorg/webrtc/ali/VideoFileRenderer;->nativeFreeNativeByteBuffer(Ljava/nio/ByteBuffer;)V

    .line 157
    .end local v3    # "buffer":Ljava/nio/ByteBuffer;
    .end local v4    # "data":[B
    goto :goto_1b

    .line 158
    :cond_42
    iget-object v2, p0, Lorg/webrtc/ali/VideoFileRenderer;->videoOutFile:Ljava/io/FileOutputStream;

    invoke-virtual {v2}, Ljava/io/FileOutputStream;->close()V

    .line 159
    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, "Video written to disk as "

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

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

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

    const-string v3, ". Number frames are "

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

    iget-object v3, p0, Lorg/webrtc/ali/VideoFileRenderer;->rawFrames:Ljava/util/ArrayList;

    .line 160
    invoke-virtual {v3}, Ljava/util/ArrayList;->size()I

    move-result v3

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

    const-string v3, " and the dimension of the frames are "

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

    iget v3, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFileWidth:I

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

    const-string v3, "x"

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

    iget v3, p0, Lorg/webrtc/ali/VideoFileRenderer;->outputFileHeight:I

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

    const-string v3, "."

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

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

    move-result-object v2

    .line 159
    invoke-static {v0, v2}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_84
    .catch Ljava/io/IOException; {:try_start_15 .. :try_end_84} :catch_85

    .line 164
    goto :goto_8b

    .line 162
    :catch_85
    move-exception v2

    .line 163
    .local v2, "e":Ljava/io/IOException;
    const-string v3, "Error writing video to disk"

    invoke-static {v0, v3, v2}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    .line 165
    .end local v2    # "e":Ljava/io/IOException;
    :goto_8b
    return-void
.end method

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

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

    new-instance v1, Lorg/webrtc/ali/VideoFileRenderer$2;

    invoke-direct {v1, p0, p1}, Lorg/webrtc/ali/VideoFileRenderer$2;-><init>(Lorg/webrtc/ali/VideoFileRenderer;Lorg/webrtc/ali/VideoRenderer$I420Frame;)V

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

    .line 85
    return-void
.end method