Karten-Fix: Scan-Race bei schnellen Zoom-Folgen (Z16→Z13→Z14 → keine Marker)
_loadOsmLayers verwarf Scan-Anfragen, die während eines laufenden Scans kamen (return). Bei langsamem Overpass (Handy) ging so der finale Z14-Scan verloren → Marker leer. Jetzt: _scanQueued merkt die Anfrage vor, finally holt sie nach → letzte Ansicht wird garantiert gescannt.
This commit is contained in:
parent
d447de2b8d
commit
980338d7f1
6 changed files with 24 additions and 17 deletions
|
|
@ -3,7 +3,7 @@
|
|||
Router, State-Management, Navigation, Initialisierung.
|
||||
============================================================ */
|
||||
|
||||
const APP_VER = '1184'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
|
||||
const APP_VER = '1185'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
|
||||
const APP_VERSION = '1.6.0'; // ← semantische Version, wird bei make release gesetzt
|
||||
window.APP_VER = APP_VER; // global verfügbar für andere Module (z.B. offline-indicator)
|
||||
window.APP_VERSION = APP_VERSION;
|
||||
|
|
|
|||
|
|
@ -142,6 +142,7 @@ window.Page_map = (() => {
|
|||
|
||||
let _overpassTimer = null;
|
||||
let _overpassActive = false;
|
||||
let _scanQueued = false; // Scan-Anfrage während laufendem Scan → danach nachholen
|
||||
let _ringClosing = false;
|
||||
let _frankfurtTimer = null;
|
||||
let _autoRetryCount = 0; // begrenzt Auto-Retry auf max 3x pro Kartenposition
|
||||
|
|
@ -1262,7 +1263,10 @@ window.Page_map = (() => {
|
|||
}
|
||||
|
||||
async function _loadOsmLayers() {
|
||||
if (!_map || _overpassActive) return;
|
||||
if (!_map) return;
|
||||
// Läuft schon ein Scan? Anfrage vormerken (nicht verwerfen) → wird danach nachgeholt.
|
||||
// Sonst gehen bei schnellen Zoom-/Pan-Folgen (z.B. Z16→Z13→Z14) Scans verloren → keine Marker.
|
||||
if (_overpassActive) { _scanQueued = true; return; }
|
||||
if (!_engineGL && !window.L) return;
|
||||
const zoom = _mapGetZoom();
|
||||
|
||||
|
|
@ -1355,6 +1359,9 @@ window.Page_map = (() => {
|
|||
await Promise.all(freshTasks);
|
||||
} finally {
|
||||
_overpassActive = false;
|
||||
// Während des Scans kam eine neue Anfrage (Karte bewegt) → jetzt nachholen,
|
||||
// damit die zuletzt sichtbare Ansicht garantiert gescannt wird.
|
||||
if (_scanQueued) { _scanQueued = false; _scheduleOsmLoad(); }
|
||||
}
|
||||
|
||||
const totalLoaded = _osmTotalCount();
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue