Как задать координаты полигона в openlayers?

Я очень новичок в OpenLayers и JavaScript, и у меня есть следующая проблема.

У меня есть .csvтаблица, представляющая координаты точек, которые я хочу визуализировать на карте с помощью OpenLayers.

Я нашел следующий пример на странице OpenLayers,

https://openlayers.org/en/latest/examples/polygon-styles.html

Однако я не мог понять представления координат там. Более конкретно, я не зналe, что означает[-5e6, 6e6], например, в координате.

Тем не менее, я попытался нарисовать простой квадрат на моей карте, используя мои координаты, но это просто дает мне точку в центре карты, как показано ниже:

https://jsfiddle.net/api/post/library/pure/#&togetherjs=bD5bfPm7vz

Поэтому я не знаю, что именно неправильно, и что я должен изменить? Я думаю, что все дело в том, как записаны координаты, но не уверен, хотя.

И это мой код:

var styles = [
  new ol.style.Style({
    stroke: new ol.style.Stroke({
      color: 'blue',
      width: 3
    }),
    fill: new ol.style.Fill({
      color: 'rgba(0, 0, 255, 0.1)'
    })
  }),
  new ol.style.Style({
    image: new ol.style.Circle({
      radius: 5,
      fill: new ol.style.Fill({
        color: 'orange'
      })
    }),
    geometry: function(feature) {
      // return the coordinates of the first ring of the polygon
      var coordinates = feature.getGeometry().getCoordinates()[0];
      return new ol.geom.MultiPoint(coordinates);
    }
  })
];

var geojsonObject = {
  'type': 'FeatureCollection',
  'crs': {
    'type': 'name',
    'properties': {
      'name': 'EPSG:3857'
    }
  },
  'features': [{
    'type': 'Feature',
    'geometry': {
      'type': 'Polygon',
      'coordinates': [[[-5e6, 6e6], [-5e6, 8e6], [-3e6, 8e6],
          [-3e6, 6e6], [-5e6, 6e6]]]
    }
  }]
};

var source = new ol.source.Vector({
  features: (new ol.format.GeoJSON()).readFeatures(geojsonObject)
});

var layer = new ol.layer.Vector({
  source: source,
  style: styles
});

    var basic = new ol.layer.Tile({
      source: new ol.source.OSM()
    });

var map = new ol.Map({
  layers: [basic, layer],
  target: 'map',
  view: new ol.View({
    center: [0, 3000000],
    zoom: 2
  })
});

1 ответ

  1. Хорошо, я нашел ответ.
    Следующие координаты [-5e6, 6e6]находятся в формате X, Y и основаны на EPSG:3857проекции. XeYравен X * 10 ^ Y. Обычно openlayers используют EPSG:3857проекцию, но для того, чтобы использовать формат координат долготы / широты, мы должны использовать проекцию: EPSG:4326проекция, и мы указываем ее четко, как: projection: 'EPSG:4326