mirror of https://gitee.com/antv-l7/antv-l7
fix: fix layercontrol 选中取消隐藏问题
This commit is contained in:
parent
4f9ccbbd4b
commit
84af61dfb0
|
@ -32,7 +32,7 @@ fetch(
|
|||
|
||||
scene.addLayer(pointLayer);
|
||||
const overlayers = {
|
||||
围栏填充: pointLayer
|
||||
气泡图: pointLayer
|
||||
};
|
||||
const layersControl = new Layers({
|
||||
overlayers
|
||||
|
|
|
@ -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) {
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -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[],
|
||||
|
|
Loading…
Reference in New Issue