В mapbox как мне переместить объект вверх (по z-index)? - PullRequest
0 голосов
/ 30 августа 2018

У меня есть слой, полный государственной границы "Особенности". Когда пользователь нажимает на состояние, я хочу переместить функцию этого состояния в верхнюю часть стека (по z-index).

export function drawStateBorders() {
  $.getJSON('https://www.mapbox.com/mapbox-gl-js/assets/us_states.geojson').then((data) => {
    this.stateGeoJSON = data;

    this.map
      .addSource('states', {
        type: 'geojson',
        data,
      })
      .addLayer({
        id: 'state-borders',
        type: 'line',
        source: 'states',
        paint: {
          'line-color': [
            'case', ['boolean', ['feature-state', 'selected'], false],
            '#8d8b76',
            '#bfe2ab',
          ],
          'line-width': [
            'case', ['boolean', ['feature-state', 'selected'], false],
            6,
            3,
          ],
        },
      });
  });
}

Когда я выбираю состояние

export function stateSelected(state) {
  const stateFeatures = this.map.queryRenderedFeatures({
    layers: ['state-borders'],
    filter: [
      '==', 'STATE_NAME', state,
    ],
  });

  const features = this.stateGeoJSON.features;
  const currentFeature = stateFeatures[0];

  if (!currentFeature) {
    return;
  }

  // same state
  if (currentFeature.id === this.selectedStateId) return;

  // move to front HERE ?????

  // old selected state
  if (this.selectedStateId) {
    this.map.setFeatureState({
      source: 'states',
      id: this.selectedStateId,
    }, {
      selected: false,
    });
  }

  this.selectedStateId = currentFeature.id;

  this.map.setFeatureState({
    source: 'states',
    id: this.selectedStateId,
  }, {
    selected: true,
  });
}

Пока я пробовал

  features.splice(features.indexOf(currentFeature), 1);
  features.push(currentFeature);
  this.map.getSource('states').setData(this.stateGeoJSON);

Это, кажется, делает некоторые действительно сумасшедшие вещи с массивом (дублирование одних состояний, удаление других). Понятия не имею, что происходит

1 Ответ

0 голосов
/ 31 августа 2018

Добавление состояния в другой слой сработало (спасибо @AndrewHarvey за совет).

Если кто-то заинтересован, вот мой код

export function stateSelected(state) {
  const features = this.stateGeoJSON.features;
  const currentFeature = features.find(s => s.properties.NAME === state);

  if (!currentFeature) {
    return;
  }

  // removes active layer
  this.removeLayersContaining('state-borders-active');
  this.drawActiveStateLayer(currentFeature);
}


export function drawActiveStateLayer(feature) {
  this.map
    .addLayer({
      id: 'state-borders-active',
      type: 'line',
      source: {
        type: 'geojson',
        data: feature
      },
      paint: {
        'line-color': '#8d8b76',
        'line-width': 6,
      },
    });
}

export function drawStateBorders() {
  $.getJSON('states.json').then((data) => {

    this.stateGeoJSON = data;

    this.map
      .addSource('states', {
        type: 'geojson',
        data,
      })
      .addLayer({
        id: 'state-borders',
        type: 'line',
        source: 'states',
        paint: {
          'line-color': '#bfe2ab',
          'line-width':  3,
        },
      });
  });

Также этот шейп-файл я использую: http://eric.clst.org/assets/wiki/uploads/Stuff/gz_2010_us_040_00_500k.json

...