-
Notifications
You must be signed in to change notification settings - Fork 17
WFS
WFS (Web Feature Service) es un estándar OGC para la transferencia de información geográfica, donde los elementos geográficos o features se transmiten en su totalidad al cliente.
Para visualizar capas WFS en el API, se pueden:
1.- Añadir en el constructor del mapa, tanto en modo cadena como objeto:
// Ejemplo de caps WFS en modo cadena
const mapajs = M.map({
container: "map",
center: { x: -965497.2717184591, y: 4166095.580546307 },
zoom: 5,
controls: ['backgroundlayers'],
layers: ["WFST*Campamentos*http://geostematicos-sigc.juntadeandalucia.es/geoserver/sepim/ows?*sepim:campamentos*MPOINT"]
});
2.- O añadiéndolas con el método correspondiente:
const layer = new M.layer.WFS({
url: "http://geostematicos-sigc.juntadeandalucia.es/geoserver/tematicos/ows?",
namespace: "tematicos",
name: "Provincias",
legend: "Provincias",
geometry: 'MPOLYGON',
ids:"3,4"
});
mapajs.addWFS(layer);
Donde:
- url: url del servicio WFS.
- namespace: workspace asociado a la capa.
- name: nombre de la capa en el servidor.
- legend: indica el nombre que queremos que aparezca en el árbol de contenidos, si lo hay.
- geometry: Tipo de geometría: POINT, MPOINT, LINE, MLINE, POLYGON o MPOLYGON.
- ids: Opcional - identificadores por los que queremos filtrar los features.
- cql: Opcional - Sentencia CQL para filtrar los features. El método setCQL(cadena_cql) refresca la capa aplicando el nuevo predicado CQL que reciba.
- version: Opcional - Versión del estandar a usar. Por defecto es 1.0.0.
-
extract: Opcional Activa la consulta por click en el feature, por defecto false.
-
Si se desea personalizar un manejador propio para mostrar un popup o label al hacer click en alguno de los features, hay que establecer el atributo extract a false, para que no sólo se active nuestro manejador.
-
Las capas WFS cuenta con métedos get y set para modificar el extract.
-
Formato de salida
API pide las capas WFS al servidor OGC en formato geojson usando por defecto como outputFormat 'application/json'. Sin embargo, en función del tipo de servidor OGC que esté atendiendo las peticiones (Geoserver, Mapserver, etc.), puede que tenga asignando un nombre diferente. En ese caso, se puede establecer el nombre del outputFormat para las peticiones getFeature y describeFeature, se usan las opciones de usuario 'getFeatureOutputFormat' y 'describeFeatureTypeOutputFormat':
lAguasSupRediam = new M.layer.WFS({
url: 'http://www.juntadeandalucia.es/medioambiente/mapwms/REDIAM_WFS_RN_Aguas?bbox=508887.12101065,4131323.42844933,509462.159552335,4131744.12235486',
legend: 'Cursos de Agua Rediam',
name: 'a_red_hidrografica',
geometry: 'MLINE'
}, {
getFeatureOutputFormat: 'geojson',
describeFeatureTypeOutputFormat: 'geojson'
});
Parámetros vendor
Algunos servidores de mapas son capaces de procesar en las peticiones OGC parámetros adicionales propios, conocidos como vendor parameters. En las capas WFS podemos especificar cualquier parámetro de este tipo si lo incluimos dentro de la estructura correspondiente en el segundo parámetro del constructor: 'vendor -> request OGC asociado -> parametro:valor', por ejemplo:
const lAguasSupRediam = new M.layer.WFS({
url: 'http://www.juntadeandalucia.es/medioambiente/mapwms/REDIAM_WFS_RN_Aguas?bbox=508887.12101065,4131323.42844933,509462.159552335,4131744.12235486',
legend: 'Cursos de Agua Rediam',
name: 'a_red_hidrografica',
geometry: 'MLINE'
},{
vendor:{
getFeature: {
'parametro1': 'valor1',
'parametro2': 'valor2'
}
}
});
El ejemplo anterior crearía peticiones getFeatures que incluirían los parámetros vendor especificados:
http://...?request=getFeature&....¶metro1=valor1¶metro2=valor2
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