diff --git a/examples/tutorial/control/demo/amap.js b/examples/tutorial/control/demo/amap.js index 714d4db1a3..12ecb9baff 100644 --- a/examples/tutorial/control/demo/amap.js +++ b/examples/tutorial/control/demo/amap.js @@ -32,7 +32,7 @@ fetch( scene.addLayer(pointLayer); const overlayers = { - 围栏填充: pointLayer + 气泡图: pointLayer }; const layersControl = new Layers({ overlayers diff --git a/packages/component/src/control/layer.ts b/packages/component/src/control/layer.ts index 4a4aa75e12..58c7596768 100644 --- a/packages/component/src/control/layer.ts +++ b/packages/component/src/control/layer.ts @@ -96,7 +96,6 @@ export default class Layers extends Control { const className = 'l7-control-layers'; const container = (this.container = DOM.create('div', className)); const { collapsed } = this.controlOption; - // makes this work on IE touch devices by stopping it from firing a mouseout event when the touch is released container.setAttribute('aria-haspopup', 'true'); @@ -105,11 +104,11 @@ export default class Layers extends Control { className + '-list', ) as HTMLElement); - // if (collapsed) { - // this.mapsService.on('click', this.collapse); - // container.addEventListener('mouseenter', this.expand); - // container.addEventListener('mouseleave', this.collapse); - // } + if (collapsed) { + this.mapsService.on('click', this.collapse); + container.addEventListener('mouseenter', this.expand); + container.addEventListener('mouseleave', this.collapse); + } this.layersLink = DOM.create('a', className + '-toggle', container); const link = this.layersLink; @@ -297,7 +296,6 @@ export default class Layers extends Control { for (let i = inputs.length - 1; i >= 0; i--) { input = inputs[i]; layer = this.layerService.getLayer(input.layerId); - if (input.checked) { addedLayers.push(layer); } else if (!input.checked) { diff --git a/packages/component/src/css/l7.css b/packages/component/src/css/l7.css index f20392e7c5..e547d69118 100644 --- a/packages/component/src/css/l7.css +++ b/packages/component/src/css/l7.css @@ -726,12 +726,10 @@ .l7-control-layers-toggle { background-image: url(''); width: 36px; - height: 36px; - } -.l7-retina .l7-control-layers-toggle { - background-image: url(''); - background-size: 26px 26px; + height: 36px; + background-size: 26px 26px; } + .l7-touch .l7-control-layers-toggle { width: 44px; height: 44px; diff --git a/packages/layers/src/core/BaseLayer.ts b/packages/layers/src/core/BaseLayer.ts index f4f66dd808..b856a4fdbd 100644 --- a/packages/layers/src/core/BaseLayer.ts +++ b/packages/layers/src/core/BaseLayer.ts @@ -551,13 +551,13 @@ export default class BaseLayer extends EventEmitter blend: type, }); this.layerModelNeedUpdate = true; - this.render(); + this.reRender(); } public show(): ILayer { this.updateLayerConfig({ visible: true, }); - + this.reRender(); return this; } @@ -565,9 +565,9 @@ export default class BaseLayer extends EventEmitter this.updateLayerConfig({ visible: false, }); + this.reRender(); return this; } - public setIndex(index: number): ILayer { this.zIndex = index; this.layerService.updateRenderOrder(); @@ -777,6 +777,11 @@ export default class BaseLayer extends EventEmitter protected getDefaultConfig() { return {}; } + private reRender() { + if (this.inited) { + this.layerService.renderLayers(); + } + } private splitValuesAndCallbackInAttribute( valuesOrCallback?: unknown[], defaultValues?: unknown[],