Fix: improve background layer switching code, might improve #1481

This commit is contained in:
Pieter Vander Vennet 2023-06-29 00:24:19 +02:00
parent 775886b2b9
commit 33fa11fc17
2 changed files with 57 additions and 33 deletions

View file

@ -1,7 +1,7 @@
import { Store, UIEventSource } from "../../Logic/UIEventSource" import { Store, UIEventSource } from "../../Logic/UIEventSource"
import type { Map as MLMap } from "maplibre-gl" import type { Map as MLMap } from "maplibre-gl"
import { Map as MlMap, SourceSpecification } from "maplibre-gl" import { Map as MlMap, SourceSpecification } from "maplibre-gl"
import { RasterLayerPolygon } from "../../Models/RasterLayers" import { AvailableRasterLayers, RasterLayerPolygon } from "../../Models/RasterLayers"
import { Utils } from "../../Utils" import { Utils } from "../../Utils"
import { BBox } from "../../Logic/BBox" import { BBox } from "../../Logic/BBox"
import { ExportableMap, MapProperties } from "../../Models/MapProperties" import { ExportableMap, MapProperties } from "../../Models/MapProperties"
@ -370,9 +370,18 @@ export class MapLibreAdaptor implements MapProperties, ExportableMap {
private removeCurrentLayer(map: MLMap): void { private removeCurrentLayer(map: MLMap): void {
if (this._currentRasterLayer) { if (this._currentRasterLayer) {
// hide the previous layer // hide the previous layer
try {
if (map.getLayer(this._currentRasterLayer)) {
map.removeLayer(this._currentRasterLayer) map.removeLayer(this._currentRasterLayer)
}
if (map.getSource(this._currentRasterLayer)) {
map.removeSource(this._currentRasterLayer) map.removeSource(this._currentRasterLayer)
} }
this._currentRasterLayer = undefined
} catch (e) {
console.warn("Could not remove the previous layer")
}
}
} }
private async setBackground(): Promise<void> { private async setBackground(): Promise<void> {
@ -381,47 +390,58 @@ export class MapLibreAdaptor implements MapProperties, ExportableMap {
return return
} }
const background: RasterLayerProperties = this.rasterLayer?.data?.properties const background: RasterLayerProperties = this.rasterLayer?.data?.properties
if (background !== undefined && this._currentRasterLayer === background.id) { console.log("Setting background to", background)
if (!background) {
console.error(
"Attempting to 'setBackground', but the background is",
background,
"for",
map.getCanvas()
)
return
}
if (this._currentRasterLayer === background.id) {
// already the correct background layer, nothing to do // already the correct background layer, nothing to do
return return
} }
// await this.awaitStyleIsLoaded()
if (background !== this.rasterLayer?.data?.properties) {
// User selected another background in the meantime... abort
return
}
if (background !== undefined && this._currentRasterLayer === background.id) {
// already the correct background layer, nothing to do
return
}
if (!background?.url) { if (!background?.url) {
// no background to set // no background to set
this.removeCurrentLayer(map) this.removeCurrentLayer(map)
this._currentRasterLayer = undefined
return return
} }
if (background.type === "vector") { if (background.type === "vector") {
console.log("Background layer is vector") console.log("Background layer is vector", background.id)
this.removeCurrentLayer(map)
map.setStyle(background.url) map.setStyle(background.url)
return return
} }
map.addSource(background.id, MapLibreAdaptor.prepareWmsSource(background))
map.resize()
let addLayerBeforeId = "aeroway_fill" // this is the first non-landuse item in the stylesheet, we add the raster layer before the roads but above the landuse let addLayerBeforeId = "aeroway_fill" // this is the first non-landuse item in the stylesheet, we add the raster layer before the roads but above the landuse
if (background.category === "osmbasedmap" || background.category === "map") { if (background.category === "osmbasedmap" || background.category === "map") {
// The background layer is already an OSM-based map or another map, so we don't want anything from the baselayer // The background layer is already an OSM-based map or another map, so we don't want anything from the baselayer
let layers = map.getStyle().layers addLayerBeforeId = undefined
// THe last index of the maptiler layers this.removeCurrentLayer(map)
let lastIndex = layers.findIndex((layer) => layer.id === "housenumber") } else {
addLayerBeforeId = layers[lastIndex + 1]?.id ?? "housenumber" // Make sure that the default maptiler style is loaded as it gives an overlay with roads
const maptiler = AvailableRasterLayers.maplibre.properties
if (!map.getSource(maptiler.id)) {
this.removeCurrentLayer(map)
map.addSource(maptiler.id, MapLibreAdaptor.prepareWmsSource(maptiler))
map.setStyle(maptiler.url)
await this.awaitStyleIsLoaded()
}
} }
if (!map.getLayer(addLayerBeforeId)) {
addLayerBeforeId = undefined
}
if (!map.getSource(background.id)) {
map.addSource(background.id, MapLibreAdaptor.prepareWmsSource(background))
}
map.resize()
if (!map.getLayer(background.id)) {
map.addLayer( map.addLayer(
{ {
id: background.id, id: background.id,
@ -431,6 +451,7 @@ export class MapLibreAdaptor implements MapProperties, ExportableMap {
}, },
addLayerBeforeId addLayerBeforeId
) )
}
await this.awaitStyleIsLoaded() await this.awaitStyleIsLoaded()
this.removeCurrentLayer(map) this.removeCurrentLayer(map)
this._currentRasterLayer = background?.id this._currentRasterLayer = background?.id

View file

@ -380,6 +380,9 @@ class LineRenderingLayer {
if (this._listenerInstalledOn.has(id)) { if (this._listenerInstalledOn.has(id)) {
continue continue
} }
if (!map.getSource(this._layername)) {
continue
}
if (this._fetchStore === undefined) { if (this._fetchStore === undefined) {
map.setFeatureState( map.setFeatureState(
{ source: this._layername, id }, { source: this._layername, id },