[英]Leaflet: Change color onClick
我试图在我的 Ionic React 应用程序中的每次点击时更改我的GeoJSON
-Layer 的颜色,但我只在第一次点击时更改了一次......我的想法是每次功能时更改蓝色和红色之间的颜色被点击。 我有想法在GeoJSON
-Layer 的options
中检查颜色,但正如所写的那样,它只在第一次点击时更改颜色一次,之后任何其他点击都不会发生任何事情。
function LeafletMap() {
const [map, setMap] = useState(null)
const onEachClick = (info, layer) => {
const part = info.properties.Objekt_ID
const id = info.properties.FID_
layer.bindPopup("Object ID: <b>" + part + "</b><br>FID: <b>" + id + "</b>")
if(layer.options.color != "blue") {
layer.on({
click: (event) => {
event.target.setStyle({
color: "blue",
});
}
})
} else {
layer.on({
click: (event) => {
event.target.setStyle({
color: "red",
});
}
})
}
}
const displayMap = useMemo(
() => (
<MapContainer
center={center}
zoom={zoom}
scrollWheelZoom={false}
whenCreated={setMap}>
<LayersControl position="topright">
<LayersControl.BaseLayer checked name="OpenStreetMap - Map">
<TileLayer
attribution='© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
url="https://{s}.tile.openstreetmap.de/tiles/osmde/{z}/{x}/{y}.png"
/>
</LayersControl.BaseLayer>
<LayersControl.BaseLayer name="Esri - Satelite">
<TileLayer
attribution='Tiles © Esri — Source: Esri, i-cubed, USDA, USGS, AEX, GeoEye, Getmapping, Aerogrid, IGN, IGP, UPR-EGP, and the GIS User Community'
url="https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}"
/>
</LayersControl.BaseLayer>
</LayersControl>
<GeoJSON data={PL.features} onEachFeature={onEachClick} color="blue"/>
<GeoJSON data={WWD.features} onEachFeature={onEachClick} color="blue"/>
</MapContainer>
),
[],
)
window.dispatchEvent(new Event('resize'));
return (
<div>
{displayMap}
</div>
)
}
export default LeafletMap
有一种非常简单的方法可以实现所需的行为。 我可以举一个使用 geojson 的例子,然后你可以根据自己的需要进行调整。
每次单击图层后,您都需要重置 geojson 样式。 您可以通过使用 react ref
和传单的resetStyle
方法获取 geojson 引用来实现这resetStyle
。 而关于样式的改变,你只需要在每次点击后设置颜色。 那里不需要 if 语句。
const geoJsonRef = useRef();
const onEachClick = (feature, layer) => {
const name = feature.properties.name;
const density = feature.properties.density;
layer.bindPopup(
"Name: <b>" + name + "</b><br>Density: <b>" + density + "</b>"
);
layer.on({ click: handleFeatureClick });
};
const handleFeatureClick = (e) => {
if (!geoJsonRef.current) return;
geoJsonRef.current.resetStyle();
const layer = e.target;
layer.setStyle({ color: "red" });
};
...
<GeoJSON ref={geoJsonRef} />
这是一个演示,其中包含来自传单网站的一些数据
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.