-
Notifications
You must be signed in to change notification settings - Fork 15
GeoJSON
GeoJSON, pese a no ser un estándar OGC (está camino de convertirse en ello), es un formato de intercambio de información geográfica muy extendido que, al igual que WFS, permite tener todos los elementos en el cliente. Es un formato estádar abierto diseñado para represetar objetos geográficos sencillos, junto con sus atributos no espaciales. Es ampliamente ultilizado en aplicaciones de cartografía en entornos web al permitir el intercambio de datos de manera rápida, ligera y sencilla. La grámatica del formato esta basada en WKT Well Known Text.
Un ejemplo de GeoJSON:
{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [125.6, 10.1]
},
"properties": {
"name": "Dinagat Islands"
}
}
Parámetros disponibles:
-
name: nombre de la capa en la leyenda.
-
url: url del fichero o servicio que genera el GeoJSON.
-
extract: opcional, activa la consulta por click en el objeto geográfico, por defecto falso.
-
Si se desea personalizar un manejador propio para mostrar un "popup" o "label" al hacer click en alguno de los objetos geográficos, hay que establecer el atributo extract a true, para que no sólo se active nuestro manejador.
-
Las capas GeoJSON cuenta con métedos GET y SET para modificar el extract.
-
-
options: Estas opciones se mandarán a la implementación.
- hide: Atributos ocultos.
- show: Mostrar atributos.
- minZoom: Zoom mínimo aplicable a la capa.
- maxZoom: Zoom máximo aplicable a la capa.
- visibility: Define si la capa es visible o no. Verdadero por defecto.
- displayInLayerSwitcher: Indica si la capa se muestra en el selector de capas.
- opacity: Opacidad de capa, por defecto 1.
- style: Define el estilo de la capa.
-
vendorOptions: Opciones para la biblioteca base. Ejemplo vendorOptions:
import OLSourceVector from 'ol/source/Vector';
{
opacity: 0.1,
source: new OLSourceVector({
attributions: 'geojson',
...
})
}
Dependiendo la fuente del GeoJSON, para añadirlo al API-CNIG:
💡 En el caso de las capas de tipo GeoJSON, se diferencia si el mismo es servido (url) o si por el contrario lo tenemos en local (source).
1.- GeoJSON local:
mapajs.addLayers(new M.layer.GeoJSON({
name: "capaJson",
source: {
"type": "FeatureCollection",
"features": [{
"properties": {
"estado": 1,
"vendor": {
"mapea": {}
},
"sede": "/Sevilla/CHGCOR003-Oficina de la zona regable del Genil",
"tipo": "ADSL",
"name": "/Sevilla/CHGCOR003-Oficina de la zona regable del Genil"
},
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [-5.278075, 37.69374444444444]
}
}],
"crs": {
"properties": {
"name": "EPSG:4326"
},
"type": "name"
}
}));
// También es posible crear una capa vacía
const layer = new M.layer.GeoJSON({
name: "Catastro",
crs: "25830"
});
// Y añadirle posteriormente features
...
layer.addFeatures(f);
⚠️ Hay que tener en cuenta que, en el caso de no establecer el crs, se tomará el establecido por defecto en el estándar: EPSG:4326
2.- GeoJSON servido:
const layer = new M.layer.GeoJSON(
{name: "Provincias",
url: "http://geostematicos-sigc.juntadeandalucia.es/geoserver/tematicos/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=tematicos:Provincias&maxFeatures=50&outputFormat=application/json"});
mapajs.addLayers(layer);
Además, existe la posibilidad de extraer de una Capa vectorial en formato GeoJSON, a través de su fuente vectorial y pasarla a base64 para poder utilizarla por APIREST:
btoa( JSON.stringify( layer.toGeoJSON() ) )
Fichero vectorial GeoJSON:
https://componentes.cnig.es/GaleriaEjemplos_APICNIG/ejemplos/GeoJSON01.html
Personalizar popup:
https://componentes.cnig.es/GaleriaEjemplos_APICNIG/ejemplos/popupPersonalizado01.html
1.INICIO
1.1. Componentes de la API-CNIG
1.2. Documentación y Puntos de acceso
1.3. Primeros pasos
1.4. Diagrama API CNIG
2.1. Capas
■ 2.1.1. Fuentes
• 2.1.1.1. Capas vectoriales
+ Vector
+ WFS
+ GeoJSON
+ KML
+ MVT
+ OGCAPIFeatures
+ MBTilesVector
+ GenericVector
+ MapLibre
• 2.1.1.2. Capas ráster
+ WMS
+ WMTS
+ TMS
+ XYZ
+ OSM
+ MBTiles
+ GenericRaster
+ GeoTIFF
• 2.1.1.3. Capas rápidas
• 2.1.1.4. Grupo de capas
■ 2.1.2. Simbolización
• 2.1.2.1. Genérica
+ Puntos
+ Líneas
+ Polígonos
• 2.1.2.2. Básica
+ Puntos
+ Líneas
+ Polígonos
• 2.1.2.3. Avanzada
+ Coropletas
+ Proporcional
+ Categorías
+ Estadísticos
+ Mapas de Calor
+ Cluster
+ Línea de flujo
+ Composición
2.4. Paneles
» Creación de panel desde cero sin controles
» Tutorial Panel de un único control
5. API REST
5.1. Parametrización API-REST
5.2. Base de Datos API-REST
5.3. API REST Actions
5.4. Servicio de correos electrónicos
5.5. Capas rápidas
6. PARAMETRIZACIÓN VISUALIZADORES
9. GUÍA DE DESARROLLO
> Guía para el desarrollo de API-CNIG
» Tutorial desarrollo del núcleo de API-CNIG - (Cliente)
> Guía de desarrollo de componentes
» Tutorial desarrollo del núcleo de API-CNIG - (Servidor)
> Guía de desarrollo de plugins
» Tutorial desarrollo de plugins ya creados
» Tutorial desarrollo de nuevos plugins
> Guía de desarrollo de visualizadores con React