Я использую этот пример, в котором метки Mapbox размещаются поверх слоя. Кажется, это написано с использованием простого пакета Mapbox. Я надеюсь сделать то же самое для компонента карты в DeckGL.
Соответствующий код из примера:
const map = new mapboxgl.Map({
container: document.body,
style: 'mapbox://styles/mapbox/light-v9',
center: [-122.4, 37.79],
zoom: 15,
pitch: 60
});
map.on('load', () => {
const firstLabelLayerId = map.getStyle().layers.find(layer => layer.type === 'symbol').id;
Мой код с использованием DeckGL:
<DeckGL
initialViewState={INITIAL_VIEW_STATE}
layers={layers}
onClick={expandTooltip}
onViewStateChange={hideTooltip}
onWebGLInitialized={onInitialized}
views={MAP_VIEW}
controller={{
touchRotate: true,
inertia: 600,
}}
>
<StaticMap
reuseMaps
mapStyle={MAP_STYLE}
preventStyleDiffing={true}
mapboxApiAccessToken={process.env.REACT_APP_MAPBOX_TOKEN}
/>
</DeckGL>
Как я могу получить доступ к getStyle().layers
в вышеуказанных компонентах? Я попытался использовать useRef
, как в этом упрощенном компоненте:
const mapRef = useRef();
<DeckGL
{...viewport}
maxZoom={20}
mapboxApiAccessToken={process.env.REACT_APP_MAPBOX_TOKEN}
ref={mapRef}
>
но обнаружил, что он не содержит информации о компоненте.