Преобразуйте полигоны геойсона в точки с узлом, используя query-overpass и turf.js - PullRequest
0 голосов
/ 14 мая 2018

Я использую модуль узла «запрос-обход» для запроса, чтобы получить фермы из openstreetmaps.Я хотел бы преобразовать все полигоны в точки внутри этого скрипта.Я использую turf.js, чтобы получить центроиды этих многоугольников, но я не могу постоянно менять объекты.Пока это мой код:

const query_overpass = require("query-overpass");
const turf = require ("turf");
const fs = require("fs")
let test
let filename = "data/test.js"
let bbox = "48.91821286473131,8.309097290039062,49.0610446187357,8.520584106445312";
console.log('starting query for ' +filename)
console.log('bbox: ' +bbox)
let query = ` 
  [out:json][timeout:250];
  // gather results
  (
  // query part for: “vending=milk”
  node["vending"="milk"](${bbox});
  way["vending"="milk"](${bbox});
  relation["vending"="milk"](${bbox});
  // query part for: “shop=farm”
  node["shop"="farm"](${bbox});
  way["shop"="farm"](${bbox});
  relation["shop"="farm"](${bbox});
  // query part for: “vending=food”
  node["vending"="food"](${bbox});
  way["vending"="food"](${bbox});
  relation["vending"="food"](${bbox});
  );
  // print results
  out body;
  >;
  out skel qt;
`;

// query overpass, write result to file
query_overpass(query, (error, data)  => {
    data = JSON.stringify(data , null, 1)
    console.log(data)
    test = JSON.parse(data)


//create centroids for every polyon and save them as a point
    for (var i = 0; i < test.features.length; i++) { 
      console.log("Log: " +test.features[i].geometry.type)
      console.log("Log: " +test.features[i].properties.name)
      if (test.features[i].geometry.type === "Polygon"){
        console.log("polygon detected")
        var centroid = turf.centroid(test.features[i]);
            var lon = centroid.geometry.coordinates[0];
            var lat = centroid.geometry.coordinates[1];
            console.log(" lon: " +lon +" lat: " +lat)

            test.features[i].geometry.type = 'Point'
            //delete Polygon structure and insert centroids as new points here
            console.log("polygon deleted and changed to point")
      }

  }
  console.log(test)
   fs.writeFile(filename, `var file = ${test};` , ["utf-8"], (error, data) => {if (error) {console.log(error)}})
 }, {flatProperties: true}
)

Кажется, что я могу что-то изменить внутри цикла for, но они не появляются, когда данные сохраняются позже.Это в основном вопрос о том, как правильно редактировать объекты json, но я не могу понять, почему это не работает здесь вообще.

Итак, в основном есть два вопроса:

  • Почему я не могу переопределить geometry.type в приведенном выше примере?
  • Как удалить старый многоугольник и добавить новую точку в элемент?

Спасибо за любую помощь.

1 Ответ

0 голосов
/ 14 мая 2018

Это довольно сложно ... Почему бы вам не позволить Overpass API выполнить эту работу и использовать out center; вместо out body;>;out skel qt; для возврата центральных точек всех узлов, путей и отношений. Вы можете использовать overpass-turbo.eu, чтобы сначала попробовать это.

...