Есть ли возможность реализовать редактирование shape через браузер?

Вопросы по нескольким пакетам сразу, или вопросы, которые непонятно к какой ГИС отнести
Ответить
dmitriy_gislab
Новоприбывший
Сообщения: 7
Зарегистрирован: 14 июн 2018, 11:44
Репутация: 0
Откуда: 2018

Есть ли возможность реализовать редактирование shape через браузер?

Сообщение dmitriy_gislab » 24 июн 2018, 19:32

Есть ли такие сервисы?
Если нет, то может есть API такие у QGIS или других?

trir
Гуру
Сообщения: 3697
Зарегистрирован: 09 апр 2010, 19:30
Статьи: 1
Репутация: 618
Ваше звание: просто мимо прохожу
Откуда: Ё-бург

Re: Есть ли возможность реализовать редактирование shape через браузер?

Сообщение trir » 24 июн 2018, 19:51



dmitriy_gislab
Новоприбывший
Сообщения: 7
Зарегистрирован: 14 июн 2018, 11:44
Репутация: 0
Откуда: 2018

Re: Есть ли возможность реализовать редактирование shape через браузер?

Сообщение dmitriy_gislab » 24 июн 2018, 21:36

bim2010 писал(а):
24 июн 2018, 19:54
shp2geojson.js - https://github.com/gipong/shp2geojson.js
https://gis.stackexchange.com/questions ... enlayers-3
Допустим я преобразую shp в geojson, но как мне его отредактировать? В canvas?
И самое главное как сохранить обратно в shp?

bim2010
Гуру
Сообщения: 927
Зарегистрирован: 27 янв 2009, 22:57
Статьи: 1
Проекты: 2
Репутация: 231

Re: Есть ли возможность реализовать редактирование shape через браузер?

Сообщение bim2010 » 24 июн 2018, 21:46

openlayers умеет редактировать geojson. Ссылки на примеры см. выше.
https://openlayers.org/en/latest/examples/geojson.html
https://openlayers.org/en/latest/examples/

geojson2shp - https://github.com/jdesboeufs/geojson2shp

dmitriy_gislab
Новоприбывший
Сообщения: 7
Зарегистрирован: 14 июн 2018, 11:44
Репутация: 0
Откуда: 2018

Re: Есть ли возможность реализовать редактирование shape через браузер?

Сообщение dmitriy_gislab » 25 июн 2018, 01:27

bim2010 писал(а):
24 июн 2018, 21:46
openlayers умеет редактировать geojson. Ссылки на примеры см. выше.
На карте элементы не отображаются.
Не получается сгенерированный файл (json) вывести на карту (JSON.stringify(data)).

Код: Выделить всё

	$(document).ready(function() {


		function loadShpZip() {
			var epsg = ($('#epsg').val() == '') ? 4326 : $('#epsg').val(),
			encoding = ($('#encoding').val() == '') ? 'UTF-8' : $('#encoding').val();
			if(file.name.split('.')[1] == 'zip') {
				if(file) $('.dimmer').addClass('active');
				loadshp({
					url: file,
					encoding: encoding,
					EPSG: epsg
				}, function(data) {
					//document.write(JSON.stringify(data));
					//console.log(JSON.stringify(data));
					
   var image = new ol.style.Circle({
        radius: 5,
        fill: null,
        stroke: new ol.style.Stroke({color: 'red', width: 10})
      });

      var styles = {
        'Point': new ol.style.Style({
          image: image
        }),
        'LineString': new ol.style.Style({
          stroke: new ol.style.Stroke({
            color: 'green',
            width: 1
          })
        }),
        'MultiLineString': new ol.style.Style({
          stroke: new ol.style.Stroke({
            color: 'green',
            width: 1
          })
        }),
        'MultiPoint': new ol.style.Style({
          image: image
        }),
        'MultiPolygon': new ol.style.Style({
          stroke: new ol.style.Stroke({
            color: 'yellow',
            width: 1
          }),
          fill: new ol.style.Fill({
            color: 'rgba(255, 255, 0, 0.1)'
          })
        }),
        'Polygon': new ol.style.Style({
          stroke: new ol.style.Stroke({
            color: 'blue',
            lineDash: [4],
            width: 3
          }),
          fill: new ol.style.Fill({
            color: 'rgba(0, 0, 255, 0.1)'
          })
        }),
        'GeometryCollection': new ol.style.Style({
          stroke: new ol.style.Stroke({
            color: 'magenta',
            width: 2
          }),
          fill: new ol.style.Fill({
            color: 'magenta'
          }),
          image: new ol.style.Circle({
            radius: 10,
            fill: null,
            stroke: new ol.style.Stroke({
              color: 'magenta'
            })
          })
        }),
        'Circle': new ol.style.Style({
          stroke: new ol.style.Stroke({
            color: 'red',
            width: 2
          }),
          fill: new ol.style.Fill({
            color: 'rgba(255,0,0,0.2)'
          })
        })
      };

var styleFunction = function(feature) {
  return styles[feature.getGeometry().getType()];
};

var vectorSource = new ol.source.Vector({
  features: (new ol.format.GeoJSON()).readFeatures(JSON.stringify(data))
});

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

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


					
					
				});
			} 
		}

		$("#file").change(function(evt) {
			file = evt.target.files[0];
			if(file.size > 0) {
				loadShpZip();
			}
		});


		$('#addZipfile').click(function() {
			$('.shp-modal').toggleClass('effect');
			$('.overlay').toggleClass('effect');
			$('#wrap').toggleClass('blur');
		});
		
	});
	
	

Ответить

Вернуться в «Общий - ПО»

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и 0 гостей