@twinmatrix/spatialverse-sdk-web 0.0.3 → 0.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/CustomThreeJsWrapper.js +2 -2
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/CustomThreeJsWrapper.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraSync.js +293 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraSync.js.map +1 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraUtils.js +35 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraUtils.js.map +1 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/constants.js +33 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/constants.js.map +1 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.js +307 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.js.map +1 -0
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/utils.js +4 -3
- package/lib/cjs/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/utils.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/3DMap/MainMap.js +202 -198
- package/lib/cjs/meta-atlas-sdk/3DMap/MainMap.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/fetch-published-json.js +3 -3
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/fetch-published-json.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/focustree.json +121 -0
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/meta-atlas-sdk-core.js +32 -29
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/meta-atlas-sdk-core.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/routing-core/index.js +10 -13
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/routing-core/index.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/routing-core/routing-helpers.js +55 -68
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/routing-core/routing-helpers.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/routing-core/utils.js +12 -12
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/routing-core/utils.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/MetaAtlasCore/whatTaxonomies.json +170 -0
- package/lib/cjs/meta-atlas-sdk/combined_style.json +2313 -0
- package/lib/cjs/meta-atlas-sdk/mapbox_draw_custom_modes/draw_marker.js +166 -0
- package/lib/cjs/meta-atlas-sdk/mapbox_draw_custom_modes/draw_marker.js.map +1 -0
- package/lib/cjs/meta-atlas-sdk/mapbox_draw_custom_modes/marker_select.js +229 -0
- package/lib/cjs/meta-atlas-sdk/mapbox_draw_custom_modes/marker_select.js.map +1 -0
- package/lib/cjs/meta-atlas-sdk/meta-atlas-sdk.js +73 -69
- package/lib/cjs/meta-atlas-sdk/meta-atlas-sdk.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/utils/helpers.js +1 -1
- package/lib/cjs/meta-atlas-sdk/utils/helpers.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/utils/local-storage.js +6 -1
- package/lib/cjs/meta-atlas-sdk/utils/local-storage.js.map +1 -1
- package/lib/cjs/meta-atlas-sdk/utils/routing-visualizer/index.js +103 -103
- package/lib/cjs/meta-atlas-sdk/utils/routing-visualizer/index.js.map +1 -1
- package/lib/cjs/react/MetaAtlasMap.js +4 -4
- package/lib/cjs/react/MetaAtlasMap.js.map +1 -1
- package/lib/cjs/react/hooks/useMapEvents/index.js +6 -3
- package/lib/cjs/react/hooks/useMapEvents/index.js.map +1 -1
- package/lib/cjs/react/hooks/useStampRally/index.js +7 -5
- package/lib/cjs/react/hooks/useStampRally/index.js.map +1 -1
- package/lib/cjs/react/hooks/useStampRally/utils.js +1 -1
- package/lib/cjs/react/hooks/useStampRally/utils.js.map +1 -1
- package/lib/cjs/react/stores/useMapDataStore.js +17 -21
- package/lib/cjs/react/stores/useMapDataStore.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/CustomThreeJsWrapper.js +2 -2
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/CustomThreeJsWrapper.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraSync.js +286 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraSync.js.map +1 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraUtils.js +27 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraUtils.js.map +1 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/constants.js +27 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/constants.js.map +1 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.js +305 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.js.map +1 -0
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/utils.js +4 -3
- package/lib/esm/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/utils.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/3DMap/MainMap.js +202 -198
- package/lib/esm/meta-atlas-sdk/3DMap/MainMap.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/fetch-published-json.js +3 -3
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/fetch-published-json.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/focustree.json +121 -0
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/meta-atlas-sdk-core.js +32 -29
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/meta-atlas-sdk-core.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/routing-core/index.js +10 -8
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/routing-core/index.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/routing-core/routing-helpers.js +55 -68
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/routing-core/routing-helpers.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/routing-core/utils.js +12 -12
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/routing-core/utils.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/MetaAtlasCore/whatTaxonomies.json +170 -0
- package/lib/esm/meta-atlas-sdk/combined_style.json +2313 -0
- package/lib/esm/meta-atlas-sdk/mapbox_draw_custom_modes/draw_marker.js +158 -0
- package/lib/esm/meta-atlas-sdk/mapbox_draw_custom_modes/draw_marker.js.map +1 -0
- package/lib/esm/meta-atlas-sdk/mapbox_draw_custom_modes/marker_select.js +221 -0
- package/lib/esm/meta-atlas-sdk/mapbox_draw_custom_modes/marker_select.js.map +1 -0
- package/lib/esm/meta-atlas-sdk/meta-atlas-sdk.js +73 -68
- package/lib/esm/meta-atlas-sdk/meta-atlas-sdk.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/utils/helpers.js +1 -1
- package/lib/esm/meta-atlas-sdk/utils/helpers.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/utils/local-storage.js +6 -1
- package/lib/esm/meta-atlas-sdk/utils/local-storage.js.map +1 -1
- package/lib/esm/meta-atlas-sdk/utils/routing-visualizer/index.js +103 -101
- package/lib/esm/meta-atlas-sdk/utils/routing-visualizer/index.js.map +1 -1
- package/lib/esm/react/MetaAtlasMap.js +4 -4
- package/lib/esm/react/MetaAtlasMap.js.map +1 -1
- package/lib/esm/react/hooks/useMapEvents/index.js +6 -3
- package/lib/esm/react/hooks/useMapEvents/index.js.map +1 -1
- package/lib/esm/react/hooks/useStampRally/index.js +7 -5
- package/lib/esm/react/hooks/useStampRally/index.js.map +1 -1
- package/lib/esm/react/hooks/useStampRally/utils.js +1 -1
- package/lib/esm/react/hooks/useStampRally/utils.js.map +1 -1
- package/lib/esm/react/stores/useMapDataStore.js +17 -21
- package/lib/esm/react/stores/useMapDataStore.js.map +1 -1
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraSync.d.ts +30 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraSync.d.ts.map +1 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraUtils.d.ts +5 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/CameraUtils.d.ts.map +1 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/constants.d.ts +21 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/constants.d.ts.map +1 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.d.ts +27 -0
- package/lib/types/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.d.ts.map +1 -0
- package/lib/types/meta-atlas-sdk/mapbox_draw_custom_modes/draw_marker.d.ts +18 -0
- package/lib/types/meta-atlas-sdk/mapbox_draw_custom_modes/draw_marker.d.ts.map +1 -0
- package/lib/types/meta-atlas-sdk/mapbox_draw_custom_modes/marker_select.d.ts +37 -0
- package/lib/types/meta-atlas-sdk/mapbox_draw_custom_modes/marker_select.d.ts.map +1 -0
- package/package.json +4 -4
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
/*
|
|
4
|
+
(c) 2011-2015, Vladimir Agafonkin
|
|
5
|
+
SunCalc is a JavaScript library for calculating sun/moon position and light phases.
|
|
6
|
+
https://github.com/mourner/suncalc
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
(function () {
|
|
10
|
+
'use strict';
|
|
11
|
+
|
|
12
|
+
// shortcuts for easier to read formulas
|
|
13
|
+
var PI = Math.PI,
|
|
14
|
+
sin = Math.sin,
|
|
15
|
+
cos = Math.cos,
|
|
16
|
+
tan = Math.tan,
|
|
17
|
+
asin = Math.asin,
|
|
18
|
+
atan = Math.atan2,
|
|
19
|
+
acos = Math.acos,
|
|
20
|
+
rad = PI / 180;
|
|
21
|
+
|
|
22
|
+
// sun calculations are based on http://aa.quae.nl/en/reken/zonpositie.html formulas
|
|
23
|
+
|
|
24
|
+
// date/time constants and conversions
|
|
25
|
+
|
|
26
|
+
var dayMs = 1000 * 60 * 60 * 24,
|
|
27
|
+
J1970 = 2440588,
|
|
28
|
+
J2000 = 2451545;
|
|
29
|
+
function toJulian(date) {
|
|
30
|
+
return date.valueOf() / dayMs - 0.5 + J1970;
|
|
31
|
+
}
|
|
32
|
+
function fromJulian(j) {
|
|
33
|
+
return new Date((j + 0.5 - J1970) * dayMs);
|
|
34
|
+
}
|
|
35
|
+
function toDays(date) {
|
|
36
|
+
return toJulian(date) - J2000;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
// general calculations for position
|
|
40
|
+
|
|
41
|
+
var e = rad * 23.4397; // obliquity of the Earth
|
|
42
|
+
|
|
43
|
+
function rightAscension(l, b) {
|
|
44
|
+
return atan(sin(l) * cos(e) - tan(b) * sin(e), cos(l));
|
|
45
|
+
}
|
|
46
|
+
function declination(l, b) {
|
|
47
|
+
return asin(sin(b) * cos(e) + cos(b) * sin(e) * sin(l));
|
|
48
|
+
}
|
|
49
|
+
function azimuth(H, phi, dec) {
|
|
50
|
+
return atan(sin(H), cos(H) * sin(phi) - tan(dec) * cos(phi));
|
|
51
|
+
}
|
|
52
|
+
function altitude(H, phi, dec) {
|
|
53
|
+
return asin(sin(phi) * sin(dec) + cos(phi) * cos(dec) * cos(H));
|
|
54
|
+
}
|
|
55
|
+
function siderealTime(d, lw) {
|
|
56
|
+
return rad * (280.16 + 360.9856235 * d) - lw;
|
|
57
|
+
}
|
|
58
|
+
function astroRefraction(h) {
|
|
59
|
+
if (h < 0)
|
|
60
|
+
// the following formula works for positive altitudes only.
|
|
61
|
+
h = 0; // if h = -0.08901179 a div/0 would occur.
|
|
62
|
+
|
|
63
|
+
// formula 16.4 of "Astronomical Algorithms" 2nd edition by Jean Meeus (Willmann-Bell, Richmond) 1998.
|
|
64
|
+
// 1.02 / tan(h + 10.26 / (h + 5.10)) h in degrees, result in arc minutes -> converted to rad:
|
|
65
|
+
return 0.0002967 / Math.tan(h + 0.00312536 / (h + 0.08901179));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// general sun calculations
|
|
69
|
+
|
|
70
|
+
function solarMeanAnomaly(d) {
|
|
71
|
+
return rad * (357.5291 + 0.98560028 * d);
|
|
72
|
+
}
|
|
73
|
+
function eclipticLongitude(M) {
|
|
74
|
+
var C = rad * (1.9148 * sin(M) + 0.02 * sin(2 * M) + 0.0003 * sin(3 * M)),
|
|
75
|
+
// equation of center
|
|
76
|
+
P = rad * 102.9372; // perihelion of the Earth
|
|
77
|
+
|
|
78
|
+
return M + C + P + PI;
|
|
79
|
+
}
|
|
80
|
+
function sunCoords(d) {
|
|
81
|
+
var M = solarMeanAnomaly(d),
|
|
82
|
+
L = eclipticLongitude(M);
|
|
83
|
+
return {
|
|
84
|
+
dec: declination(L, 0),
|
|
85
|
+
ra: rightAscension(L, 0)
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
var SunCalc = {};
|
|
89
|
+
|
|
90
|
+
// calculates sun position for a given date and latitude/longitude
|
|
91
|
+
|
|
92
|
+
SunCalc.getPosition = function (date, lat, lng) {
|
|
93
|
+
var lw = rad * -lng,
|
|
94
|
+
phi = rad * lat,
|
|
95
|
+
d = toDays(date),
|
|
96
|
+
c = sunCoords(d),
|
|
97
|
+
H = siderealTime(d, lw) - c.ra;
|
|
98
|
+
return {
|
|
99
|
+
azimuth: azimuth(H, phi, c.dec),
|
|
100
|
+
altitude: altitude(H, phi, c.dec)
|
|
101
|
+
};
|
|
102
|
+
};
|
|
103
|
+
SunCalc.toJulian = function (date) {
|
|
104
|
+
return toJulian(date);
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
// sun times configuration (angle, morning name, evening name)
|
|
108
|
+
|
|
109
|
+
var times = SunCalc.times = [[-0.833, 'sunrise', 'sunset'], [-0.3, 'sunriseEnd', 'sunsetStart'], [-6, 'dawn', 'dusk'], [-12, 'nauticalDawn', 'nauticalDusk'], [-18, 'nightEnd', 'night'], [6, 'goldenHourEnd', 'goldenHour']];
|
|
110
|
+
|
|
111
|
+
// adds a custom time to the times config
|
|
112
|
+
|
|
113
|
+
SunCalc.addTime = function (angle, riseName, setName) {
|
|
114
|
+
times.push([angle, riseName, setName]);
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
// calculations for sun times
|
|
118
|
+
|
|
119
|
+
var J0 = 0.0009;
|
|
120
|
+
function julianCycle(d, lw) {
|
|
121
|
+
return Math.round(d - J0 - lw / (2 * PI));
|
|
122
|
+
}
|
|
123
|
+
function approxTransit(Ht, lw, n) {
|
|
124
|
+
return J0 + (Ht + lw) / (2 * PI) + n;
|
|
125
|
+
}
|
|
126
|
+
function solarTransitJ(ds, M, L) {
|
|
127
|
+
return J2000 + ds + 0.0053 * sin(M) - 0.0069 * sin(2 * L);
|
|
128
|
+
}
|
|
129
|
+
function hourAngle(h, phi, d) {
|
|
130
|
+
return acos((sin(h) - sin(phi) * sin(d)) / (cos(phi) * cos(d)));
|
|
131
|
+
}
|
|
132
|
+
function observerAngle(height) {
|
|
133
|
+
return -2.076 * Math.sqrt(height) / 60;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
// returns set time for the given sun altitude
|
|
137
|
+
function getSetJ(h, lw, phi, dec, n, M, L) {
|
|
138
|
+
var w = hourAngle(h, phi, dec),
|
|
139
|
+
a = approxTransit(w, lw, n);
|
|
140
|
+
return solarTransitJ(a, M, L);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// calculates sun times for a given date, latitude/longitude, and, optionally,
|
|
144
|
+
// the observer height (in meters) relative to the horizon
|
|
145
|
+
|
|
146
|
+
SunCalc.getTimes = function (date, lat, lng, height) {
|
|
147
|
+
height = height || 0;
|
|
148
|
+
var lw = rad * -lng,
|
|
149
|
+
phi = rad * lat,
|
|
150
|
+
dh = observerAngle(height),
|
|
151
|
+
d = toDays(date),
|
|
152
|
+
n = julianCycle(d, lw),
|
|
153
|
+
ds = approxTransit(0, lw, n),
|
|
154
|
+
M = solarMeanAnomaly(ds),
|
|
155
|
+
L = eclipticLongitude(M),
|
|
156
|
+
dec = declination(L, 0),
|
|
157
|
+
Jnoon = solarTransitJ(ds, M, L),
|
|
158
|
+
i,
|
|
159
|
+
len,
|
|
160
|
+
time,
|
|
161
|
+
h0,
|
|
162
|
+
Jset,
|
|
163
|
+
Jrise;
|
|
164
|
+
var result = {
|
|
165
|
+
solarNoon: fromJulian(Jnoon),
|
|
166
|
+
nadir: fromJulian(Jnoon - 0.5)
|
|
167
|
+
};
|
|
168
|
+
for (i = 0, len = times.length; i < len; i += 1) {
|
|
169
|
+
time = times[i];
|
|
170
|
+
h0 = (time[0] + dh) * rad;
|
|
171
|
+
Jset = getSetJ(h0, lw, phi, dec, n, M, L);
|
|
172
|
+
Jrise = Jnoon - (Jset - Jnoon);
|
|
173
|
+
result[time[1]] = fromJulian(Jrise);
|
|
174
|
+
result[time[2]] = fromJulian(Jset);
|
|
175
|
+
}
|
|
176
|
+
return result;
|
|
177
|
+
};
|
|
178
|
+
|
|
179
|
+
// moon calculations, based on http://aa.quae.nl/en/reken/hemelpositie.html formulas
|
|
180
|
+
|
|
181
|
+
function moonCoords(d) {
|
|
182
|
+
// geocentric ecliptic coordinates of the moon
|
|
183
|
+
|
|
184
|
+
var L = rad * (218.316 + 13.176396 * d),
|
|
185
|
+
// ecliptic longitude
|
|
186
|
+
M = rad * (134.963 + 13.064993 * d),
|
|
187
|
+
// mean anomaly
|
|
188
|
+
F = rad * (93.272 + 13.229350 * d),
|
|
189
|
+
// mean distance
|
|
190
|
+
|
|
191
|
+
l = L + rad * 6.289 * sin(M),
|
|
192
|
+
// longitude
|
|
193
|
+
b = rad * 5.128 * sin(F),
|
|
194
|
+
// latitude
|
|
195
|
+
dt = 385001 - 20905 * cos(M); // distance to the moon in km
|
|
196
|
+
|
|
197
|
+
return {
|
|
198
|
+
ra: rightAscension(l, b),
|
|
199
|
+
dec: declination(l, b),
|
|
200
|
+
dist: dt
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
SunCalc.getMoonPosition = function (date, lat, lng) {
|
|
204
|
+
var lw = rad * -lng,
|
|
205
|
+
phi = rad * lat,
|
|
206
|
+
d = toDays(date),
|
|
207
|
+
c = moonCoords(d),
|
|
208
|
+
H = siderealTime(d, lw) - c.ra,
|
|
209
|
+
h = altitude(H, phi, c.dec),
|
|
210
|
+
// formula 14.1 of "Astronomical Algorithms" 2nd edition by Jean Meeus (Willmann-Bell, Richmond) 1998.
|
|
211
|
+
pa = atan(sin(H), tan(phi) * cos(c.dec) - sin(c.dec) * cos(H));
|
|
212
|
+
h = h + astroRefraction(h); // altitude correction for refraction
|
|
213
|
+
|
|
214
|
+
return {
|
|
215
|
+
azimuth: azimuth(H, phi, c.dec),
|
|
216
|
+
altitude: h,
|
|
217
|
+
distance: c.dist,
|
|
218
|
+
parallacticAngle: pa
|
|
219
|
+
};
|
|
220
|
+
};
|
|
221
|
+
|
|
222
|
+
// calculations for illumination parameters of the moon,
|
|
223
|
+
// based on http://idlastro.gsfc.nasa.gov/ftp/pro/astro/mphase.pro formulas and
|
|
224
|
+
// Chapter 48 of "Astronomical Algorithms" 2nd edition by Jean Meeus (Willmann-Bell, Richmond) 1998.
|
|
225
|
+
|
|
226
|
+
SunCalc.getMoonIllumination = function (date) {
|
|
227
|
+
var d = toDays(date || new Date()),
|
|
228
|
+
s = sunCoords(d),
|
|
229
|
+
m = moonCoords(d),
|
|
230
|
+
sdist = 149598000,
|
|
231
|
+
// distance from Earth to Sun in km
|
|
232
|
+
|
|
233
|
+
phi = acos(sin(s.dec) * sin(m.dec) + cos(s.dec) * cos(m.dec) * cos(s.ra - m.ra)),
|
|
234
|
+
inc = atan(sdist * sin(phi), m.dist - sdist * cos(phi)),
|
|
235
|
+
angle = atan(cos(s.dec) * sin(s.ra - m.ra), sin(s.dec) * cos(m.dec) - cos(s.dec) * sin(m.dec) * cos(s.ra - m.ra));
|
|
236
|
+
return {
|
|
237
|
+
fraction: (1 + cos(inc)) / 2,
|
|
238
|
+
phase: 0.5 + 0.5 * inc * (angle < 0 ? -1 : 1) / Math.PI,
|
|
239
|
+
angle: angle
|
|
240
|
+
};
|
|
241
|
+
};
|
|
242
|
+
function hoursLater(date, h) {
|
|
243
|
+
return new Date(date.valueOf() + h * dayMs / 24);
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
// calculations for moon rise/set times are based on http://www.stargazing.net/kepler/moonrise.html article
|
|
247
|
+
|
|
248
|
+
SunCalc.getMoonTimes = function (date, lat, lng, inUTC) {
|
|
249
|
+
var t = new Date(date);
|
|
250
|
+
if (inUTC) t.setUTCHours(0, 0, 0, 0);else t.setHours(0, 0, 0, 0);
|
|
251
|
+
var hc = 0.133 * rad,
|
|
252
|
+
h0 = SunCalc.getMoonPosition(t, lat, lng).altitude - hc,
|
|
253
|
+
h1,
|
|
254
|
+
h2,
|
|
255
|
+
rise,
|
|
256
|
+
set,
|
|
257
|
+
a,
|
|
258
|
+
b,
|
|
259
|
+
xe,
|
|
260
|
+
ye,
|
|
261
|
+
d,
|
|
262
|
+
roots,
|
|
263
|
+
x1,
|
|
264
|
+
x2,
|
|
265
|
+
dx;
|
|
266
|
+
|
|
267
|
+
// go in 2-hour chunks, each time seeing if a 3-point quadratic curve crosses zero (which means rise or set)
|
|
268
|
+
for (var i = 1; i <= 24; i += 2) {
|
|
269
|
+
h1 = SunCalc.getMoonPosition(hoursLater(t, i), lat, lng).altitude - hc;
|
|
270
|
+
h2 = SunCalc.getMoonPosition(hoursLater(t, i + 1), lat, lng).altitude - hc;
|
|
271
|
+
a = (h0 + h2) / 2 - h1;
|
|
272
|
+
b = (h2 - h0) / 2;
|
|
273
|
+
xe = -b / (2 * a);
|
|
274
|
+
ye = (a * xe + b) * xe + h1;
|
|
275
|
+
d = b * b - 4 * a * h1;
|
|
276
|
+
roots = 0;
|
|
277
|
+
if (d >= 0) {
|
|
278
|
+
dx = Math.sqrt(d) / (Math.abs(a) * 2);
|
|
279
|
+
x1 = xe - dx;
|
|
280
|
+
x2 = xe + dx;
|
|
281
|
+
if (Math.abs(x1) <= 1) roots++;
|
|
282
|
+
if (Math.abs(x2) <= 1) roots++;
|
|
283
|
+
if (x1 < -1) x1 = x2;
|
|
284
|
+
}
|
|
285
|
+
if (roots === 1) {
|
|
286
|
+
if (h0 < 0) rise = i + x1;else set = i + x1;
|
|
287
|
+
} else if (roots === 2) {
|
|
288
|
+
rise = i + (ye < 0 ? x2 : x1);
|
|
289
|
+
set = i + (ye < 0 ? x1 : x2);
|
|
290
|
+
}
|
|
291
|
+
if (rise && set) break;
|
|
292
|
+
h0 = h2;
|
|
293
|
+
}
|
|
294
|
+
var result = {};
|
|
295
|
+
if (rise) result.rise = hoursLater(t, rise);
|
|
296
|
+
if (set) result.set = hoursLater(t, set);
|
|
297
|
+
if (!rise && !set) result[ye > 0 ? 'alwaysUp' : 'alwaysDown'] = true;
|
|
298
|
+
return result;
|
|
299
|
+
};
|
|
300
|
+
|
|
301
|
+
//// export as Node module / AMD module / browser variable
|
|
302
|
+
//if (typeof exports === 'object' && typeof module !== 'undefined') module.exports = SunCalc;
|
|
303
|
+
//else if (typeof define === 'function' && define.amd) define(SunCalc);
|
|
304
|
+
//else window.SunCalc = SunCalc;
|
|
305
|
+
module.exports = exports = SunCalc;
|
|
306
|
+
})();
|
|
307
|
+
//# sourceMappingURL=suncalc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suncalc.js","names":["PI","Math","sin","cos","tan","asin","atan","atan2","acos","rad","dayMs","J1970","J2000","toJulian","date","valueOf","fromJulian","j","Date","toDays","e","rightAscension","l","b","declination","azimuth","H","phi","dec","altitude","siderealTime","d","lw","astroRefraction","h","solarMeanAnomaly","eclipticLongitude","M","C","P","sunCoords","L","ra","SunCalc","getPosition","lat","lng","c","times","addTime","angle","riseName","setName","push","J0","julianCycle","round","approxTransit","Ht","n","solarTransitJ","ds","hourAngle","observerAngle","height","sqrt","getSetJ","w","a","getTimes","dh","Jnoon","i","len","time","h0","Jset","Jrise","result","solarNoon","nadir","length","moonCoords","F","dt","dist","getMoonPosition","pa","distance","parallacticAngle","getMoonIllumination","s","m","sdist","inc","fraction","phase","hoursLater","getMoonTimes","inUTC","t","setUTCHours","setHours","hc","h1","h2","rise","set","xe","ye","roots","x1","x2","dx","abs","module","exports"],"sources":["../../../../../../src/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/suncalc.js"],"sourcesContent":["/*\n (c) 2011-2015, Vladimir Agafonkin\n SunCalc is a JavaScript library for calculating sun/moon position and light phases.\n https://github.com/mourner/suncalc\n*/\n\n(function () {\n 'use strict';\n\n // shortcuts for easier to read formulas\n\n var PI = Math.PI,\n sin = Math.sin,\n cos = Math.cos,\n tan = Math.tan,\n asin = Math.asin,\n atan = Math.atan2,\n acos = Math.acos,\n rad = PI / 180;\n\n // sun calculations are based on http://aa.quae.nl/en/reken/zonpositie.html formulas\n\n\n // date/time constants and conversions\n\n var dayMs = 1000 * 60 * 60 * 24,\n J1970 = 2440588,\n J2000 = 2451545;\n\n function toJulian(date) { return date.valueOf() / dayMs - 0.5 + J1970; }\n function fromJulian(j) { return new Date((j + 0.5 - J1970) * dayMs); }\n function toDays(date) { return toJulian(date) - J2000; }\n\n // general calculations for position\n\n var e = rad * 23.4397; // obliquity of the Earth\n\n function rightAscension(l, b) { return atan(sin(l) * cos(e) - tan(b) * sin(e), cos(l)); }\n function declination(l, b) { return asin(sin(b) * cos(e) + cos(b) * sin(e) * sin(l)); }\n\n function azimuth(H, phi, dec) { return atan(sin(H), cos(H) * sin(phi) - tan(dec) * cos(phi)); }\n function altitude(H, phi, dec) { return asin(sin(phi) * sin(dec) + cos(phi) * cos(dec) * cos(H)); }\n\n function siderealTime(d, lw) { return rad * (280.16 + 360.9856235 * d) - lw; }\n\n function astroRefraction(h) {\n if (h < 0) // the following formula works for positive altitudes only.\n h = 0; // if h = -0.08901179 a div/0 would occur.\n\n // formula 16.4 of \"Astronomical Algorithms\" 2nd edition by Jean Meeus (Willmann-Bell, Richmond) 1998.\n // 1.02 / tan(h + 10.26 / (h + 5.10)) h in degrees, result in arc minutes -> converted to rad:\n return 0.0002967 / Math.tan(h + 0.00312536 / (h + 0.08901179));\n }\n\n // general sun calculations\n\n function solarMeanAnomaly(d) { return rad * (357.5291 + 0.98560028 * d); }\n\n function eclipticLongitude(M) {\n\n var C = rad * (1.9148 * sin(M) + 0.02 * sin(2 * M) + 0.0003 * sin(3 * M)), // equation of center\n P = rad * 102.9372; // perihelion of the Earth\n\n return M + C + P + PI;\n }\n\n function sunCoords(d) {\n\n var M = solarMeanAnomaly(d),\n L = eclipticLongitude(M);\n\n return {\n dec: declination(L, 0),\n ra: rightAscension(L, 0)\n };\n }\n\n\n var SunCalc = {};\n\n\n // calculates sun position for a given date and latitude/longitude\n\n SunCalc.getPosition = function (date, lat, lng) {\n\n var lw = rad * -lng,\n phi = rad * lat,\n d = toDays(date),\n\n c = sunCoords(d),\n H = siderealTime(d, lw) - c.ra;\n\n return {\n azimuth: azimuth(H, phi, c.dec),\n altitude: altitude(H, phi, c.dec)\n };\n };\n\n SunCalc.toJulian = function (date) {\n return toJulian(date);\n };\n\n // sun times configuration (angle, morning name, evening name)\n\n var times = SunCalc.times = [\n [-0.833, 'sunrise', 'sunset'],\n [-0.3, 'sunriseEnd', 'sunsetStart'],\n [-6, 'dawn', 'dusk'],\n [-12, 'nauticalDawn', 'nauticalDusk'],\n [-18, 'nightEnd', 'night'],\n [6, 'goldenHourEnd', 'goldenHour']\n ];\n\n // adds a custom time to the times config\n\n SunCalc.addTime = function (angle, riseName, setName) {\n times.push([angle, riseName, setName]);\n };\n\n\n // calculations for sun times\n\n var J0 = 0.0009;\n\n function julianCycle(d, lw) { return Math.round(d - J0 - lw / (2 * PI)); }\n\n function approxTransit(Ht, lw, n) { return J0 + (Ht + lw) / (2 * PI) + n; }\n function solarTransitJ(ds, M, L) { return J2000 + ds + 0.0053 * sin(M) - 0.0069 * sin(2 * L); }\n\n function hourAngle(h, phi, d) { return acos((sin(h) - sin(phi) * sin(d)) / (cos(phi) * cos(d))); }\n function observerAngle(height) { return -2.076 * Math.sqrt(height) / 60; }\n\n // returns set time for the given sun altitude\n function getSetJ(h, lw, phi, dec, n, M, L) {\n\n var w = hourAngle(h, phi, dec),\n a = approxTransit(w, lw, n);\n return solarTransitJ(a, M, L);\n }\n\n\n // calculates sun times for a given date, latitude/longitude, and, optionally,\n // the observer height (in meters) relative to the horizon\n\n SunCalc.getTimes = function (date, lat, lng, height) {\n\n height = height || 0;\n\n var lw = rad * -lng,\n phi = rad * lat,\n\n dh = observerAngle(height),\n\n d = toDays(date),\n n = julianCycle(d, lw),\n ds = approxTransit(0, lw, n),\n\n M = solarMeanAnomaly(ds),\n L = eclipticLongitude(M),\n dec = declination(L, 0),\n\n Jnoon = solarTransitJ(ds, M, L),\n\n i, len, time, h0, Jset, Jrise;\n\n\n var result = {\n solarNoon: fromJulian(Jnoon),\n nadir: fromJulian(Jnoon - 0.5)\n };\n\n for (i = 0, len = times.length; i < len; i += 1) {\n time = times[i];\n h0 = (time[0] + dh) * rad;\n\n Jset = getSetJ(h0, lw, phi, dec, n, M, L);\n Jrise = Jnoon - (Jset - Jnoon);\n\n result[time[1]] = fromJulian(Jrise);\n result[time[2]] = fromJulian(Jset);\n }\n\n return result;\n };\n\n\n // moon calculations, based on http://aa.quae.nl/en/reken/hemelpositie.html formulas\n\n function moonCoords(d) { // geocentric ecliptic coordinates of the moon\n\n var L = rad * (218.316 + 13.176396 * d), // ecliptic longitude\n M = rad * (134.963 + 13.064993 * d), // mean anomaly\n F = rad * (93.272 + 13.229350 * d), // mean distance\n\n l = L + rad * 6.289 * sin(M), // longitude\n b = rad * 5.128 * sin(F), // latitude\n dt = 385001 - 20905 * cos(M); // distance to the moon in km\n\n return {\n ra: rightAscension(l, b),\n dec: declination(l, b),\n dist: dt\n };\n }\n\n SunCalc.getMoonPosition = function (date, lat, lng) {\n\n var lw = rad * -lng,\n phi = rad * lat,\n d = toDays(date),\n\n c = moonCoords(d),\n H = siderealTime(d, lw) - c.ra,\n h = altitude(H, phi, c.dec),\n // formula 14.1 of \"Astronomical Algorithms\" 2nd edition by Jean Meeus (Willmann-Bell, Richmond) 1998.\n pa = atan(sin(H), tan(phi) * cos(c.dec) - sin(c.dec) * cos(H));\n\n h = h + astroRefraction(h); // altitude correction for refraction\n\n return {\n azimuth: azimuth(H, phi, c.dec),\n altitude: h,\n distance: c.dist,\n parallacticAngle: pa\n };\n };\n\n\n // calculations for illumination parameters of the moon,\n // based on http://idlastro.gsfc.nasa.gov/ftp/pro/astro/mphase.pro formulas and\n // Chapter 48 of \"Astronomical Algorithms\" 2nd edition by Jean Meeus (Willmann-Bell, Richmond) 1998.\n\n SunCalc.getMoonIllumination = function (date) {\n\n var d = toDays(date || new Date()),\n s = sunCoords(d),\n m = moonCoords(d),\n\n sdist = 149598000, // distance from Earth to Sun in km\n\n phi = acos(sin(s.dec) * sin(m.dec) + cos(s.dec) * cos(m.dec) * cos(s.ra - m.ra)),\n inc = atan(sdist * sin(phi), m.dist - sdist * cos(phi)),\n angle = atan(cos(s.dec) * sin(s.ra - m.ra), sin(s.dec) * cos(m.dec) -\n cos(s.dec) * sin(m.dec) * cos(s.ra - m.ra));\n\n return {\n fraction: (1 + cos(inc)) / 2,\n phase: 0.5 + 0.5 * inc * (angle < 0 ? -1 : 1) / Math.PI,\n angle: angle\n };\n };\n\n\n function hoursLater(date, h) {\n return new Date(date.valueOf() + h * dayMs / 24);\n }\n\n // calculations for moon rise/set times are based on http://www.stargazing.net/kepler/moonrise.html article\n\n SunCalc.getMoonTimes = function (date, lat, lng, inUTC) {\n var t = new Date(date);\n if (inUTC) t.setUTCHours(0, 0, 0, 0);\n else t.setHours(0, 0, 0, 0);\n\n var hc = 0.133 * rad,\n h0 = SunCalc.getMoonPosition(t, lat, lng).altitude - hc,\n h1, h2, rise, set, a, b, xe, ye, d, roots, x1, x2, dx;\n\n // go in 2-hour chunks, each time seeing if a 3-point quadratic curve crosses zero (which means rise or set)\n for (var i = 1; i <= 24; i += 2) {\n h1 = SunCalc.getMoonPosition(hoursLater(t, i), lat, lng).altitude - hc;\n h2 = SunCalc.getMoonPosition(hoursLater(t, i + 1), lat, lng).altitude - hc;\n\n a = (h0 + h2) / 2 - h1;\n b = (h2 - h0) / 2;\n xe = -b / (2 * a);\n ye = (a * xe + b) * xe + h1;\n d = b * b - 4 * a * h1;\n roots = 0;\n\n if (d >= 0) {\n dx = Math.sqrt(d) / (Math.abs(a) * 2);\n x1 = xe - dx;\n x2 = xe + dx;\n if (Math.abs(x1) <= 1) roots++;\n if (Math.abs(x2) <= 1) roots++;\n if (x1 < -1) x1 = x2;\n }\n\n if (roots === 1) {\n if (h0 < 0) rise = i + x1;\n else set = i + x1;\n\n } else if (roots === 2) {\n rise = i + (ye < 0 ? x2 : x1);\n set = i + (ye < 0 ? x1 : x2);\n }\n\n if (rise && set) break;\n\n h0 = h2;\n }\n\n var result = {};\n\n if (rise) result.rise = hoursLater(t, rise);\n if (set) result.set = hoursLater(t, set);\n\n if (!rise && !set) result[ye > 0 ? 'alwaysUp' : 'alwaysDown'] = true;\n\n return result;\n };\n\n\n //// export as Node module / AMD module / browser variable\n //if (typeof exports === 'object' && typeof module !== 'undefined') module.exports = SunCalc;\n //else if (typeof define === 'function' && define.amd) define(SunCalc);\n //else window.SunCalc = SunCalc;\n module.exports = exports = SunCalc\n}());\n\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -59,6 +59,7 @@ function addModelsToMap(wrapper, map, models, modelMap, onModelsLoaded) {
|
|
|
59
59
|
return new Promise((modelResolve, modelReject) => {
|
|
60
60
|
const loader = new _GLTFLoader.GLTFLoader();
|
|
61
61
|
loader.load(modelUrl, gltf => {
|
|
62
|
+
var _modelMap$get$visible, _modelMap$get;
|
|
62
63
|
const model = gltf.scene;
|
|
63
64
|
model.traverse(child => {
|
|
64
65
|
if (child instanceof THREE.Mesh) {
|
|
@@ -78,12 +79,12 @@ function addModelsToMap(wrapper, map, models, modelMap, onModelsLoaded) {
|
|
|
78
79
|
model.up.set(0, 0, 1);
|
|
79
80
|
model.rotation.set(rotation[0], rotation[1], rotation[2]);
|
|
80
81
|
model.scale.set(scale[0], scale[1], scale[2]);
|
|
81
|
-
model.visible = modelMap.get(id)
|
|
82
|
+
model.visible = (_modelMap$get$visible = (_modelMap$get = modelMap.get(id)) === null || _modelMap$get === void 0 ? void 0 : _modelMap$get.visible) !== null && _modelMap$get$visible !== void 0 ? _modelMap$get$visible : true;
|
|
82
83
|
wrapper.add(model);
|
|
83
84
|
modelMap.set(id, model);
|
|
84
85
|
modelResolve(modelMap);
|
|
85
86
|
}, undefined, error => {
|
|
86
|
-
console.error(
|
|
87
|
+
console.error("Error loading model ".concat(id, ":"), error);
|
|
87
88
|
modelReject(error);
|
|
88
89
|
});
|
|
89
90
|
});
|
|
@@ -125,7 +126,7 @@ function toggleModelVisibility(modelMap, modelId, isVisible) {
|
|
|
125
126
|
}
|
|
126
127
|
});
|
|
127
128
|
} else if (child.isMesh) {
|
|
128
|
-
console.error(
|
|
129
|
+
console.error("GSAP Animation already running for child id ".concat(id, "!"));
|
|
129
130
|
}
|
|
130
131
|
}
|
|
131
132
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","names":["_three","_interopRequireWildcard","require","THREE","_constants","_interopRequireDefault","_gsap","_GLTFLoader","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","projectToWorld","coords","projected","constants","MERCATOR_A","DEG2RAD","PROJECTION_WORLD_SIZE","Math","log","tan","PI","push","pixelsPerMeter","projectedUnitsPerMeter","result","Vector3","latitude","abs","WORLD_SIZE","cos","EARTH_CIRCUMFERENCE","unprojectFromWorld","worldUnits","unprojected","x","atan","exp","y","height","z","toDecimal","d","Number","toFixed","addModelsToMap","wrapper","map","models","modelMap","onModelsLoaded","Promise","resolve","reject","modelLoadPromises","_ref","id","modelUrl","rotation","scale","instanced","modelResolve","modelReject","loader","GLTFLoader","load","gltf","model","scene","traverse","child","Mesh","Array","isArray","material","forEach","mat","side","DoubleSide","needsUpdate","worldPosition","position","up","visible","add","undefined","error","console","addLayer","type","renderingMode","onAdd","all","then","res","catch","render","toggleModelVisibility","modelId","isVisible","isAnimating","isMesh","transparent","gsap","to","opacity","duration","ease","onComplete","bearingToRotation","bearing","threeRotation","rotationToBearing","quaternion","euler","Euler","setFromQuaternion","objectDirectionToBearing","object","forward","getWorldDirection","atan2"],"sources":["../../../../../../src/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/utils.ts"],"sourcesContent":["import * as THREE from 'three';\nimport {Quaternion, Euler, Vector3, InstancedMesh, Object3D} from 'three';\nimport constants from './constants';\nimport { RGBELoader } from 'three/examples/jsm/loaders/RGBELoader.js';\nimport { LngLatLike } from 'maplibre-gl';\nimport { Position } from 'geojson';\nimport gsap from 'gsap';\nimport { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader';\nimport { AmbientLight, DirectionalLight } from 'three';\nimport CustomThreeJSWrapper from '../CustomThreeJsWrapper.js';\n\nexport function projectToWorld(coords: Position) {\n var projected = [\n -constants.MERCATOR_A *\n constants.DEG2RAD *\n coords[0] *\n constants.PROJECTION_WORLD_SIZE,\n -constants.MERCATOR_A *\n Math.log(Math.tan(Math.PI * 0.25 + 0.5 * constants.DEG2RAD * coords[1])) *\n constants.PROJECTION_WORLD_SIZE,\n ];\n\n if (!coords[2]) projected.push(0);\n else {\n var pixelsPerMeter = projectedUnitsPerMeter(coords[1]);\n projected.push(coords[2] * pixelsPerMeter);\n }\n\n var result = new Vector3(projected[0], projected[1], projected[2]);\n\n return result;\n}\n\nfunction projectedUnitsPerMeter(latitude: number) {\n return Math.abs(\n constants.WORLD_SIZE /\n Math.cos(constants.DEG2RAD * latitude) /\n constants.EARTH_CIRCUMFERENCE\n );\n}\n\nexport function unprojectFromWorld(worldUnits: Vector3) {\n var unprojected = [\n -worldUnits.x /\n (constants.MERCATOR_A *\n constants.DEG2RAD *\n constants.PROJECTION_WORLD_SIZE),\n (2 *\n (Math.atan(\n Math.exp(\n worldUnits.y /\n (constants.PROJECTION_WORLD_SIZE * -constants.MERCATOR_A)\n )\n ) -\n Math.PI / 4)) /\n constants.DEG2RAD,\n ];\n\n var pixelsPerMeter = projectedUnitsPerMeter(unprojected[1]);\n\n // z dimension\n var height = worldUnits.z || 0;\n unprojected.push(height / pixelsPerMeter);\n\n return unprojected as LngLatLike;\n}\n\nexport function toDecimal (n, d) {\n return Number(n.toFixed(d));\n}\n\n// RF: TO BE REMOVED. ModelLoader component can be used to load 3D models.\nexport function addModelsToMap(wrapper, map, models, modelMap, onModelsLoaded) {\n return new Promise((resolve, reject) => {\n try {\n const modelLoadPromises = models.map(({ id, modelUrl, coords, rotation, scale, instanced }) => {\n return new Promise((modelResolve, modelReject) => {\n const loader = new GLTFLoader();\n loader.load(\n modelUrl,\n (gltf) => {\n const model = gltf.scene;\n model.traverse((child) => {\n if (child instanceof THREE.Mesh) {\n if (Array.isArray(child.material)) {\n child.material.forEach((mat) => {\n mat.side = THREE.DoubleSide;\n mat.needsUpdate = true;\n });\n } else {\n child.material.side = THREE.DoubleSide;\n child.material.needsUpdate = true;\n }\n }\n });\n \n const worldPosition = projectToWorld(coords);\n model.position.set(worldPosition.x, worldPosition.y, 0);\n model.up.set(0, 0, 1);\n model.rotation.set(rotation[0], rotation[1], rotation[2]);\n model.scale.set(scale[0], scale[1], scale[2]);\n model.visible = modelMap.get(id)?.visible ?? true;\n wrapper.add(model);\n modelMap.set(id, model);\n modelResolve(modelMap);\n },\n undefined,\n (error) => {\n console.error(`Error loading model ${id}:`, error);\n modelReject(error);\n }\n );\n });\n });\n\n map.addLayer({\n id: '3d-model-layer2',\n type: 'custom',\n renderingMode: '3d',\n onAdd: () => Promise.all(modelLoadPromises).then((res)=>{\n resolve(res);\n onModelsLoaded(true);\n }).catch(reject),\n render: () => {},\n });\n } catch (error) {\n reject(error);\n }\n });\n}\n\nexport function toggleModelVisibility(modelMap, modelId, isVisible) {\n const model = modelMap.get(modelId);\n if (!model) return;\n console.log('toggleModelVisibility_model', model);\n const isAnimating = {}; // Object to track animations\n model.traverse((child) => {\n if (child.isMesh) {\n const id = child.id; // Use unique child.id as the key\n child.material.transparent = true;\n if (!isAnimating[id]) {\n isAnimating[id] = true; // Set animation flag\n gsap.to(child.material, {\n opacity: isVisible ? 1 : 0,\n duration: 0.5, // Smooth fade animation\n ease: 'power2.inOut',\n onComplete: () => {\n isAnimating[id] = false; // Reset animation flag\n model.visible = isVisible;\n },\n });\n } else if (child.isMesh) {\n console.error(`GSAP Animation already running for child id ${id}!`);\n }\n }\n });\n if (isVisible) {\n model.visible = true;\n }\n}\n\nexport function bearingToRotation(bearing: number) {\n // Mapbox bearing is clockwise from north, Three.js rotation is counterclockwise from east\n const threeRotation = -((bearing - 90) * Math.PI / 180);\n return threeRotation;\n}\n\nexport function rotationToBearing(quaternion: Quaternion) {\n const euler = new Euler().setFromQuaternion(quaternion);\n // Convert from radians to degrees and adjust coordinate systems\n const bearing = (360 - (euler.y * 180 / Math.PI - 90)) % 360;\n return bearing;\n}\n\nexport function objectDirectionToBearing(object) {\n const forward = new Vector3();\n object.getWorldDirection(forward);\n\n // Project onto the map's X-Z plane (ignore Y)\n const bearing = Math.atan2(forward.x, forward.z) * (180 / Math.PI);\n \n return bearing;\n}"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"utils.js","names":["_three","_interopRequireWildcard","require","THREE","_constants","_interopRequireDefault","_gsap","_GLTFLoader","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","projectToWorld","coords","projected","constants","MERCATOR_A","DEG2RAD","PROJECTION_WORLD_SIZE","Math","log","tan","PI","push","pixelsPerMeter","projectedUnitsPerMeter","result","Vector3","latitude","abs","WORLD_SIZE","cos","EARTH_CIRCUMFERENCE","unprojectFromWorld","worldUnits","unprojected","x","atan","exp","y","height","z","toDecimal","d","Number","toFixed","addModelsToMap","wrapper","map","models","modelMap","onModelsLoaded","Promise","resolve","reject","modelLoadPromises","_ref","id","modelUrl","rotation","scale","instanced","modelResolve","modelReject","loader","GLTFLoader","load","gltf","_modelMap$get$visible","_modelMap$get","model","scene","traverse","child","Mesh","Array","isArray","material","forEach","mat","side","DoubleSide","needsUpdate","worldPosition","position","up","visible","add","undefined","error","console","concat","addLayer","type","renderingMode","onAdd","all","then","res","catch","render","toggleModelVisibility","modelId","isVisible","isAnimating","isMesh","transparent","gsap","to","opacity","duration","ease","onComplete","bearingToRotation","bearing","threeRotation","rotationToBearing","quaternion","euler","Euler","setFromQuaternion","objectDirectionToBearing","object","forward","getWorldDirection","atan2"],"sources":["../../../../../../src/meta-atlas-sdk/3DMap/CustomThreeJsWrapper/utility/utils.ts"],"sourcesContent":["import * as THREE from 'three';\nimport {Quaternion, Euler, Vector3, InstancedMesh, Object3D} from 'three';\nimport constants from './constants';\nimport { RGBELoader } from 'three/examples/jsm/loaders/RGBELoader.js';\nimport { LngLatLike } from 'maplibre-gl';\nimport { Position } from 'geojson';\nimport gsap from 'gsap';\nimport { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader';\nimport { AmbientLight, DirectionalLight } from 'three';\nimport CustomThreeJSWrapper from '../CustomThreeJsWrapper.js';\n\nexport function projectToWorld(coords: Position) {\n var projected = [\n -constants.MERCATOR_A *\n constants.DEG2RAD *\n coords[0] *\n constants.PROJECTION_WORLD_SIZE,\n -constants.MERCATOR_A *\n Math.log(Math.tan(Math.PI * 0.25 + 0.5 * constants.DEG2RAD * coords[1])) *\n constants.PROJECTION_WORLD_SIZE,\n ];\n\n if (!coords[2]) projected.push(0);\n else {\n var pixelsPerMeter = projectedUnitsPerMeter(coords[1]);\n projected.push(coords[2] * pixelsPerMeter);\n }\n\n var result = new Vector3(projected[0], projected[1], projected[2]);\n\n return result;\n}\n\nfunction projectedUnitsPerMeter(latitude: number) {\n return Math.abs(\n constants.WORLD_SIZE /\n Math.cos(constants.DEG2RAD * latitude) /\n constants.EARTH_CIRCUMFERENCE\n );\n}\n\nexport function unprojectFromWorld(worldUnits: Vector3) {\n var unprojected = [\n -worldUnits.x /\n (constants.MERCATOR_A *\n constants.DEG2RAD *\n constants.PROJECTION_WORLD_SIZE),\n (2 *\n (Math.atan(\n Math.exp(\n worldUnits.y /\n (constants.PROJECTION_WORLD_SIZE * -constants.MERCATOR_A)\n )\n ) -\n Math.PI / 4)) /\n constants.DEG2RAD,\n ];\n\n var pixelsPerMeter = projectedUnitsPerMeter(unprojected[1]);\n\n // z dimension\n var height = worldUnits.z || 0;\n unprojected.push(height / pixelsPerMeter);\n\n return unprojected as LngLatLike;\n}\n\nexport function toDecimal (n, d) {\n return Number(n.toFixed(d));\n}\n\n// RF: TO BE REMOVED. ModelLoader component can be used to load 3D models.\nexport function addModelsToMap(wrapper, map, models, modelMap, onModelsLoaded) {\n return new Promise((resolve, reject) => {\n try {\n const modelLoadPromises = models.map(({ id, modelUrl, coords, rotation, scale, instanced }) => {\n return new Promise((modelResolve, modelReject) => {\n const loader = new GLTFLoader();\n loader.load(\n modelUrl,\n (gltf) => {\n const model = gltf.scene;\n model.traverse((child) => {\n if (child instanceof THREE.Mesh) {\n if (Array.isArray(child.material)) {\n child.material.forEach((mat) => {\n mat.side = THREE.DoubleSide;\n mat.needsUpdate = true;\n });\n } else {\n child.material.side = THREE.DoubleSide;\n child.material.needsUpdate = true;\n }\n }\n });\n \n const worldPosition = projectToWorld(coords);\n model.position.set(worldPosition.x, worldPosition.y, 0);\n model.up.set(0, 0, 1);\n model.rotation.set(rotation[0], rotation[1], rotation[2]);\n model.scale.set(scale[0], scale[1], scale[2]);\n model.visible = modelMap.get(id)?.visible ?? true;\n wrapper.add(model);\n modelMap.set(id, model);\n modelResolve(modelMap);\n },\n undefined,\n (error) => {\n console.error(`Error loading model ${id}:`, error);\n modelReject(error);\n }\n );\n });\n });\n\n map.addLayer({\n id: '3d-model-layer2',\n type: 'custom',\n renderingMode: '3d',\n onAdd: () => Promise.all(modelLoadPromises).then((res)=>{\n resolve(res);\n onModelsLoaded(true);\n }).catch(reject),\n render: () => {},\n });\n } catch (error) {\n reject(error);\n }\n });\n}\n\nexport function toggleModelVisibility(modelMap, modelId, isVisible) {\n const model = modelMap.get(modelId);\n if (!model) return;\n console.log('toggleModelVisibility_model', model);\n const isAnimating = {}; // Object to track animations\n model.traverse((child) => {\n if (child.isMesh) {\n const id = child.id; // Use unique child.id as the key\n child.material.transparent = true;\n if (!isAnimating[id]) {\n isAnimating[id] = true; // Set animation flag\n gsap.to(child.material, {\n opacity: isVisible ? 1 : 0,\n duration: 0.5, // Smooth fade animation\n ease: 'power2.inOut',\n onComplete: () => {\n isAnimating[id] = false; // Reset animation flag\n model.visible = isVisible;\n },\n });\n } else if (child.isMesh) {\n console.error(`GSAP Animation already running for child id ${id}!`);\n }\n }\n });\n if (isVisible) {\n model.visible = true;\n }\n}\n\nexport function bearingToRotation(bearing: number) {\n // Mapbox bearing is clockwise from north, Three.js rotation is counterclockwise from east\n const threeRotation = -((bearing - 90) * Math.PI / 180);\n return threeRotation;\n}\n\nexport function rotationToBearing(quaternion: Quaternion) {\n const euler = new Euler().setFromQuaternion(quaternion);\n // Convert from radians to degrees and adjust coordinate systems\n const bearing = (360 - (euler.y * 180 / Math.PI - 90)) % 360;\n return bearing;\n}\n\nexport function objectDirectionToBearing(object) {\n const forward = new Vector3();\n object.getWorldDirection(forward);\n\n // Project onto the map's X-Z plane (ignore Y)\n const bearing = Math.atan2(forward.x, forward.z) * (180 / Math.PI);\n \n return bearing;\n}"],"mappings":"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","ignoreList":[]}
|