VideoFrameReleaseTimeHelper.smali
.class public final Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;
.super Ljava/lang/Object;
.source "VideoFrameReleaseTimeHelper.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;,
Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
}
.end annotation
# static fields
.field private static final CHOREOGRAPHER_SAMPLE_DELAY_MILLIS:J = 0x1f4L
.field private static final MAX_ALLOWED_DRIFT_NS:J = 0x1312d00L
.field private static final MIN_FRAMES_FOR_ADJUSTMENT:I
.field private static final VSYNC_OFFSET_PERCENTAGE:J = 0x50L
# instance fields
.field private adjustedLastFrameTimeNs:J
.field private final displayListener:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
.field private frameCount:J
.field private haveSync:Z
.field private lastFramePresentationTimeUs:J
.field private pendingAdjustedFrameTimeNs:J
.field private syncFramePresentationTimeNs:J
.field private syncUnadjustedReleaseTimeNs:J
.field private vsyncDurationNs:J
.field private vsyncOffsetNs:J
.field private final vsyncSampler:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
.field private final windowManager:Landroid/view/WindowManager;
# direct methods
.method static constructor <clinit>()V
.registers 1
const v0, 0x1569
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->MIN_FRAMES_FOR_ADJUSTMENT:I
return-void
.end method
.method public constructor <init>()V
.registers 2
.line 65
const/4 v0, 0x0
invoke-direct {p0, v0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;-><init>(Landroid/content/Context;)V
.line 66
return-void
.end method
.method public constructor <init>(Landroid/content/Context;)V
.registers 5
.param p1, "context" # Landroid/content/Context;
.line 74
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 75
const/4 v0, 0x0
if-eqz p1, :cond_16
.line 76
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object p1
.line 77
const-string/jumbo v1, "window"
invoke-virtual {p1, v1}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroid/view/WindowManager;
iput-object v1, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->windowManager:Landroid/view/WindowManager;
goto :goto_18
.line 79
:cond_16
iput-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->windowManager:Landroid/view/WindowManager;
.line 81
:goto_18
iget-object v1, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->windowManager:Landroid/view/WindowManager;
if-eqz v1, :cond_2f
.line 82
sget v1, Lcom/google/android/exoplayer2/util/Util;->SDK_INT:I
const/16 v2, 0x11
if-lt v1, v2, :cond_26
invoke-direct {p0, p1}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->maybeBuildDefaultDisplayListenerV17(Landroid/content/Context;)Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
move-result-object v0
:cond_26
iput-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->displayListener:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
.line 83
invoke-static {}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;->getInstance()Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
move-result-object v0
iput-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncSampler:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
goto :goto_33
.line 85
:cond_2f
iput-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->displayListener:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
.line 86
iput-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncSampler:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
.line 88
:goto_33
const-wide v0, -0x7fffffffffffffffL # -4.9E-324
iput-wide v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncDurationNs:J
.line 89
iput-wide v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncOffsetNs:J
.line 90
return-void
.end method
.method static synthetic access$000(Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;)V
.registers 1
.param p0, "x0" # Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;
.line 36
invoke-direct {p0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->updateDefaultDisplayRefreshRateParams()V
return-void
.end method
.method private static closestVsync(JJJ)J
.registers 20
.param p0, "releaseTime" # J
.param p2, "sampledVsyncTime" # J
.param p4, "vsyncDuration" # J
.line 214
sub-long v0, p0, p2
div-long v0, v0, p4
.line 215
.local v0, "vsyncCount":J
mul-long v2, p4, v0
add-long v2, p2, v2
.line 218
.local v2, "snappedTimeNs":J
cmp-long v4, p0, v2
if-gtz v4, :cond_10
.line 219
sub-long v4, v2, p4
.line 220
.local v4, "snappedBeforeNs":J
move-wide v6, v2
.local v6, "snappedAfterNs":J
goto :goto_13
.line 222
.end local v4 # "snappedBeforeNs":J
.end local v6 # "snappedAfterNs":J
:cond_10
move-wide v4, v2
.line 223
.restart local v4 # "snappedBeforeNs":J
add-long v6, v2, p4
.line 225
.restart local v6 # "snappedAfterNs":J
:goto_13
sub-long v8, v6, p0
.line 226
.local v8, "snappedAfterDiff":J
sub-long v10, p0, v4
.line 227
.local v10, "snappedBeforeDiff":J
cmp-long v12, v8, v10
if-gez v12, :cond_1d
move-wide v12, v6
goto :goto_1e
:cond_1d
move-wide v12, v4
:goto_1e
return-wide v12
.end method
.method private isDriftTooLarge(JJ)Z
.registers 14
.param p1, "frameTimeNs" # J
.param p3, "releaseTimeNs" # J
.line 208
iget-wide v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncFramePresentationTimeNs:J
sub-long v0, p1, v0
.line 209
.local v0, "elapsedFrameTimeNs":J
iget-wide v2, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncUnadjustedReleaseTimeNs:J
sub-long v2, p3, v2
.line 210
.local v2, "elapsedReleaseTimeNs":J
sub-long v4, v2, v0
invoke-static {v4, v5}, Ljava/lang/Math;->abs(J)J
move-result-wide v4
const-wide/32 v6, 0x1312d00
cmp-long v8, v4, v6
if-lez v8, :cond_17
const/4 v4, 0x1
goto :goto_18
:cond_17
const/4 v4, 0x0
:goto_18
return v4
.end method
.method private maybeBuildDefaultDisplayListenerV17(Landroid/content/Context;)Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
.registers 4
.param p1, "context" # Landroid/content/Context;
.line 193
const-string v0, "display"
invoke-virtual {p1, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/hardware/display/DisplayManager;
.line 194
.local v0, "manager":Landroid/hardware/display/DisplayManager;
if-nez v0, :cond_c
const/4 v1, 0x0
goto :goto_11
:cond_c
new-instance v1, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
invoke-direct {v1, p0, v0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;-><init>(Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;Landroid/hardware/display/DisplayManager;)V
:goto_11
return-object v1
.end method
.method private updateDefaultDisplayRefreshRateParams()V
.registers 8
.line 199
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->windowManager:Landroid/view/WindowManager;
invoke-interface {v0}, Landroid/view/WindowManager;->getDefaultDisplay()Landroid/view/Display;
move-result-object v0
.line 200
.local v0, "defaultDisplay":Landroid/view/Display;
if-eqz v0, :cond_22
.line 201
invoke-virtual {v0}, Landroid/view/Display;->getRefreshRate()F
move-result v1
float-to-double v1, v1
.line 202
.local v1, "defaultDisplayRefreshRate":D
const-wide v3, 0x41cdcd6500000000L # 1.0E9
invoke-static {v1, v2}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v3, v1
double-to-long v3, v3
iput-wide v3, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncDurationNs:J
.line 203
const-wide/16 v5, 0x50
mul-long v3, v3, v5
const-wide/16 v5, 0x64
div-long/2addr v3, v5
iput-wide v3, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncOffsetNs:J
.line 205
.end local v1 # "defaultDisplayRefreshRate":D
:cond_22
return-void
.end method
# virtual methods
.method public adjustReleaseTime(JJ)J
.registers 27
.param p1, "framePresentationTimeUs" # J
.param p3, "unadjustedReleaseTimeNs" # J
.line 128
move-object/from16 v0, p0
move-wide/from16 v1, p1
move-wide/from16 v3, p3
const-wide/16 v5, 0x3e8
mul-long v5, v5, v1
.line 131
.local v5, "framePresentationTimeNs":J
move-wide v7, v5
.line 132
.local v7, "adjustedFrameTimeNs":J
move-wide/from16 v9, p3
.line 134
.local v9, "adjustedReleaseTimeNs":J
iget-boolean v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->haveSync:Z
if-eqz v11, :cond_57
.line 136
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->lastFramePresentationTimeUs:J
cmp-long v13, v1, v11
if-eqz v13, :cond_22
.line 137
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->frameCount:J
const-wide/16 v13, 0x1
add-long/2addr v11, v13
iput-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->frameCount:J
.line 138
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->pendingAdjustedFrameTimeNs:J
iput-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->adjustedLastFrameTimeNs:J
.line 140
:cond_22
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->frameCount:J
const-wide/16 v13, 0x6
const/4 v15, 0x0
cmp-long v16, v11, v13
if-ltz v16, :cond_4c
.line 145
iget-wide v13, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncFramePresentationTimeNs:J
sub-long v13, v5, v13
div-long/2addr v13, v11
.line 148
.local v13, "averageFrameDurationNs":J
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->adjustedLastFrameTimeNs:J
add-long/2addr v11, v13
.line 150
.local v11, "candidateAdjustedFrameTimeNs":J
invoke-direct {v0, v11, v12, v3, v4}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->isDriftTooLarge(JJ)Z
move-result v16
if-eqz v16, :cond_3c
.line 151
iput-boolean v15, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->haveSync:Z
goto :goto_49
.line 153
:cond_3c
move-wide v7, v11
.line 154
move-wide/from16 v16, v9
.end local v9 # "adjustedReleaseTimeNs":J
.local v16, "adjustedReleaseTimeNs":J
iget-wide v9, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncUnadjustedReleaseTimeNs:J
add-long/2addr v9, v7
move-wide/from16 v18, v7
.end local v7 # "adjustedFrameTimeNs":J
.local v18, "adjustedFrameTimeNs":J
iget-wide v7, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncFramePresentationTimeNs:J
sub-long/2addr v9, v7
move-wide/from16 v7, v18
.line 157
.end local v11 # "candidateAdjustedFrameTimeNs":J
.end local v13 # "averageFrameDurationNs":J
.end local v16 # "adjustedReleaseTimeNs":J
.end local v18 # "adjustedFrameTimeNs":J
.restart local v7 # "adjustedFrameTimeNs":J
.restart local v9 # "adjustedReleaseTimeNs":J
:goto_49
move-wide/from16 v16, v9
goto :goto_59
.line 160
:cond_4c
move-wide/from16 v16, v9
.end local v9 # "adjustedReleaseTimeNs":J
.restart local v16 # "adjustedReleaseTimeNs":J
invoke-direct {v0, v5, v6, v3, v4}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->isDriftTooLarge(JJ)Z
move-result v9
if-eqz v9, :cond_59
.line 161
iput-boolean v15, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->haveSync:Z
goto :goto_59
.line 134
.end local v16 # "adjustedReleaseTimeNs":J
.restart local v9 # "adjustedReleaseTimeNs":J
:cond_57
move-wide/from16 v16, v9
.line 167
.end local v9 # "adjustedReleaseTimeNs":J
.restart local v16 # "adjustedReleaseTimeNs":J
:cond_59
:goto_59
iget-boolean v9, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->haveSync:Z
if-nez v9, :cond_68
.line 168
iput-wide v5, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncFramePresentationTimeNs:J
.line 169
iput-wide v3, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->syncUnadjustedReleaseTimeNs:J
.line 170
const-wide/16 v9, 0x0
iput-wide v9, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->frameCount:J
.line 171
const/4 v9, 0x1
iput-boolean v9, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->haveSync:Z
.line 174
:cond_68
iput-wide v1, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->lastFramePresentationTimeUs:J
.line 175
iput-wide v7, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->pendingAdjustedFrameTimeNs:J
.line 177
iget-object v9, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncSampler:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
if-eqz v9, :cond_97
iget-wide v10, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncDurationNs:J
const-wide v12, -0x7fffffffffffffffL # -4.9E-324
cmp-long v14, v10, v12
if-nez v14, :cond_7c
goto :goto_97
.line 180
:cond_7c
iget-wide v14, v9, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;->sampledVsyncTimeNs:J
.line 181
.local v14, "sampledVsyncTimeNs":J
cmp-long v9, v14, v12
if-nez v9, :cond_83
.line 182
return-wide v16
.line 186
:cond_83
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncDurationNs:J
move-wide/from16 v9, v16
move-wide/from16 v18, v11
move-wide v11, v14
move-wide/from16 v20, v14
.end local v14 # "sampledVsyncTimeNs":J
.local v20, "sampledVsyncTimeNs":J
move-wide/from16 v13, v18
invoke-static/range {v9 .. v14}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->closestVsync(JJJ)J
move-result-wide v9
.line 188
.local v9, "snappedTimeNs":J
iget-wide v11, v0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncOffsetNs:J
sub-long v11, v9, v11
return-wide v11
.line 178
.end local v9 # "snappedTimeNs":J
.end local v20 # "sampledVsyncTimeNs":J
:cond_97
:goto_97
return-wide v16
.end method
.method public disable()V
.registers 2
.line 110
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->windowManager:Landroid/view/WindowManager;
if-eqz v0, :cond_10
.line 111
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->displayListener:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
if-eqz v0, :cond_b
.line 112
invoke-virtual {v0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;->unregister()V
.line 114
:cond_b
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncSampler:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
invoke-virtual {v0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;->removeObserver()V
.line 116
:cond_10
return-void
.end method
.method public enable()V
.registers 2
.line 96
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->haveSync:Z
.line 97
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->windowManager:Landroid/view/WindowManager;
if-eqz v0, :cond_16
.line 98
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->vsyncSampler:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;
invoke-virtual {v0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$VSyncSampler;->addObserver()V
.line 99
iget-object v0, p0, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->displayListener:Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;
if-eqz v0, :cond_13
.line 100
invoke-virtual {v0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper$DefaultDisplayListener;->register()V
.line 102
:cond_13
invoke-direct {p0}, Lcom/google/android/exoplayer2/video/VideoFrameReleaseTimeHelper;->updateDefaultDisplayRefreshRateParams()V
.line 104
:cond_16
return-void
.end method