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