EglRenderer.smali
.class public Lio/agora/base/internal/video/EglRenderer;
.super Ljava/lang/Object;
.source "EglRenderer.java"
# interfaces
.implements Lio/agora/base/internal/video/VideoSink;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;,
Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;,
Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;,
Lio/agora/base/internal/video/EglRenderer$VsyncStats;,
Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;,
Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;,
Lio/agora/base/internal/video/EglRenderer$FrameListener;,
Lio/agora/base/internal/video/EglRenderer$Color;
}
.end annotation
# static fields
.field private static final DEBUG:Z = false
.field private static DEFAULT_FRAME_INTERVAL_NANOS:J = 0xfe502aL
.field private static ENABLE_LAST_FRAME:Z = false
.field private static final LOG_INTERVAL_SEC:J = 0x4L
.field private static final MAX_INVOKE_TIME_MS:I = 0x3e8
.field private static final NANOS_PER_SECOND:J = 0x3b9aca00L
.field private static final TAG:Ljava/lang/String; = "EglRenderer"
# instance fields
.field protected backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
.field private final bitmapTextureFramebuffer:Lio/agora/base/internal/video/GlTextureFrameBuffer;
.field private final drawMatrix:Landroid/graphics/Matrix;
.field private drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
.field private eglBase:Lio/agora/base/internal/video/EglBase;
.field private eglContextAttached:Z
.field private final eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
.field private final fpsReductionLock:Ljava/lang/Object;
.field private final frameDrawer:Lio/agora/base/internal/video/VideoFrameDrawer;
.field private frameIntervalNanos:J
.field private final frameListeners:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList<",
"Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;",
">;"
}
.end annotation
.end field
.field private final handlerLock:Ljava/lang/Object;
.field protected isFirstFrameRendered:Z
.field private volatile isReleasing:Z
.field private isRenderOnSurfaceView:Z
.field private isVsyncCallbackStared:Z
.field private lastFrame:Lio/agora/base/VideoFrame;
.field private layoutAspectRatio:F
.field private final layoutLock:Ljava/lang/Object;
.field private layoutScaledFit:Z
.field private final logStatisticsRunnable:Ljava/lang/Runnable;
.field private minRenderPeriodNs:J
.field private mirror:Z
.field protected final name:Ljava/lang/String;
.field private nextFrameTimeNs:J
.field private rect:Landroid/graphics/Rect;
.field private renderThreadHandler:Landroid/os/Handler;
.field protected rendererEvents:Lio/agora/base/internal/video/RendererCommon$RendererEvents;
.field private statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
.field private final surfaceLock:Ljava/lang/Object;
.field private surfaceValid:Z
.field private switchToStartVsync:Z
.field private volatile textureCoordUpdate:Z
# direct methods
.method static constructor <clinit>()V
.registers 0
return-void
.end method
.method public constructor <init>(Ljava/lang/String;)V
.registers 6
.line 201
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 126
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
.line 127
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceLock:Ljava/lang/Object;
.line 130
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->frameListeners:Ljava/util/ArrayList;
.line 134
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->fpsReductionLock:Ljava/lang/Object;
const/4 v0, 0x0
.line 144
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->eglContextAttached:Z
.line 145
new-instance v1, Lio/agora/base/internal/video/VideoFrameDrawer;
invoke-direct {v1}, Lio/agora/base/internal/video/VideoFrameDrawer;-><init>()V
iput-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->frameDrawer:Lio/agora/base/internal/video/VideoFrameDrawer;
.line 147
new-instance v1, Landroid/graphics/Matrix;
invoke-direct {v1}, Landroid/graphics/Matrix;-><init>()V
iput-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/4 v1, 0x0
.line 149
iput-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
.line 152
new-instance v2, Ljava/lang/Object;
invoke-direct {v2}, Ljava/lang/Object;-><init>()V
iput-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->layoutLock:Ljava/lang/Object;
.line 162
new-instance v2, Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
invoke-direct {v2, p0}, Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;-><init>(Lio/agora/base/internal/video/EglRenderer;)V
iput-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
const-wide/16 v2, 0x0
.line 164
iput-wide v2, p0, Lio/agora/base/internal/video/EglRenderer;->frameIntervalNanos:J
.line 167
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->switchToStartVsync:Z
.line 168
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->isVsyncCallbackStared:Z
.line 170
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->isRenderOnSurfaceView:Z
const/4 v2, 0x1
.line 172
iput-boolean v2, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceValid:Z
.line 174
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->isReleasing:Z
.line 176
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->textureCoordUpdate:Z
.line 178
new-instance v2, Lio/agora/base/internal/video/GlTextureFrameBuffer;
const/16 v3, 0x1908
invoke-direct {v2, v3}, Lio/agora/base/internal/video/GlTextureFrameBuffer;-><init>(I)V
iput-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->bitmapTextureFramebuffer:Lio/agora/base/internal/video/GlTextureFrameBuffer;
.line 181
new-instance v2, Lio/agora/base/internal/video/EglRenderer$1;
invoke-direct {v2, p0}, Lio/agora/base/internal/video/EglRenderer$1;-><init>(Lio/agora/base/internal/video/EglRenderer;)V
iput-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;
.line 195
new-instance v2, Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
invoke-direct {v2, p0, v1}, Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;-><init>(Lio/agora/base/internal/video/EglRenderer;Lio/agora/base/internal/video/EglRenderer$1;)V
iput-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
.line 202
iput-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->name:Ljava/lang/String;
.line 203
new-instance p1, Lio/agora/base/internal/video/EglRenderer$Color;
invoke-direct {p1, p0, v0}, Lio/agora/base/internal/video/EglRenderer$Color;-><init>(Lio/agora/base/internal/video/EglRenderer;I)V
iput-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
return-void
.end method
.method static synthetic access$000(Lio/agora/base/internal/video/EglRenderer;)Lio/agora/base/internal/video/EglBase;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
return-object p0
.end method
.method static synthetic access$002(Lio/agora/base/internal/video/EglRenderer;Lio/agora/base/internal/video/EglBase;)Lio/agora/base/internal/video/EglBase;
.registers 2
.line 49
iput-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
return-object p1
.end method
.method static synthetic access$100(Lio/agora/base/internal/video/EglRenderer;)Z
.registers 1
.line 49
iget-boolean p0, p0, Lio/agora/base/internal/video/EglRenderer;->eglContextAttached:Z
return p0
.end method
.method static synthetic access$1000(Lio/agora/base/internal/video/EglRenderer;Ljava/lang/String;)V
.registers 2
.line 49
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
return-void
.end method
.method static synthetic access$102(Lio/agora/base/internal/video/EglRenderer;Z)Z
.registers 2
.line 49
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->eglContextAttached:Z
return p1
.end method
.method static synthetic access$1102(Lio/agora/base/internal/video/EglRenderer;Z)Z
.registers 2
.line 49
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceValid:Z
return p1
.end method
.method static synthetic access$1300(Lio/agora/base/internal/video/EglRenderer;)Lio/agora/base/internal/video/RendererCommon$GlDrawer;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
return-object p0
.end method
.method static synthetic access$1302(Lio/agora/base/internal/video/EglRenderer;Lio/agora/base/internal/video/RendererCommon$GlDrawer;)Lio/agora/base/internal/video/RendererCommon$GlDrawer;
.registers 2
.line 49
iput-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
return-object p1
.end method
.method static synthetic access$1400(Lio/agora/base/internal/video/EglRenderer;)Lio/agora/base/internal/video/VideoFrameDrawer;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->frameDrawer:Lio/agora/base/internal/video/VideoFrameDrawer;
return-object p0
.end method
.method static synthetic access$1500(Lio/agora/base/internal/video/EglRenderer;)Lio/agora/base/internal/video/GlTextureFrameBuffer;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->bitmapTextureFramebuffer:Lio/agora/base/internal/video/GlTextureFrameBuffer;
return-object p0
.end method
.method static synthetic access$1600(Lio/agora/base/internal/video/EglRenderer;)Ljava/util/ArrayList;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->frameListeners:Ljava/util/ArrayList;
return-object p0
.end method
.method static synthetic access$1700(Lio/agora/base/internal/video/EglRenderer;)J
.registers 3
.line 49
iget-wide v0, p0, Lio/agora/base/internal/video/EglRenderer;->frameIntervalNanos:J
return-wide v0
.end method
.method static synthetic access$1702(Lio/agora/base/internal/video/EglRenderer;J)J
.registers 3
.line 49
iput-wide p1, p0, Lio/agora/base/internal/video/EglRenderer;->frameIntervalNanos:J
return-wide p1
.end method
.method static synthetic access$1900(Lio/agora/base/internal/video/EglRenderer;FFFF)V
.registers 5
.line 49
invoke-direct {p0, p1, p2, p3, p4}, Lio/agora/base/internal/video/EglRenderer;->clearSurfaceOnRenderThread(FFFF)V
return-void
.end method
.method static synthetic access$200(Lio/agora/base/internal/video/EglRenderer;)Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
return-object p0
.end method
.method static synthetic access$2100()Z
.registers 1
.line 49
sget-boolean v0, Lio/agora/base/internal/video/EglRenderer;->ENABLE_LAST_FRAME:Z
return v0
.end method
.method static synthetic access$2200(Lio/agora/base/internal/video/EglRenderer;)Lio/agora/base/VideoFrame;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
return-object p0
.end method
.method static synthetic access$2300(Lio/agora/base/internal/video/EglRenderer;)Z
.registers 1
.line 49
iget-boolean p0, p0, Lio/agora/base/internal/video/EglRenderer;->isVsyncCallbackStared:Z
return p0
.end method
.method static synthetic access$2302(Lio/agora/base/internal/video/EglRenderer;Z)Z
.registers 2
.line 49
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->isVsyncCallbackStared:Z
return p1
.end method
.method static synthetic access$2600(Lio/agora/base/internal/video/EglRenderer;Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;J)V
.registers 4
.line 49
invoke-direct {p0, p1, p2, p3}, Lio/agora/base/internal/video/EglRenderer;->renderFrameOnRenderThread(Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;J)V
return-void
.end method
.method static synthetic access$400(Lio/agora/base/internal/video/EglRenderer;)Ljava/lang/Object;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
return-object p0
.end method
.method static synthetic access$500(Lio/agora/base/internal/video/EglRenderer;)Landroid/os/Handler;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
return-object p0
.end method
.method static synthetic access$600(Lio/agora/base/internal/video/EglRenderer;)Ljava/lang/Runnable;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;
return-object p0
.end method
.method static synthetic access$900(Lio/agora/base/internal/video/EglRenderer;)Ljava/lang/Object;
.registers 1
.line 49
iget-object p0, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceLock:Ljava/lang/Object;
return-object p0
.end method
.method private checkHDR()V
.registers 2
const/4 v0, 0x2
.line 216
invoke-static {v0}, Lio/agora/base/internal/video/VideoRenderUtils;->isSupportedHDRByType(I)Z
.line 217
invoke-static {}, Lio/agora/base/internal/video/VideoRenderUtils;->getDesiredMaxAverageLuminance()F
.line 218
invoke-static {}, Lio/agora/base/internal/video/VideoRenderUtils;->getDesiredMaxLuminance()F
.line 219
invoke-static {}, Lio/agora/base/internal/video/VideoRenderUtils;->getDesiredMinLuminance()F
.line 220
invoke-static {}, Lio/agora/base/internal/video/VideoRenderUtils;->isWideColorGamut()Z
.line 221
invoke-static {}, Lio/agora/base/internal/video/VideoRenderUtils;->getPreferredWideGamutColorSpaceId()I
return-void
.end method
.method private clearSurfaceOnRenderThread(FFFF)V
.registers 6
.line 809
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
if-eqz v0, :cond_1c
invoke-interface {v0}, Lio/agora/base/internal/video/EglBase;->hasSurface()Z
move-result v0
if-eqz v0, :cond_1c
const-string v0, "clearSurface"
.line 810
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 811
invoke-static {p1, p2, p3, p4}, Landroid/opengl/GLES20;->glClearColor(FFFF)V
const/16 p1, 0x4000
.line 812
invoke-static {p1}, Landroid/opengl/GLES20;->glClear(I)V
.line 813
iget-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
invoke-interface {p1}, Lio/agora/base/internal/video/EglBase;->swapBuffers()V
:cond_1c
return-void
.end method
.method private convertRectFromAndroidGraphicsRect(Landroid/graphics/Rect;Lio/agora/base/VideoFrame;)[F
.registers 9
.line 846
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotation()I
move-result v0
rem-int/lit16 v0, v0, 0x168
const/4 v1, 0x0
const/high16 v2, 0x3f800000 # 1.0f
if-eqz v0, :cond_d0
const/16 v3, 0x5a
if-eq v0, v3, :cond_92
const/16 v3, 0xb4
if-eq v0, v3, :cond_57
const/16 v3, 0x10e
if-eq v0, v3, :cond_1b
move p1, v1
move v0, v2
goto/16 :goto_118
.line 884
:cond_1b
iget v0, p1, Landroid/graphics/Rect;->right:I
int-to-float v0, v0
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v1
int-to-float v1, v1
div-float/2addr v0, v1
.line 885
iget v1, p1, Landroid/graphics/Rect;->left:I
int-to-float v1, v1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v3
int-to-float v3, v3
div-float/2addr v1, v3
.line 886
iget-boolean v3, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
if-eqz v3, :cond_45
.line 887
iget v3, p1, Landroid/graphics/Rect;->bottom:I
int-to-float v3, v3
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v4
int-to-float v4, v4
div-float/2addr v3, v4
sub-float v3, v2, v3
.line 888
iget p1, p1, Landroid/graphics/Rect;->top:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v4
goto/16 :goto_fc
.line 890
:cond_45
iget v2, p1, Landroid/graphics/Rect;->top:I
int-to-float v2, v2
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v3
int-to-float v3, v3
div-float/2addr v2, v3
.line 891
iget p1, p1, Landroid/graphics/Rect;->bottom:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v3
goto/16 :goto_112
.line 872
:cond_57
iget v0, p1, Landroid/graphics/Rect;->bottom:I
int-to-float v0, v0
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v1
int-to-float v1, v1
div-float/2addr v0, v1
.line 873
iget v1, p1, Landroid/graphics/Rect;->top:I
int-to-float v1, v1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v3
int-to-float v3, v3
div-float/2addr v1, v3
.line 874
iget-boolean v3, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
if-eqz v3, :cond_7f
.line 875
iget v2, p1, Landroid/graphics/Rect;->left:I
int-to-float v2, v2
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v3
int-to-float v3, v3
div-float/2addr v2, v3
.line 876
iget p1, p1, Landroid/graphics/Rect;->right:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v3
goto/16 :goto_112
.line 878
:cond_7f
iget v3, p1, Landroid/graphics/Rect;->right:I
int-to-float v3, v3
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v4
int-to-float v4, v4
div-float/2addr v3, v4
sub-float v3, v2, v3
.line 879
iget p1, p1, Landroid/graphics/Rect;->left:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v4
goto :goto_fc
.line 860
:cond_92
iget v0, p1, Landroid/graphics/Rect;->left:I
int-to-float v0, v0
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v1
int-to-float v1, v1
div-float/2addr v0, v1
sub-float v0, v2, v0
.line 861
iget v1, p1, Landroid/graphics/Rect;->right:I
int-to-float v1, v1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v3
int-to-float v3, v3
div-float/2addr v1, v3
sub-float v1, v2, v1
.line 862
iget-boolean v3, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
if-eqz v3, :cond_bd
.line 863
iget v2, p1, Landroid/graphics/Rect;->top:I
int-to-float v2, v2
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v3
int-to-float v3, v3
div-float/2addr v2, v3
.line 864
iget p1, p1, Landroid/graphics/Rect;->bottom:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v3
goto :goto_112
.line 866
:cond_bd
iget v3, p1, Landroid/graphics/Rect;->bottom:I
int-to-float v3, v3
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v4
int-to-float v4, v4
div-float/2addr v3, v4
sub-float v3, v2, v3
.line 867
iget p1, p1, Landroid/graphics/Rect;->top:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v4
goto :goto_fc
.line 848
:cond_d0
iget v0, p1, Landroid/graphics/Rect;->top:I
int-to-float v0, v0
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v1
int-to-float v1, v1
div-float/2addr v0, v1
sub-float v0, v2, v0
.line 849
iget v1, p1, Landroid/graphics/Rect;->bottom:I
int-to-float v1, v1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v3
int-to-float v3, v3
div-float/2addr v1, v3
sub-float v1, v2, v1
.line 850
iget-boolean v3, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
if-eqz v3, :cond_102
.line 851
iget v3, p1, Landroid/graphics/Rect;->right:I
int-to-float v3, v3
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v4
int-to-float v4, v4
div-float/2addr v3, v4
sub-float v3, v2, v3
.line 852
iget p1, p1, Landroid/graphics/Rect;->left:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v4
:goto_fc
int-to-float v4, v4
div-float/2addr p1, v4
sub-float/2addr v2, p1
move p1, v1
move v1, v3
goto :goto_118
.line 854
:cond_102
iget v2, p1, Landroid/graphics/Rect;->left:I
int-to-float v2, v2
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v3
int-to-float v3, v3
div-float/2addr v2, v3
.line 855
iget p1, p1, Landroid/graphics/Rect;->right:I
int-to-float p1, p1
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v3
:goto_112
int-to-float v3, v3
div-float/2addr p1, v3
move v5, v2
move v2, p1
move p1, v1
move v1, v5
.line 901
:goto_118
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "rotation "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Lio/agora/base/VideoFrame;->getRotation()I
move-result p2
rem-int/lit16 p2, p2, 0x168
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, " mirror "
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-boolean p2, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string p2, " left "
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;
const-string p2, " right "
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;
const-string p2, " top "
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;
const-string p2, " bottom "
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(F)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p0, p2}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
const/16 p2, 0x8
new-array p2, p2, [F
const/4 v3, 0x0
aput v1, p2, v3
const/4 v3, 0x1
aput p1, p2, v3
const/4 v3, 0x2
aput v2, p2, v3
const/4 v3, 0x3
aput p1, p2, v3
const/4 p1, 0x4
aput v1, p2, p1
const/4 p1, 0x5
aput v0, p2, p1
const/4 p1, 0x6
aput v2, p2, p1
const/4 p1, 0x7
aput v0, p2, p1
return-object p2
.end method
.method private createEglSurfaceInternal(Ljava/lang/Object;)V
.registers 3
.line 312
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
invoke-virtual {v0, p1}, Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;->setSurface(Ljava/lang/Object;)V
.line 313
iget-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceLock:Ljava/lang/Object;
monitor-enter p1
const/4 v0, 0x1
.line 314
:try_start_9
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceValid:Z
.line 315
monitor-exit p1
:try_end_c
.catchall {:try_start_9 .. :try_end_c} :catchall_12
.line 316
iget-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->postToRenderThread(Ljava/lang/Runnable;)V
return-void
:catchall_12
move-exception v0
.line 315
:try_start_13
monitor-exit p1
:try_end_14
.catchall {:try_start_13 .. :try_end_14} :catchall_12
throw v0
.end method
.method public static getDefaultDisplayRefreshRateParams()D
.registers 4
.line 1369
invoke-static {}, Lio/agora/base/internal/ContextUtils;->getApplicationContext()Landroid/content/Context;
move-result-object v0
const-wide/16 v1, 0x0
if-nez v0, :cond_9
return-wide v1
.line 1373
:cond_9
invoke-static {}, Lio/agora/base/internal/ContextUtils;->getApplicationContext()Landroid/content/Context;
move-result-object v0
const-string/jumbo v3, "window"
invoke-virtual {v0, v3}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/view/WindowManager;
if-nez v0, :cond_19
return-wide v1
.line 1378
:cond_19
invoke-interface {v0}, Landroid/view/WindowManager;->getDefaultDisplay()Landroid/view/Display;
move-result-object v0
if-eqz v0, :cond_25
.line 1380
invoke-virtual {v0}, Landroid/view/Display;->getRefreshRate()F
move-result v0
float-to-double v0, v0
return-wide v0
:cond_25
return-wide v1
.end method
.method private logD(Ljava/lang/String;)V
.registers 4
.line 1165
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
iget-object v1, p0, Lio/agora/base/internal/video/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 p1
const-string v0, "EglRenderer"
invoke-static {v0, p1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method private notifyCallbacks(Lio/agora/base/VideoFrame;Z)V
.registers 19
move-object/from16 v1, p0
.line 1100
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->frameListeners:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->isEmpty()Z
move-result v0
if-eqz v0, :cond_b
return-void
.line 1103
:cond_b
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
invoke-virtual {v0}, Landroid/graphics/Matrix;->reset()V
.line 1104
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/high16 v2, 0x3f000000 # 0.5f
invoke-virtual {v0, v2, v2}, Landroid/graphics/Matrix;->preTranslate(FF)Z
.line 1105
iget-boolean v0, v1, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
const/high16 v2, -0x40800000 # -1.0f
const/high16 v3, 0x3f800000 # 1.0f
if-eqz v0, :cond_24
.line 1106
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
invoke-virtual {v0, v2, v3}, Landroid/graphics/Matrix;->preScale(FF)Z
.line 1107
:cond_24
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
invoke-virtual {v0, v3, v2}, Landroid/graphics/Matrix;->preScale(FF)Z
.line 1108
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/high16 v2, -0x41000000 # -0.5f
invoke-virtual {v0, v2, v2}, Landroid/graphics/Matrix;->preTranslate(FF)Z
.line 1110
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->frameListeners:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v2
.line 1111
:goto_36
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_f7
.line 1112
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
move-object v3, v0
check-cast v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;
if-nez p2, :cond_4a
.line 1113
iget-boolean v0, v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;->applyFpsReduction:Z
if-eqz v0, :cond_4a
goto :goto_36
.line 1116
:cond_4a
invoke-interface {v2}, Ljava/util/Iterator;->remove()V
.line 1118
iget v0, v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;->scale:F
invoke-virtual/range {p1 .. p1}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v4
int-to-float v4, v4
mul-float/2addr v0, v4
float-to-int v12, v0
.line 1119
iget v0, v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;->scale:F
invoke-virtual/range {p1 .. p1}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v4
int-to-float v4, v4
mul-float/2addr v0, v4
float-to-int v13, v0
if-eqz v12, :cond_ef
if-nez v13, :cond_65
goto/16 :goto_ef
.line 1126
:cond_65
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->bitmapTextureFramebuffer:Lio/agora/base/internal/video/GlTextureFrameBuffer;
invoke-virtual {v0, v12, v13}, Lio/agora/base/internal/video/GlTextureFrameBuffer;->setSize(II)V
.line 1128
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->bitmapTextureFramebuffer:Lio/agora/base/internal/video/GlTextureFrameBuffer;
invoke-virtual {v0}, Lio/agora/base/internal/video/GlTextureFrameBuffer;->getFrameBufferId()I
move-result v0
const v15, 0x8d40
invoke-static {v15, v0}, Landroid/opengl/GLES20;->glBindFramebuffer(II)V
const v0, 0x8ce0
const/16 v4, 0xde1
.line 1129
iget-object v5, v1, Lio/agora/base/internal/video/EglRenderer;->bitmapTextureFramebuffer:Lio/agora/base/internal/video/GlTextureFrameBuffer;
.line 1130
invoke-virtual {v5}, Lio/agora/base/internal/video/GlTextureFrameBuffer;->getTextureId()I
move-result v5
const/4 v11, 0x0
.line 1129
invoke-static {v15, v0, v4, v5, v11}, Landroid/opengl/GLES20;->glFramebufferTexture2D(IIIII)V
.line 1132
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v0, v0, Lio/agora/base/internal/video/EglRenderer$Color;->red:F
iget-object v4, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v4, v4, Lio/agora/base/internal/video/EglRenderer$Color;->green:F
iget-object v5, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v5, v5, Lio/agora/base/internal/video/EglRenderer$Color;->blue:F
iget-object v6, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v6, v6, Lio/agora/base/internal/video/EglRenderer$Color;->alpha:F
invoke-static {v0, v4, v5, v6}, Landroid/opengl/GLES20;->glClearColor(FFFF)V
const/16 v0, 0x4000
.line 1134
invoke-static {v0}, Landroid/opengl/GLES20;->glClear(I)V
.line 1135
iget-object v4, v1, Lio/agora/base/internal/video/EglRenderer;->frameDrawer:Lio/agora/base/internal/video/VideoFrameDrawer;
iget-object v6, v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;->drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
iget-object v7, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/4 v8, 0x0
const/4 v9, 0x0
move-object/from16 v5, p1
move v10, v12
move v14, v11
move v11, v13
invoke-virtual/range {v4 .. v11}, Lio/agora/base/internal/video/VideoFrameDrawer;->drawFrame(Lio/agora/base/VideoFrame;Lio/agora/base/internal/video/RendererCommon$GlDrawer;Landroid/graphics/Matrix;IIII)V
mul-int v0, v12, v13
mul-int/lit8 v0, v0, 0x4
.line 1140
:try_start_b1
invoke-static {v0}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;
move-result-object v0
:try_end_b5
.catch Ljava/lang/IllegalArgumentException; {:try_start_b1 .. :try_end_b5} :catch_b6
goto :goto_bc
:catch_b6
move-exception v0
move-object v4, v0
.line 1142
invoke-static {v4}, Lcom/google/devtools/build/android/desugar/runtime/ThrowableExtension;->printStackTrace(Ljava/lang/Throwable;)V
const/4 v0, 0x0
.line 1144
:goto_bc
invoke-static {v14, v14, v12, v13}, Landroid/opengl/GLES20;->glViewport(IIII)V
const/4 v4, 0x0
const/4 v5, 0x0
const/16 v8, 0x1908
const/16 v9, 0x1401
move v6, v12
move v7, v13
move-object v10, v0
.line 1145
invoke-static/range {v4 .. v10}, Landroid/opengl/GLES20;->glReadPixels(IIIIIILjava/nio/Buffer;)V
.line 1148
invoke-static {v15, v14}, Landroid/opengl/GLES20;->glBindFramebuffer(II)V
const-string v4, "EglRenderer.notifyCallbacks"
.line 1149
invoke-static {v4}, Lio/agora/base/internal/video/GlUtil;->checkNoGLES2Error(Ljava/lang/String;)V
.line 1152
:try_start_d3
sget-object v4, Landroid/graphics/Bitmap$Config;->ARGB_8888:Landroid/graphics/Bitmap$Config;
.line 1153
invoke-static {v12, v13, v4}, Landroid/graphics/Bitmap;->createBitmap(IILandroid/graphics/Bitmap$Config;)Landroid/graphics/Bitmap;
move-result-object v4
.line 1154
invoke-virtual {v4, v0}, Landroid/graphics/Bitmap;->copyPixelsFromBuffer(Ljava/nio/Buffer;)V
.line 1155
iget-object v0, v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;->listener:Lio/agora/base/internal/video/EglRenderer$FrameListener;
invoke-interface {v0, v4}, Lio/agora/base/internal/video/EglRenderer$FrameListener;->onFrame(Landroid/graphics/Bitmap;)V
:try_end_e1
.catch Ljava/lang/IllegalArgumentException; {:try_start_d3 .. :try_end_e1} :catch_e9
.catch Ljava/lang/IllegalStateException; {:try_start_d3 .. :try_end_e1} :catch_e3
goto/16 :goto_36
:catch_e3
move-exception v0
.line 1159
invoke-static {v0}, Lcom/google/devtools/build/android/desugar/runtime/ThrowableExtension;->printStackTrace(Ljava/lang/Throwable;)V
goto/16 :goto_36
:catch_e9
move-exception v0
.line 1157
invoke-static {v0}, Lcom/google/devtools/build/android/desugar/runtime/ThrowableExtension;->printStackTrace(Ljava/lang/Throwable;)V
goto/16 :goto_36
.line 1122
:cond_ef
:goto_ef
iget-object v0, v3, Lio/agora/base/internal/video/EglRenderer$FrameListenerAndParams;->listener:Lio/agora/base/internal/video/EglRenderer$FrameListener;
const/4 v3, 0x0
invoke-interface {v0, v3}, Lio/agora/base/internal/video/EglRenderer$FrameListener;->onFrame(Landroid/graphics/Bitmap;)V
goto/16 :goto_36
:cond_f7
return-void
.end method
.method private postToRenderThread(Ljava/lang/Runnable;)V
.registers 4
.line 801
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 802
:try_start_3
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-eqz v1, :cond_a
.line 803
invoke-virtual {v1, p1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
.line 805
:cond_a
monitor-exit v0
return-void
:catchall_c
move-exception p1
monitor-exit v0
:try_end_e
.catchall {:try_start_3 .. :try_end_e} :catchall_c
throw p1
.end method
.method private renderFrameOnRenderThread(Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;J)V
.registers 26
move-object/from16 v1, p0
move-object/from16 v0, p1
.line 923
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v2, :cond_e
const-string v0, "renderFrameOnRenderThread failed, Already released"
.line 924
invoke-direct {v1, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
return-void
.line 927
:cond_e
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
if-nez v0, :cond_14
return-void
.line 931
:cond_14
iget-object v10, v0, Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;->frame:Lio/agora/base/VideoFrame;
.line 932
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
if-eqz v2, :cond_20a
invoke-interface {v2}, Lio/agora/base/internal/video/EglBase;->hasSurface()Z
move-result v2
if-eqz v2, :cond_20a
iget-boolean v2, v1, Lio/agora/base/internal/video/EglRenderer;->isReleasing:Z
if-eqz v2, :cond_26
goto/16 :goto_20a
.line 938
:cond_26
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->surfaceLock:Ljava/lang/Object;
monitor-enter v2
.line 939
:try_start_29
iget-boolean v3, v1, Lio/agora/base/internal/video/EglRenderer;->surfaceValid:Z
if-nez v3, :cond_37
const-string v0, "Dropping frame - surface not valid"
.line 940
invoke-direct {v1, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 941
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->release()V
.line 942
monitor-exit v2
return-void
.line 944
:cond_37
monitor-exit v2
:try_end_38
.catchall {:try_start_29 .. :try_end_38} :catchall_207
.line 948
sget-boolean v2, Lio/agora/base/internal/video/EglRenderer;->ENABLE_LAST_FRAME:Z
if-eqz v2, :cond_4a
.line 949
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
if-eqz v2, :cond_45
if-eq v2, v10, :cond_45
.line 950
invoke-virtual {v2}, Lio/agora/base/VideoFrame;->release()V
.line 952
:cond_45
iput-object v10, v1, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
.line 953
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->retain()V
.line 957
:cond_4a
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->fpsReductionLock:Ljava/lang/Object;
monitor-enter v3
.line 958
:try_start_4d
iget-wide v4, v1, Lio/agora/base/internal/video/EglRenderer;->minRenderPeriodNs:J
const-wide v6, 0x7fffffffffffffffL
cmp-long v2, v4, v6
const/4 v11, 0x1
const/4 v6, 0x0
if-nez v2, :cond_5c
:goto_5a
move v12, v6
goto :goto_80
:cond_5c
const-wide/16 v7, 0x0
cmp-long v2, v4, v7
if-gtz v2, :cond_64
:goto_62
move v12, v11
goto :goto_80
.line 965
:cond_64
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v4
.line 966
iget-wide v7, v1, Lio/agora/base/internal/video/EglRenderer;->nextFrameTimeNs:J
cmp-long v2, v4, v7
if-gez v2, :cond_74
const-string v2, "Skipping frame rendering - fps reduction is active."
.line 967
invoke-direct {v1, v2}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
goto :goto_5a
.line 970
:cond_74
iget-wide v12, v1, Lio/agora/base/internal/video/EglRenderer;->minRenderPeriodNs:J
add-long/2addr v7, v12
iput-wide v7, v1, Lio/agora/base/internal/video/EglRenderer;->nextFrameTimeNs:J
.line 972
invoke-static {v7, v8, v4, v5}, Ljava/lang/Math;->max(JJ)J
move-result-wide v4
iput-wide v4, v1, Lio/agora/base/internal/video/EglRenderer;->nextFrameTimeNs:J
goto :goto_62
.line 976
:goto_80
monitor-exit v3
:try_end_81
.catchall {:try_start_4d .. :try_end_81} :catchall_204
.line 977
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v18
.line 980
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getSampleAspectRatio()F
move-result v2
const/high16 v3, 0x3f800000 # 1.0f
cmpl-float v4, v2, v3
const/4 v5, 0x0
if-eqz v4, :cond_95
cmpl-float v4, v2, v5
if-lez v4, :cond_95
goto :goto_96
:cond_95
move v2, v3
.line 986
:goto_96
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v4
int-to-float v4, v4
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v7
int-to-float v7, v7
div-float/2addr v4, v7
mul-float/2addr v4, v2
.line 989
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
if-eqz v2, :cond_e2
.line 990
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getRotation()I
move-result v2
.line 991
rem-int/lit16 v2, v2, 0xb4
if-nez v2, :cond_c0
.line 992
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v2, v2, Landroid/graphics/Rect;->right:I
iget-object v7, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v7, v7, Landroid/graphics/Rect;->left:I
sub-int/2addr v2, v7
.line 993
iget-object v7, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v7, v7, Landroid/graphics/Rect;->bottom:I
iget-object v8, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v8, v8, Landroid/graphics/Rect;->top:I
goto :goto_d1
.line 995
:cond_c0
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v2, v2, Landroid/graphics/Rect;->bottom:I
iget-object v7, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v7, v7, Landroid/graphics/Rect;->top:I
sub-int/2addr v2, v7
.line 996
iget-object v7, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v7, v7, Landroid/graphics/Rect;->right:I
iget-object v8, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
iget v8, v8, Landroid/graphics/Rect;->left:I
:goto_d1
sub-int/2addr v7, v8
.line 1000
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getRotatedWidth()I
move-result v8
if-gt v2, v8, :cond_e2
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getRotatedHeight()I
move-result v8
if-gt v7, v8, :cond_e2
int-to-float v2, v2
int-to-float v4, v7
div-float v4, v2, v4
.line 1007
:cond_e2
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->layoutLock:Ljava/lang/Object;
monitor-enter v2
.line 1008
:try_start_e5
iget v7, v1, Lio/agora/base/internal/video/EglRenderer;->layoutAspectRatio:F
cmpl-float v5, v7, v5
if-eqz v5, :cond_ec
goto :goto_ed
:cond_ec
move v7, v4
.line 1009
:goto_ed
iget-boolean v5, v1, Lio/agora/base/internal/video/EglRenderer;->layoutScaledFit:Z
.line 1010
monitor-exit v2
:try_end_f0
.catchall {:try_start_e5 .. :try_end_f0} :catchall_201
.line 1016
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
invoke-interface {v2}, Lio/agora/base/internal/video/EglBase;->surfaceWidth()I
move-result v2
.line 1017
iget-object v8, v1, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
invoke-interface {v8}, Lio/agora/base/internal/video/EglBase;->surfaceHeight()I
move-result v8
if-eqz v5, :cond_11b
cmpl-float v5, v4, v7
const/high16 v9, 0x40000000 # 2.0f
if-lez v5, :cond_10f
div-float/2addr v7, v4
sub-float v4, v3, v7
int-to-float v5, v8
mul-float/2addr v4, v5
div-float/2addr v4, v9
float-to-int v4, v4
move v5, v3
move v9, v4
move v7, v6
goto :goto_119
:cond_10f
div-float/2addr v4, v7
sub-float v4, v3, v4
int-to-float v5, v2
mul-float/2addr v4, v5
div-float/2addr v4, v9
float-to-int v4, v4
move v5, v3
move v7, v4
move v9, v6
:goto_119
move v4, v5
goto :goto_127
:cond_11b
cmpl-float v5, v4, v7
if-lez v5, :cond_122
div-float/2addr v7, v4
move v4, v3
goto :goto_124
:cond_122
div-float/2addr v4, v7
move v7, v3
:goto_124
move v9, v6
move v5, v7
move v7, v9
.line 1043
:goto_127
iget-object v13, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
invoke-virtual {v13}, Landroid/graphics/Matrix;->reset()V
.line 1044
iget-object v13, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/high16 v14, 0x3f000000 # 0.5f
invoke-virtual {v13, v14, v14}, Landroid/graphics/Matrix;->preTranslate(FF)Z
.line 1045
iget-boolean v13, v1, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
if-eqz v13, :cond_13e
.line 1046
iget-object v13, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/high16 v14, -0x40800000 # -1.0f
invoke-virtual {v13, v14, v3}, Landroid/graphics/Matrix;->preScale(FF)Z
.line 1047
:cond_13e
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
invoke-virtual {v3, v5, v4}, Landroid/graphics/Matrix;->preScale(FF)Z
.line 1048
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
const/high16 v4, -0x41000000 # -0.5f
invoke-virtual {v3, v4, v4}, Landroid/graphics/Matrix;->preTranslate(FF)Z
.line 1051
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
if-eqz v3, :cond_163
iget-boolean v3, v1, Lio/agora/base/internal/video/EglRenderer;->textureCoordUpdate:Z
if-eqz v3, :cond_163
.line 1053
iput-boolean v6, v1, Lio/agora/base/internal/video/EglRenderer;->textureCoordUpdate:Z
.line 1054
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
invoke-direct {v1, v3, v10}, Lio/agora/base/internal/video/EglRenderer;->convertRectFromAndroidGraphicsRect(Landroid/graphics/Rect;Lio/agora/base/VideoFrame;)[F
move-result-object v3
.line 1055
iget-object v4, v1, Lio/agora/base/internal/video/EglRenderer;->drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
invoke-static {v3}, Lio/agora/base/internal/video/GlUtil;->createFloatBuffer([F)Ljava/nio/FloatBuffer;
move-result-object v3
invoke-interface {v4, v3}, Lio/agora/base/internal/video/RendererCommon$GlDrawer;->setTextureCropCoord(Ljava/nio/FloatBuffer;)V
:cond_163
if-eqz v12, :cond_1fa
.line 1058
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v3, v3, Lio/agora/base/internal/video/EglRenderer$Color;->red:F
iget-object v4, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v4, v4, Lio/agora/base/internal/video/EglRenderer$Color;->green:F
iget-object v5, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v5, v5, Lio/agora/base/internal/video/EglRenderer$Color;->blue:F
iget-object v6, v1, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v6, v6, Lio/agora/base/internal/video/EglRenderer$Color;->alpha:F
invoke-static {v3, v4, v5, v6}, Landroid/opengl/GLES20;->glClearColor(FFFF)V
const/16 v3, 0x4000
.line 1060
invoke-static {v3}, Landroid/opengl/GLES20;->glClear(I)V
.line 1061
iget-object v3, v1, Lio/agora/base/internal/video/EglRenderer;->frameDrawer:Lio/agora/base/internal/video/VideoFrameDrawer;
iget-object v4, v1, Lio/agora/base/internal/video/EglRenderer;->drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
iget-object v5, v1, Lio/agora/base/internal/video/EglRenderer;->drawMatrix:Landroid/graphics/Matrix;
mul-int/lit8 v6, v7, 0x2
sub-int v13, v2, v6
mul-int/lit8 v2, v9, 0x2
sub-int v14, v8, v2
move-object v2, v3
move-object v3, v10
move v6, v7
move v7, v9
move v8, v13
move v9, v14
invoke-virtual/range {v2 .. v9}, Lio/agora/base/internal/video/VideoFrameDrawer;->drawFrame(Lio/agora/base/VideoFrame;Lio/agora/base/internal/video/RendererCommon$GlDrawer;Landroid/graphics/Matrix;IIII)V
.line 1065
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v20
.line 1066
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
instance-of v3, v2, Lio/agora/base/internal/video/EglBase14;
if-eqz v3, :cond_1ab
iget-boolean v3, v1, Lio/agora/base/internal/video/EglRenderer;->isVsyncCallbackStared:Z
if-eqz v3, :cond_1ab
.line 1068
check-cast v2, Lio/agora/base/internal/video/EglBase14;
iget-wide v3, v1, Lio/agora/base/internal/video/EglRenderer;->frameIntervalNanos:J
add-long v3, p2, v3
invoke-virtual {v2, v3, v4}, Lio/agora/base/internal/video/EglBase14;->setPresentationTime(J)V
.line 1070
:cond_1ab
iget-object v2, v1, Lio/agora/base/internal/video/EglRenderer;->eglBase:Lio/agora/base/internal/video/EglBase;
invoke-interface {v2}, Lio/agora/base/internal/video/EglBase;->swapBuffers()V
.line 1071
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v2
.line 1072
iget-object v13, v1, Lio/agora/base/internal/video/EglRenderer;->statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
iget-wide v4, v0, Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;->frameDrawStartTimeNs:J
move-wide v14, v2
move-wide/from16 v16, v4
# invokes: Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->updateFramesHasDrawn(JJJJ)V
invoke-static/range {v13 .. v21}, Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->access$2000(Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;JJJJ)V
.line 1075
iget-object v4, v1, Lio/agora/base/internal/video/EglRenderer;->rendererEvents:Lio/agora/base/internal/video/RendererCommon$RendererEvents;
if-eqz v4, :cond_1cc
.line 1076
iget-wide v5, v0, Lio/agora/base/internal/video/EglRenderer$VideoFrameInternal;->frameDrawStartTimeNs:J
sub-long/2addr v2, v5
const-wide/32 v5, 0xf4240
div-long/2addr v2, v5
invoke-interface {v4, v2, v3}, Lio/agora/base/internal/video/RendererCommon$RendererEvents;->onFrameDrawn(J)V
.line 1080
:cond_1cc
iget-boolean v0, v1, Lio/agora/base/internal/video/EglRenderer;->isFirstFrameRendered:Z
if-nez v0, :cond_1fa
.line 1081
iput-boolean v11, v1, Lio/agora/base/internal/video/EglRenderer;->isFirstFrameRendered:Z
const-string v0, "Reporting first rendered frame."
.line 1082
invoke-direct {v1, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 1083
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->rendererEvents:Lio/agora/base/internal/video/RendererCommon$RendererEvents;
if-eqz v0, :cond_1fa
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getBuffer()Lio/agora/base/VideoFrame$Buffer;
move-result-object v0
if-eqz v0, :cond_1fa
.line 1084
iget-object v0, v1, Lio/agora/base/internal/video/EglRenderer;->rendererEvents:Lio/agora/base/internal/video/RendererCommon$RendererEvents;
.line 1085
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getBuffer()Lio/agora/base/VideoFrame$Buffer;
move-result-object v2
invoke-interface {v2}, Lio/agora/base/VideoFrame$Buffer;->getWidth()I
move-result v2
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getBuffer()Lio/agora/base/VideoFrame$Buffer;
move-result-object v3
invoke-interface {v3}, Lio/agora/base/VideoFrame$Buffer;->getHeight()I
move-result v3
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->getRotation()I
move-result v4
.line 1084
invoke-interface {v0, v2, v3, v4}, Lio/agora/base/internal/video/RendererCommon$RendererEvents;->onFirstFrameRendered(III)V
.line 1090
:cond_1fa
invoke-direct {v1, v10, v12}, Lio/agora/base/internal/video/EglRenderer;->notifyCallbacks(Lio/agora/base/VideoFrame;Z)V
.line 1091
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->release()V
return-void
:catchall_201
move-exception v0
.line 1010
:try_start_202
monitor-exit v2
:try_end_203
.catchall {:try_start_202 .. :try_end_203} :catchall_201
throw v0
:catchall_204
move-exception v0
.line 976
:try_start_205
monitor-exit v3
:try_end_206
.catchall {:try_start_205 .. :try_end_206} :catchall_204
throw v0
:catchall_207
move-exception v0
.line 944
:try_start_208
monitor-exit v2
:try_end_209
.catchall {:try_start_208 .. :try_end_209} :catchall_207
throw v0
:cond_20a
:goto_20a
const-string v0, "Dropping frame - No Surface"
.line 933
invoke-direct {v1, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 934
invoke-virtual {v10}, Lio/agora/base/VideoFrame;->release()V
return-void
.end method
# virtual methods
.method public addFrameListener(Lio/agora/base/internal/video/EglRenderer$FrameListener;F)V
.registers 5
const/4 v0, 0x0
const/4 v1, 0x0
.line 651
invoke-virtual {p0, p1, p2, v0, v1}, Lio/agora/base/internal/video/EglRenderer;->addFrameListener(Lio/agora/base/internal/video/EglRenderer$FrameListener;FLio/agora/base/internal/video/RendererCommon$GlDrawer;Z)V
return-void
.end method
.method public addFrameListener(Lio/agora/base/internal/video/EglRenderer$FrameListener;FLio/agora/base/internal/video/RendererCommon$GlDrawer;)V
.registers 5
const/4 v0, 0x0
.line 664
invoke-virtual {p0, p1, p2, p3, v0}, Lio/agora/base/internal/video/EglRenderer;->addFrameListener(Lio/agora/base/internal/video/EglRenderer$FrameListener;FLio/agora/base/internal/video/RendererCommon$GlDrawer;Z)V
return-void
.end method
.method public addFrameListener(Lio/agora/base/internal/video/EglRenderer$FrameListener;FLio/agora/base/internal/video/RendererCommon$GlDrawer;Z)V
.registers 12
.line 679
new-instance v6, Lio/agora/base/internal/video/EglRenderer$7;
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}, Lio/agora/base/internal/video/EglRenderer$7;-><init>(Lio/agora/base/internal/video/EglRenderer;Lio/agora/base/internal/video/RendererCommon$GlDrawer;Lio/agora/base/internal/video/EglRenderer$FrameListener;FZ)V
invoke-direct {p0, v6}, Lio/agora/base/internal/video/EglRenderer;->postToRenderThread(Ljava/lang/Runnable;)V
return-void
.end method
.method public clearImage()V
.registers 5
.line 821
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v0, v0, Lio/agora/base/internal/video/EglRenderer$Color;->red:F
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v1, v1, Lio/agora/base/internal/video/EglRenderer$Color;->green:F
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v2, v2, Lio/agora/base/internal/video/EglRenderer$Color;->blue:F
iget-object v3, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v3, v3, Lio/agora/base/internal/video/EglRenderer$Color;->alpha:F
invoke-virtual {p0, v0, v1, v2, v3}, Lio/agora/base/internal/video/EglRenderer;->clearImage(FFFF)V
return-void
.end method
.method public clearImage(FFFF)V
.registers 14
.line 828
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 829
:try_start_3
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v1, :cond_9
.line 830
monitor-exit v0
return-void
.line 832
:cond_9
new-instance v8, Lio/agora/base/internal/video/EglRenderer$10;
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}, Lio/agora/base/internal/video/EglRenderer$10;-><init>(Lio/agora/base/internal/video/EglRenderer;FFFF)V
invoke-virtual {v1, v8}, Landroid/os/Handler;->postAtFrontOfQueue(Ljava/lang/Runnable;)Z
.line 838
monitor-exit v0
return-void
:catchall_19
move-exception p1
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw p1
.end method
.method public createEglSurface(Landroid/graphics/SurfaceTexture;)V
.registers 2
.line 308
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->createEglSurfaceInternal(Ljava/lang/Object;)V
return-void
.end method
.method public createEglSurface(Landroid/view/Surface;)V
.registers 2
.line 304
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->createEglSurfaceInternal(Ljava/lang/Object;)V
return-void
.end method
.method public disableFpsReduction()V
.registers 2
const/high16 v0, 0x7f800000 # Float.POSITIVE_INFINITY
.line 634
invoke-virtual {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->setFpsReduction(F)V
return-void
.end method
.method public getFrameDrawn()I
.registers 2
.line 207
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
# getter for: Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->frameDrawn:I
invoke-static {v0}, Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->access$800(Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;)I
move-result v0
return v0
.end method
.method public init(Lio/agora/base/internal/video/EglBase$Context;[ILio/agora/base/internal/video/RendererCommon$GlDrawer;Z)V
.registers 11
.line 232
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 233
:try_start_3
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v1, :cond_b3
const-string v1, "Initializing EglRenderer"
.line 236
invoke-direct {p0, v1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 237
iput-object p3, p0, Lio/agora/base/internal/video/EglRenderer;->drawer:Lio/agora/base/internal/video/RendererCommon$GlDrawer;
const/4 p3, 0x0
.line 238
iput-boolean p3, p0, Lio/agora/base/internal/video/EglRenderer;->isReleasing:Z
.line 239
new-instance p3, Landroid/os/HandlerThread;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->name:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "EglRenderer"
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
invoke-direct {p3, v1}, Landroid/os/HandlerThread;-><init>(Ljava/lang/String;)V
.line 240
invoke-virtual {p3}, Landroid/os/HandlerThread;->start()V
.line 241
invoke-static {}, Lio/agora/base/internal/video/EglRenderer;->getDefaultDisplayRefreshRateParams()D
move-result-wide v1
const-wide/16 v3, 0x0
cmpl-double v1, v1, v3
if-eqz v1, :cond_4c
.line 242
new-instance v1, Ljava/lang/Double;
const-wide v2, 0x41cdcd6500000000L # 1.0E9
.line 243
invoke-static {}, Lio/agora/base/internal/video/EglRenderer;->getDefaultDisplayRefreshRateParams()D
move-result-wide v4
div-double/2addr v2, v4
invoke-direct {v1, v2, v3}, Ljava/lang/Double;-><init>(D)V
invoke-virtual {v1}, Ljava/lang/Double;->longValue()J
move-result-wide v1
iput-wide v1, p0, Lio/agora/base/internal/video/EglRenderer;->frameIntervalNanos:J
goto :goto_50
.line 245
:cond_4c
sget-wide v1, Lio/agora/base/internal/video/EglRenderer;->DEFAULT_FRAME_INTERVAL_NANOS:J
iput-wide v1, p0, Lio/agora/base/internal/video/EglRenderer;->frameIntervalNanos:J
.line 247
:goto_50
new-instance v1, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;
.line 248
invoke-virtual {p3}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;
move-result-object p3
new-instance v2, Lio/agora/base/internal/video/EglRenderer$2;
invoke-direct {v2, p0}, Lio/agora/base/internal/video/EglRenderer$2;-><init>(Lio/agora/base/internal/video/EglRenderer;)V
invoke-direct {v1, p3, v2, p0}, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;-><init>(Landroid/os/Looper;Ljava/lang/Runnable;Lio/agora/base/internal/video/EglRenderer;)V
iput-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
.line 262
new-instance p3, Lio/agora/base/internal/video/EglRenderer$3;
invoke-direct {p3, p0, p1, p2}, Lio/agora/base/internal/video/EglRenderer$3;-><init>(Lio/agora/base/internal/video/EglRenderer;Lio/agora/base/internal/video/EglBase$Context;[I)V
invoke-static {v1, p3}, Lio/agora/base/internal/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;Ljava/lang/Runnable;)V
.line 277
iput-boolean p4, p0, Lio/agora/base/internal/video/EglRenderer;->switchToStartVsync:Z
.line 278
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string p2, "renderThreadHandler useVsync:"
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 279
iget-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->switchToStartVsync:Z
if-eqz p1, :cond_8d
.line 280
iget-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
new-instance p2, Lio/agora/base/internal/video/EglRenderer$4;
invoke-direct {p2, p0}, Lio/agora/base/internal/video/EglRenderer$4;-><init>(Lio/agora/base/internal/video/EglRenderer;)V
invoke-virtual {p1, p2}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
goto :goto_92
:cond_8d
const-string p1, "renderThreadHandler Choreographer disable"
.line 293
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 295
:goto_92
iget-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
iget-object p2, p0, Lio/agora/base/internal/video/EglRenderer;->eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
invoke-virtual {p1, p2}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
.line 296
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide p1
.line 297
iget-object p3, p0, Lio/agora/base/internal/video/EglRenderer;->statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
# invokes: Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->resetStatistics(J)V
invoke-static {p3, p1, p2}, Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->access$1200(Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;J)V
.line 298
iget-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
iget-object p2, p0, Lio/agora/base/internal/video/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;
sget-object p3, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x4
.line 299
invoke-virtual {p3, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide p3
.line 298
invoke-virtual {p1, p2, p3, p4}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z
.line 300
monitor-exit v0
return-void
.line 234
:cond_b3
new-instance p1, Ljava/lang/IllegalStateException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
iget-object p3, p0, Lio/agora/base/internal/video/EglRenderer;->name:Ljava/lang/String;
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p3, "Already initialized"
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
:catchall_cc
move-exception p1
.line 300
monitor-exit v0
:try_end_ce
.catchall {:try_start_3 .. :try_end_ce} :catchall_cc
throw p1
.end method
.method public isRenderOnSurfaceView(Z)V
.registers 2
.line 211
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->isRenderOnSurfaceView:Z
return-void
.end method
.method protected notifySurfaceSizeChanged()V
.registers 5
.line 722
sget-boolean v0, Lio/agora/base/internal/video/EglRenderer;->ENABLE_LAST_FRAME:Z
if-nez v0, :cond_5
return-void
.line 725
:cond_5
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 726
:try_start_8
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v1, :cond_13
const-string v1, "notifySurfaceSizeChanged "
.line 727
invoke-direct {p0, v1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 728
monitor-exit v0
return-void
.line 730
:cond_13
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
if-eqz v1, :cond_22
.line 731
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v1
.line 732
iget-object v3, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
check-cast v3, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;
.line 733
invoke-virtual {v3, v1, v2}, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;->sendLastFrameToRenderThread(J)V
.line 735
:cond_22
monitor-exit v0
return-void
:catchall_24
move-exception v1
monitor-exit v0
:try_end_26
.catchall {:try_start_8 .. :try_end_26} :catchall_24
throw v1
.end method
.method public onFrame(Lio/agora/base/VideoFrame;)V
.registers 6
.line 741
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->statisticsInfo:Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;
# invokes: Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->updateFrameReceived()V
invoke-static {v0}, Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;->access$1800(Lio/agora/base/internal/video/EglRenderer$StatisticsInfo;)V
.line 743
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
.line 744
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceLock:Ljava/lang/Object;
monitor-enter v2
.line 745
:try_start_c
iget-boolean v3, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceValid:Z
if-nez v3, :cond_17
const-string p1, "Dropping frame - Not valid surface."
.line 746
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 747
monitor-exit v2
return-void
.line 749
:cond_17
monitor-exit v2
:try_end_18
.catchall {:try_start_c .. :try_end_18} :catchall_30
.line 750
iget-object v3, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v3
.line 751
:try_start_1b
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v2, :cond_26
const-string p1, "Dropping frame - Not initialized or already released."
.line 752
invoke-direct {p0, p1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 753
monitor-exit v3
return-void
.line 755
:cond_26
check-cast v2, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;
.line 756
invoke-virtual {v2, v0, v1, p1}, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;->sendFrameToRenderThread(JLio/agora/base/VideoFrame;)V
.line 757
monitor-exit v3
return-void
:catchall_2d
move-exception p1
monitor-exit v3
:try_end_2f
.catchall {:try_start_1b .. :try_end_2f} :catchall_2d
throw p1
:catchall_30
move-exception p1
.line 749
:try_start_31
monitor-exit v2
:try_end_32
.catchall {:try_start_31 .. :try_end_32} :catchall_30
throw p1
.end method
.method public pauseVideo()V
.registers 2
const/4 v0, 0x0
.line 638
invoke-virtual {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->setFpsReduction(F)V
return-void
.end method
.method public printStackTrace()V
.registers 6
.line 538
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 540
:try_start_3
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v1, :cond_9
const/4 v1, 0x0
goto :goto_11
:cond_9
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_11
if-eqz v1, :cond_2f
.line 542
invoke-virtual {v1}, Ljava/lang/Thread;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v1
.line 543
array-length v2, v1
if-lez v2, :cond_2f
const-string v2, "EglRenderer stack trace:"
.line 544
invoke-direct {p0, v2}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 545
array-length v2, v1
const/4 v3, 0x0
:goto_21
if-ge v3, v2, :cond_2f
aget-object v4, v1, v3
.line 546
invoke-virtual {v4}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v4
invoke-direct {p0, v4}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
add-int/lit8 v3, v3, 0x1
goto :goto_21
.line 550
:cond_2f
monitor-exit v0
return-void
:catchall_31
move-exception v1
monitor-exit v0
:try_end_33
.catchall {:try_start_3 .. :try_end_33} :catchall_31
throw v1
.end method
.method public release()V
.registers 6
const-string v0, "Releasing."
.line 326
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
const/4 v0, 0x1
.line 327
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->isReleasing:Z
.line 328
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v0
.line 329
:try_start_b
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v1, :cond_16
const-string v1, "Already released"
.line 330
invoke-direct {p0, v1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 331
monitor-exit v0
return-void
.line 333
:cond_16
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->logStatisticsRunnable:Ljava/lang/Runnable;
invoke-virtual {v1, v2}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V
:try_end_1b
.catchall {:try_start_b .. :try_end_1b} :catchall_67
.line 336
:try_start_1b
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
const-wide/16 v2, 0x3e8
new-instance v4, Lio/agora/base/internal/video/EglRenderer$5;
invoke-direct {v4, p0}, Lio/agora/base/internal/video/EglRenderer$5;-><init>(Lio/agora/base/internal/video/EglRenderer;)V
invoke-static {v1, v2, v3, v4}, Lio/agora/base/internal/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;JLjava/util/concurrent/Callable;)Ljava/lang/Object;
:try_end_27
.catch Ljava/lang/Exception; {:try_start_1b .. :try_end_27} :catch_28
.catchall {:try_start_1b .. :try_end_27} :catchall_67
goto :goto_3d
:catch_28
move-exception v1
.line 374
:try_start_29
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "failed to make current and detach: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {p0, v1}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 376
:goto_3d
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
check-cast v1, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;
invoke-virtual {v1}, Lio/agora/base/internal/video/EglRenderer$HandlerWithFrameSyncControl;->sendStopChoreographer()V
.line 378
iget-object v1, p0, Lio/agora/base/internal/video/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;->quitSafely()V
const/4 v1, 0x0
.line 379
iput-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
.line 380
monitor-exit v0
:try_end_51
.catchall {:try_start_29 .. :try_end_51} :catchall_67
const/4 v0, 0x0
.line 381
iput-boolean v0, p0, Lio/agora/base/internal/video/EglRenderer;->isVsyncCallbackStared:Z
.line 382
sget-boolean v0, Lio/agora/base/internal/video/EglRenderer;->ENABLE_LAST_FRAME:Z
if-eqz v0, :cond_61
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
if-eqz v0, :cond_61
.line 383
invoke-virtual {v0}, Lio/agora/base/VideoFrame;->release()V
.line 384
iput-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->lastFrame:Lio/agora/base/VideoFrame;
:cond_61
const-string v0, "Releasing done."
.line 386
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
return-void
:catchall_67
move-exception v1
.line 380
:try_start_68
monitor-exit v0
:try_end_69
.catchall {:try_start_68 .. :try_end_69} :catchall_67
throw v1
.end method
.method public releaseEglSurface()V
.registers 6
.line 766
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceLock:Ljava/lang/Object;
monitor-enter v0
const/4 v1, 0x0
.line 767
:try_start_4
iput-boolean v1, p0, Lio/agora/base/internal/video/EglRenderer;->surfaceValid:Z
.line 768
monitor-exit v0
:try_end_7
.catchall {:try_start_4 .. :try_end_7} :catchall_4a
const-string v0, "releaseEglSurface"
.line 769
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 770
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;->setSurface(Ljava/lang/Object;)V
.line 771
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v1
.line 772
:try_start_15
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
:try_end_17
.catchall {:try_start_15 .. :try_end_17} :catchall_47
if-eqz v0, :cond_45
.line 774
:try_start_19
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->eglSurfaceCreationRunnable:Lio/agora/base/internal/video/EglRenderer$EglSurfaceCreation;
invoke-virtual {v0, v2}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V
const-string v0, "invoke releaseEglSurface"
.line 775
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 776
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
const-wide/16 v2, 0x3e8
new-instance v4, Lio/agora/base/internal/video/EglRenderer$9;
invoke-direct {v4, p0}, Lio/agora/base/internal/video/EglRenderer$9;-><init>(Lio/agora/base/internal/video/EglRenderer;)V
invoke-static {v0, v2, v3, v4}, Lio/agora/base/internal/ThreadUtils;->invokeAtFrontUninterruptibly(Landroid/os/Handler;JLjava/util/concurrent/Callable;)Ljava/lang/Object;
:try_end_2f
.catch Ljava/lang/Exception; {:try_start_19 .. :try_end_2f} :catch_30
.catchall {:try_start_19 .. :try_end_2f} :catchall_47
goto :goto_45
:catch_30
move-exception v0
.line 791
:try_start_31
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "failed to release surface: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 794
:cond_45
:goto_45
monitor-exit v1
return-void
:catchall_47
move-exception v0
monitor-exit v1
:try_end_49
.catchall {:try_start_31 .. :try_end_49} :catchall_47
throw v0
:catchall_4a
move-exception v1
.line 768
:try_start_4b
monitor-exit v0
:try_end_4c
.catchall {:try_start_4b .. :try_end_4c} :catchall_4a
throw v1
.end method
.method public removeFrameListener(Lio/agora/base/internal/video/EglRenderer$FrameListener;)V
.registers 6
.line 697
new-instance v0, Ljava/util/concurrent/CountDownLatch;
const/4 v1, 0x1
invoke-direct {v0, v1}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V
.line 698
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->handlerLock:Ljava/lang/Object;
monitor-enter v1
.line 699
:try_start_9
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-nez v2, :cond_f
.line 700
monitor-exit v1
return-void
.line 702
:cond_f
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
iget-object v3, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
invoke-virtual {v3}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;
move-result-object v3
invoke-virtual {v3}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;
move-result-object v3
if-eq v2, v3, :cond_2c
.line 705
new-instance v2, Lio/agora/base/internal/video/EglRenderer$8;
invoke-direct {v2, p0, v0, p1}, Lio/agora/base/internal/video/EglRenderer$8;-><init>(Lio/agora/base/internal/video/EglRenderer;Ljava/util/concurrent/CountDownLatch;Lio/agora/base/internal/video/EglRenderer$FrameListener;)V
invoke-direct {p0, v2}, Lio/agora/base/internal/video/EglRenderer;->postToRenderThread(Ljava/lang/Runnable;)V
.line 717
monitor-exit v1
:try_end_28
.catchall {:try_start_9 .. :try_end_28} :catchall_34
.line 718
invoke-static {v0}, Lio/agora/base/internal/ThreadUtils;->awaitUninterruptibly(Ljava/util/concurrent/CountDownLatch;)V
return-void
.line 703
:cond_2c
:try_start_2c
new-instance p1, Ljava/lang/RuntimeException;
const-string v0, "removeFrameListener must not be called on the render thread."
invoke-direct {p1, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw p1
:catchall_34
move-exception p1
.line 717
monitor-exit v1
:try_end_36
.catchall {:try_start_2c .. :try_end_36} :catchall_34
throw p1
.end method
.method public setBackgroundColor(I)V
.registers 5
.line 584
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "setBackgroundColor"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {p1}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String;
move-result-object v1
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
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 585
new-instance v0, Lio/agora/base/internal/video/EglRenderer$Color;
invoke-direct {v0, p0, p1}, Lio/agora/base/internal/video/EglRenderer$Color;-><init>(Lio/agora/base/internal/video/EglRenderer;I)V
iput-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
.line 586
iget p1, v0, Lio/agora/base/internal/video/EglRenderer$Color;->red:F
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v0, v0, Lio/agora/base/internal/video/EglRenderer$Color;->green:F
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v1, v1, Lio/agora/base/internal/video/EglRenderer$Color;->blue:F
iget-object v2, p0, Lio/agora/base/internal/video/EglRenderer;->backgroudColor:Lio/agora/base/internal/video/EglRenderer$Color;
iget v2, v2, Lio/agora/base/internal/video/EglRenderer$Color;->alpha:F
invoke-virtual {p0, p1, v0, v1, v2}, Lio/agora/base/internal/video/EglRenderer;->clearImage(FFFF)V
return-void
.end method
.method public setFpsReduction(F)V
.registers 8
.line 618
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}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 619
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->fpsReductionLock:Ljava/lang/Object;
monitor-enter v0
.line 620
:try_start_17
iget-wide v1, p0, Lio/agora/base/internal/video/EglRenderer;->minRenderPeriodNs:J
const/4 v3, 0x0
cmpg-float v3, p1, v3
if-gtz v3, :cond_26
const-wide v3, 0x7fffffffffffffffL
.line 622
iput-wide v3, p0, Lio/agora/base/internal/video/EglRenderer;->minRenderPeriodNs:J
goto :goto_33
.line 624
: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, Lio/agora/base/internal/video/EglRenderer;->minRenderPeriodNs:J
.line 626
:goto_33
iget-wide v3, p0, Lio/agora/base/internal/video/EglRenderer;->minRenderPeriodNs:J
cmp-long p1, v3, v1
if-eqz p1, :cond_3f
.line 628
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v1
iput-wide v1, p0, Lio/agora/base/internal/video/EglRenderer;->nextFrameTimeNs:J
.line 630
:cond_3f
monitor-exit v0
return-void
:catchall_41
move-exception p1
monitor-exit v0
:try_end_43
.catchall {:try_start_17 .. :try_end_43} :catchall_41
throw p1
.end method
.method public setLayoutAspectRatio(F)V
.registers 4
.line 594
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}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 595
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->layoutLock:Ljava/lang/Object;
monitor-enter v0
.line 596
:try_start_17
iput p1, p0, Lio/agora/base/internal/video/EglRenderer;->layoutAspectRatio:F
.line 597
monitor-exit v0
return-void
:catchall_1b
move-exception p1
monitor-exit v0
:try_end_1d
.catchall {:try_start_17 .. :try_end_1d} :catchall_1b
throw p1
.end method
.method public setLayoutScaledFit(Z)V
.registers 4
.line 605
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "layoutScaledFit: "
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}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 606
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->layoutLock:Ljava/lang/Object;
monitor-enter v0
.line 607
:try_start_17
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->layoutScaledFit:Z
.line 608
monitor-exit v0
return-void
:catchall_1b
move-exception p1
monitor-exit v0
:try_end_1d
.catchall {:try_start_17 .. :try_end_1d} :catchall_1b
throw p1
.end method
.method public setMirror(Z)V
.registers 4
.line 557
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}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 558
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->layoutLock:Ljava/lang/Object;
monitor-enter v0
.line 559
:try_start_17
iget-boolean v1, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
if-eq v1, p1, :cond_20
.line 560
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->mirror:Z
const/4 p1, 0x1
.line 561
iput-boolean p1, p0, Lio/agora/base/internal/video/EglRenderer;->textureCoordUpdate:Z
.line 563
:cond_20
monitor-exit v0
return-void
:catchall_22
move-exception p1
monitor-exit v0
:try_end_24
.catchall {:try_start_17 .. :try_end_24} :catchall_22
throw p1
.end method
.method public updateCropArea(Landroid/graphics/Rect;)V
.registers 5
.line 571
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "updateCropArea: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Landroid/graphics/Rect;->toString()Ljava/lang/String;
move-result-object v1
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
invoke-direct {p0, v0}, Lio/agora/base/internal/video/EglRenderer;->logD(Ljava/lang/String;)V
.line 572
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->layoutLock:Ljava/lang/Object;
monitor-enter v0
.line 573
:try_start_1b
iget-object v1, p0, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
const/4 v2, 0x1
if-nez v1, :cond_27
if-eqz p1, :cond_27
.line 574
iput-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
.line 575
iput-boolean v2, p0, Lio/agora/base/internal/video/EglRenderer;->textureCoordUpdate:Z
goto :goto_35
:cond_27
if-eqz v1, :cond_35
if-eqz p1, :cond_35
.line 576
invoke-virtual {v1, p1}, Landroid/graphics/Rect;->equals(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_35
.line 577
iput-object p1, p0, Lio/agora/base/internal/video/EglRenderer;->rect:Landroid/graphics/Rect;
.line 578
iput-boolean v2, p0, Lio/agora/base/internal/video/EglRenderer;->textureCoordUpdate:Z
.line 580
:cond_35
:goto_35
monitor-exit v0
return-void
:catchall_37
move-exception p1
monitor-exit v0
:try_end_39
.catchall {:try_start_1b .. :try_end_39} :catchall_37
throw p1
.end method
.method public updateVsyncDuration(J)V
.registers 5
.line 390
iget-object v0, p0, Lio/agora/base/internal/video/EglRenderer;->renderThreadHandler:Landroid/os/Handler;
if-eqz v0, :cond_c
.line 391
new-instance v1, Lio/agora/base/internal/video/EglRenderer$6;
invoke-direct {v1, p0, p1, p2}, Lio/agora/base/internal/video/EglRenderer$6;-><init>(Lio/agora/base/internal/video/EglRenderer;J)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
:cond_c
return-void
.end method