fix: fix layercontrol 选中取消隐藏问题

This commit is contained in:
thinkinggis 2020-01-14 17:01:29 +08:00
parent 4f9ccbbd4b
commit 84af61dfb0
4 changed files with 17 additions and 16 deletions

View File

@ -32,7 +32,7 @@ fetch(
scene.addLayer(pointLayer);
const overlayers = {
围栏填充: pointLayer
气泡图: pointLayer
};
const layersControl = new Layers({
overlayers

View File

@ -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) {

View File

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

View File

@ -551,13 +551,13 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> 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<ChildLayerStyleOptions = {}> 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<ChildLayerStyleOptions = {}> extends EventEmitter
protected getDefaultConfig() {
return {};
}
private reRender() {
if (this.inited) {
this.layerService.renderLayers();
}
}
private splitValuesAndCallbackInAttribute(
valuesOrCallback?: unknown[],
defaultValues?: unknown[],