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:
rene 2026-06-05 10:56:08 +02:00
parent d447de2b8d
commit 980338d7f1
6 changed files with 24 additions and 17 deletions

View file

@ -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();