TwilightCalculator.smali
.class Landroidx/appcompat/app/TwilightCalculator;
.super Ljava/lang/Object;
.source "TwilightCalculator.java"
# static fields
.field private static final ALTIDUTE_CORRECTION_CIVIL_TWILIGHT:F = -0.10471976f
.field private static final C1:F = 0.0334196f
.field private static final C2:F = 3.49066E-4f
.field private static final C3:F = 5.236E-6f
.field public static final DAY:I
.field private static final DEGREES_TO_RADIANS:F = 0.017453292f
.field private static final J0:F = 9.0E-4f
.field public static final NIGHT:I
.field private static final OBLIQUITY:F = 0.4092797f
.field private static final UTC_2000:J = 0xdc6d62da00L
.field private static sInstance:Landroidx/appcompat/app/TwilightCalculator;
# instance fields
.field public state:I
.field public sunrise:J
.field public sunset:J
# direct methods
.method static constructor <clinit>()V
.registers 1
const v0, 0x156f
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Landroidx/appcompat/app/TwilightCalculator;->DAY:I
const v0, 0x156e
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Landroidx/appcompat/app/TwilightCalculator;->NIGHT:I
return-void
.end method
.method constructor <init>()V
.registers 1
.line 26
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method static getInstance()Landroidx/appcompat/app/TwilightCalculator;
.registers 1
.line 31
sget-object v0, Landroidx/appcompat/app/TwilightCalculator;->sInstance:Landroidx/appcompat/app/TwilightCalculator;
if-nez v0, :cond_b
.line 32
new-instance v0, Landroidx/appcompat/app/TwilightCalculator;
invoke-direct {v0}, Landroidx/appcompat/app/TwilightCalculator;-><init>()V
sput-object v0, Landroidx/appcompat/app/TwilightCalculator;->sInstance:Landroidx/appcompat/app/TwilightCalculator;
.line 34
:cond_b
sget-object v0, Landroidx/appcompat/app/TwilightCalculator;->sInstance:Landroidx/appcompat/app/TwilightCalculator;
return-object v0
.end method
# virtual methods
.method public calculateTwilight(JDD)V
.registers 36
.param p1, "time" # J
.param p3, "latitude" # D
.param p5, "longitude" # D
.line 89
move-object/from16 v0, p0
const-wide v1, 0xdc6d62da00L
sub-long v3, p1, v1
long-to-float v3, v3
const v4, 0x4ca4cb80 # 8.64E7f
div-float/2addr v3, v4
.line 92
.local v3, "daysSince2000":F
const v4, 0x3c8ceb25
mul-float v4, v4, v3
const v5, 0x40c7ae92
add-float/2addr v4, v5
.line 95
.local v4, "meanAnomaly":F
float-to-double v5, v4
float-to-double v7, v4
invoke-static {v7, v8}, Ljava/lang/Math;->sin(D)D
move-result-wide v7
const-wide v9, 0x3fa11c5fc0000000L # 0.03341960161924362
mul-double v7, v7, v9
invoke-static {v5, v6}, Ljava/lang/Double;->isNaN(D)Z
add-double/2addr v5, v7
const/high16 v7, 0x40000000 # 2.0f
mul-float v7, v7, v4
float-to-double v7, v7
.line 96
invoke-static {v7, v8}, Ljava/lang/Math;->sin(D)D
move-result-wide v7
const-wide v9, 0x3f36e05b00000000L # 3.4906598739326E-4
mul-double v7, v7, v9
add-double/2addr v5, v7
const/high16 v7, 0x40400000 # 3.0f
mul-float v7, v7, v4
float-to-double v7, v7
invoke-static {v7, v8}, Ljava/lang/Math;->sin(D)D
move-result-wide v7
const-wide v9, 0x3ed5f61cc0000000L # 5.236000106378924E-6
mul-double v7, v7, v9
add-double/2addr v5, v7
.line 99
.local v5, "trueAnomaly":D
const-wide v7, 0x3ffcbed85e1ce332L # 1.796593063
add-double/2addr v7, v5
const-wide v9, 0x400921fb54442d18L # Math.PI
add-double/2addr v7, v9
.line 102
.local v7, "solarLng":D
move-wide/from16 v9, p5
neg-double v11, v9
const-wide v13, 0x4076800000000000L # 360.0
div-double/2addr v11, v13
.line 103
.local v11, "arcLongitude":D
const v13, 0x3a6bedfa # 9.0E-4f
sub-float v14, v3, v13
float-to-double v14, v14
invoke-static {v14, v15}, Ljava/lang/Double;->isNaN(D)Z
sub-double/2addr v14, v11
invoke-static {v14, v15}, Ljava/lang/Math;->round(D)J
move-result-wide v14
long-to-float v14, v14
.line 104
.local v14, "n":F
add-float/2addr v13, v14
float-to-double v1, v13
invoke-static {v1, v2}, Ljava/lang/Double;->isNaN(D)Z
add-double/2addr v1, v11
move-wide/from16 v17, v5
.end local v5 # "trueAnomaly":D
.local v17, "trueAnomaly":D
float-to-double v5, v4
invoke-static {v5, v6}, Ljava/lang/Math;->sin(D)D
move-result-wide v5
const-wide v19, 0x3f75b573eab367a1L # 0.0053
mul-double v5, v5, v19
add-double/2addr v1, v5
const-wide/high16 v5, 0x4000000000000000L # 2.0
mul-double v5, v5, v7
.line 105
invoke-static {v5, v6}, Ljava/lang/Math;->sin(D)D
move-result-wide v5
const-wide v19, -0x4083bcd35a858794L # -0.0069
mul-double v5, v5, v19
add-double/2addr v1, v5
.line 108
.local v1, "solarTransitJ2000":D
invoke-static {v7, v8}, Ljava/lang/Math;->sin(D)D
move-result-wide v5
const-wide v19, 0x3fda31a380000000L # 0.4092797040939331
invoke-static/range {v19 .. v20}, Ljava/lang/Math;->sin(D)D
move-result-wide v19
mul-double v5, v5, v19
invoke-static {v5, v6}, Ljava/lang/Math;->asin(D)D
move-result-wide v5
.line 110
.local v5, "solarDec":D
const-wide v19, 0x3f91df46a0000000L # 0.01745329238474369
mul-double v19, v19, p3
.line 112
.local v19, "latRad":D
const-wide v21, -0x4045311600000000L # -0.10471975803375244
invoke-static/range {v21 .. v22}, Ljava/lang/Math;->sin(D)D
move-result-wide v21
invoke-static/range {v19 .. v20}, Ljava/lang/Math;->sin(D)D
move-result-wide v23
.line 113
invoke-static {v5, v6}, Ljava/lang/Math;->sin(D)D
move-result-wide v25
mul-double v23, v23, v25
sub-double v21, v21, v23
invoke-static/range {v19 .. v20}, Ljava/lang/Math;->cos(D)D
move-result-wide v23
invoke-static {v5, v6}, Ljava/lang/Math;->cos(D)D
move-result-wide v25
mul-double v23, v23, v25
div-double v21, v21, v23
.line 116
.local v21, "cosHourAngle":D
move/from16 v23, v14
.end local v14 # "n":F
.local v23, "n":F
const-wide/16 v13, -0x1
const-wide/high16 v25, 0x3ff0000000000000L # 1.0
cmpl-double v27, v21, v25
if-ltz v27, :cond_e0
.line 117
const/4 v15, 0x1
iput v15, v0, Landroidx/appcompat/app/TwilightCalculator;->state:I
.line 118
iput-wide v13, v0, Landroidx/appcompat/app/TwilightCalculator;->sunset:J
.line 119
iput-wide v13, v0, Landroidx/appcompat/app/TwilightCalculator;->sunrise:J
.line 120
return-void
.line 121
:cond_e0
const-wide/high16 v25, -0x4010000000000000L # -1.0
const/4 v15, 0x0
cmpg-double v16, v21, v25
if-gtz v16, :cond_ee
.line 122
iput v15, v0, Landroidx/appcompat/app/TwilightCalculator;->state:I
.line 123
iput-wide v13, v0, Landroidx/appcompat/app/TwilightCalculator;->sunset:J
.line 124
iput-wide v13, v0, Landroidx/appcompat/app/TwilightCalculator;->sunrise:J
.line 125
return-void
.line 128
:cond_ee
invoke-static/range {v21 .. v22}, Ljava/lang/Math;->acos(D)D
move-result-wide v13
const-wide v25, 0x401921fb54442d18L # 6.283185307179586
div-double v13, v13, v25
double-to-float v13, v13
.line 130
.local v13, "hourAngle":F
move v14, v3
move/from16 v16, v4
.end local v3 # "daysSince2000":F
.end local v4 # "meanAnomaly":F
.local v14, "daysSince2000":F
.local v16, "meanAnomaly":F
float-to-double v3, v13
invoke-static {v3, v4}, Ljava/lang/Double;->isNaN(D)Z
add-double/2addr v3, v1
const-wide v25, 0x4194997000000000L # 8.64E7
mul-double v3, v3, v25
invoke-static {v3, v4}, Ljava/lang/Math;->round(D)J
move-result-wide v3
const-wide v27, 0xdc6d62da00L
add-long v3, v3, v27
iput-wide v3, v0, Landroidx/appcompat/app/TwilightCalculator;->sunset:J
.line 131
float-to-double v3, v13
invoke-static {v3, v4}, Ljava/lang/Double;->isNaN(D)Z
sub-double v3, v1, v3
mul-double v3, v3, v25
invoke-static {v3, v4}, Ljava/lang/Math;->round(D)J
move-result-wide v3
add-long v3, v3, v27
iput-wide v3, v0, Landroidx/appcompat/app/TwilightCalculator;->sunrise:J
.line 133
cmp-long v25, v3, p1
if-gez v25, :cond_133
iget-wide v3, v0, Landroidx/appcompat/app/TwilightCalculator;->sunset:J
cmp-long v25, v3, p1
if-lez v25, :cond_133
.line 134
iput v15, v0, Landroidx/appcompat/app/TwilightCalculator;->state:I
goto :goto_136
.line 136
:cond_133
const/4 v3, 0x1
iput v3, v0, Landroidx/appcompat/app/TwilightCalculator;->state:I
.line 138
:goto_136
return-void
.end method