6.6. Add layers
6.6.1. Raster layer
Raster images in NextGIS Web should be loaded using the “Raster Layer” special resource.
6.6.1.1. Creation process
To add a raster layer navigate to a group where you want to create it. Press Create resource button and select Raster layer (see Pic. 6.32.).
On the “Raster layer” tab you need to upload a geodata file in GeoTIFF format. The upload dialog indicates the maximum file size allowed on your subscription plan (Pic. 6.33.).
If you plan to use this raster in QGIS directly from your Web GIS, tick the Upload as Cloud Optimized GeoTIFF (COG) checkbox. This will optimize the raster to ensure fast display.
In the “Resource” tab specify the name of the raster layer (see Pic. 6.34.). It will be displayed in the admin interface. The “Key” field is optional.
On the “Description” tab you can add any text describing the content of this layer (Pic. 6.35.).
In the “Metadata” tab you can enter information in the “key-value” format (Pic. 6.36.).
To complete click the Create button.
6.6.1.2. Raster style (QGIS)
After a raster file is successfully uploaded and a raster layer is created, you need to create a QGIS style. This procedure is similar to adding a vector layer style. You can create one in NextGIS QGIS. You will need this style to add the raster to a Web Map when creating one (for more information see subsection Creating a Web Map).
6.6.1.3. Raster layer with transparency (clip or alpha channel)
Most of utilities do not create an alpha channel and only add a NoData value. To transform NoData value to an alpha channel use the command line utility gdalwarp. Here is an example of this command.
gdalwarp -t_srs EPSG:3857 -multi -dstalpha -dstnodata none -wo \
"UNIFIED_SRC_NODATA=YES" -co COMPRESS=JPEG \
d:\temp\o\ast_20010730_010043_rgb.tif d:\temp\o\ast_20010730_010043_rgba.tif
6.6.1.4. Uploading Indexed Color Rasters
Indexed Color raster files are uploaded just like the RGB raster files. If the file is not in GeoTIFF format, you can convert it as follows:
gdal_translate yaroslavl.map yaroslavl.tif
6.6.2. Vector layer from file
You can create vector layers based on ESRI Shapefile, GeoJSON, KML, CSV, GML and GeoPackage formats in NextGIS Web.
6.6.2.1. Creation process
Navigate to the resource group (folder) in which to create a vector layer. Press Create resource button and select Vector layer (see Pic. 6.37.).
In the opened tab you need to upload a geodata file in ESRI Shapefile (zip-archive), GeoJSON, KML, GML or GeoPackage format. The upload dialog indicates the maximum file size allowed on your subscription plan (Pic. 6.38.). Web GIS can process multi-layer datasets. If an archive contains several layers, then after it is uploaded, you will be asked to select which layer will be used for creating Vector layer resource.
Below it is proposed to define advanced options for creating a vector layer. Depending on the quality of the data you can handle geometry errors when uploading a file as follows:
Not fix errors
Fix whatever is possible
Fix without losing data
Next - the type of geometry, the presence/absence of multigeometries, Z-coordinates and the source of the FID (FID field, determine automatically or indicate from a particular field) are indicated. More about advanced options.
In the “Resource” tab enter the name of the vector layer (Pic. 6.39.). It will be displayed in the admin interface. The “Key” field is optional.
In the “Description” tab you can add any text describing the content of this layer (Pic. 6.40.).
In the “Metadata” tab you can add information in the “key-value” format (Pic. 6.41.).
On the “Settings” tab you can enable feature versioning. It allows the layer to be edited directly in QGIS via NextGIS Connect by multiple users at once.
After uploading the file and specifying the parameters, click the Create button.
Then you can create a style that will later visualize the data layer on a Web Map. You can also create a form or data collection.
6.6.2.2. Input data requirements
Source files could be in the following formats:
Point layers can also be created from CSV and XLSX files, the coordinates should be in the ‘lat’ and ‘lon’ columns. Watch the process of creating such a layer in the video:
Watch on youtube.
Use NextGIS Connect if you need to upload data in other formats.
Note
In case of ESRI Shapefile, all components (dbf, shp, shx, prj and other files) should be compressed to a zip-archive.
Warning
Avoid using Unicode symbols in data field names. While such data can be uploaded to the Web GIS and displayed on Web Maps, you can experience problems working with it in NextGIS Mobile or visualization (especially if labels are using such fields). Use plain Latin for field names and set up field aliases to show Unicode names.
If input data layer contains fields named id (ID) or geom (GEOM), they will be renamed on import. If id has meaningful identifiers, they will automatically be turned into internal FIDs.
6.6.3. Empty vector layer
Creating an empty vector layer allows you to start a data base in your WebGIS without using a desktop app.
Navigate to the resource group (folder) in which to create a vector layer. Press Create resource button and select Vector layer (see Pic. 6.43.).
In the opened window use the dropdown menu to select “Create empty layer”. In the field below select geometry type for the layer. By default, a point layer will be created.
In the “Resource” tab enter the name of the vector layer (Pic. 6.39.). It will be displayed in the admin interface. The “Key” field is optional.
In the “Description” tab you can add any text describing the content (Pic. 6.40.).
In the “Metadata” tab you can add information in the “key-value” format (Pic. 6.41.).
After uploading the file and specifying the parameters, click the Create button.
Then you can create a style that will later visualize the data layer on a Web Map.
To add features to the newly created layer you can use the editing toolbar.
6.6.4. Vector layer from PostGIS
To add a vector layer from PostgreSQL database with PostGIS extension, you need to create a PostGIS connection resource. It is enough to create one connection.
6.6.4.1. Creating PostGIS connection
Press Create resource button and select PostGIS connection (see Pic. 6.45.).
Enter a display name that will be visible in the administrator interface. Not to be confused with layer name in a database.
“Keyname” field is optional.
You can also add resource description and metadata on the corresponding tabs.
Switch from “Resource” to “PostGIS connection” tab, which is presented on Pic. 6.49..
In this tab you should enter connection parameters for the PostGIS database that you are going to take data from.
disable - use an unencrypted connection.
allow - attempt to connect whithout encryption, falling back to an encrypted connection if an unencrypted connection cannot be established.
prefer - attempt to connect using encryption, falling back to an unencrypted connection if an encrypted connection cannot be established.
require - require an encrypted connection and fail if one cannot be established.
verify-ca - require an encrypted connection, and also perform verification against the server CA certificate.
verify-full - require an encrypted connection, and also perform verification against the server CA certificate and against the server host name in its certificate.
More about SSL modes.
After configuring all the neccessary settings click Create.
6.6.4.2. Creating PostGIS layer
Now you can add individual PostGIS layers. Navigate to a group where you want to create layers. Press Create resource button and select PostGIS layer (see Pic. 6.50.).
Enter a display name that will be visible in administrator interface and in the map layer tree.
“Keyname” field is optional.
You can also add resource description and metadata on the corresponding tabs.
Switch from “Resource” tab to “PostGIS layer” tab, which is presented on Pic. 6.53..
Then perform the following steps:
From a dropdown list select a database connection (creation of a connection is described above).
Select a schema of the database where layer data is stored. A single database can store multiple schemas. Each schema contains tables and views. If there is only one schema, it’s called public. For more information see PostgreSQL DBMS manual.
Select the Table name (PostGIS layer). You need to know names of tables and columns in your database. Display of tables content is not a feature of NextGIS Web. You can view them using NextGIS QGIS or pgAdmin software.
Select an ID column. When data is loaded into PostGIS using NextGIS QGIS software, an ogc_fid column is created. If the data was loaded another way, the column name may be different. An ID column should follow rules for data type: the value type should be a number (numeric) and it should be a primary key.
Select the Geometry column (if the data was loaded to PostGIS using NextGIS QGIS software, usually a geometry column called wkb_geometry is created. If the data was loaded some other way, the name of the column may be different).
Parameters “Geometry type”, “Fields” and “SRID” are not required, so you can use default values.
After specifying all the necessery parameters, click Create.
Important
You need an unique integer column to attach your table to NextGIS Web. If the primary key column of the table is not integer or there is none at all, you can create an auxiliary key.
To create a key column connect to your database (for example using psql in qgis) and execute the following (replacing ‘tablename’ with the name of your table):
ALTER TABLE tablename ADD fid serial NOT NULL;
ALTER TABLE tablename ADD CONSTRAINT tablename_fid_unique UNIQUE (fid);
And then use this column (fid) an ID column in NextGIS Web.
More details about PostGIS here.
6.6.5. WMS layer
Note
Currently supported WMS versions 1.1.1 and 1.3.0.
NextGIS Web is a WMS client. To connect a WMS layer you need to know its address. WMS server should be able to serve it using a coordinate system EPSG:3857. You can check if this coordinate system is available for a particular layer by making a GetCapabilites
request to a server and examining the response. For example a WMS layer provided by Geofabrik (GetCapabilities), responds in EPSG:4326 and EPSG:900913. While EPSG:900913 and EPSG:3857 are technically the same, NextGIS Web requests data in EPSG:3857 and this particular server does not support that coordinate system.
6.6.5.1. Creating WMS Connection
To add a WMS layer you need to create a resource called WMS connection. You may create a single connection for many layers. Press Create resource button and select WMS connection (see Pic. 6.55.).
Create resource dialog for WMS connection is presented on Pic. 6.56..
Enter the name of the resource that will be displayed in the administrator interface. Not to be confused with layer name in a database. “Keyname” field is optional.
On the “Description” tab you can add any text describing the content of this connection.
On the “Metadata” tab you can enter information in the “key-value” format.
Switch to “WMS connection” tab, which is presented on Pic. 6.59..
Here enter the following WMS server connection parameters:
URL
Username
Password
Version of WMS protocol
Capabilities (manages GetCapabilities queries to the WMS Server)
URL field needs to be filled, others are used when necessary. Supported versions of WMS protocol: 1.1.1, 1.3.0
After setting up all necessery parameters, click Create.
6.6.5.2. Creating WMS Layer
Now you can add individual WMS layers. Navigate to a group where you want to create WMS layers. Press Create resource button and select WMS layer (see Pic. 6.60.).
Create resource dialog for WMS layer is presented on Pic. 6.61.
Enter display name that will be visible in administrator interface and in the map layer tree.
“Keyname” field is optional.
Tile cache settings are described in detail in this section.
On the “Description” tab you can add any text describing the content of this layer.
OIn the “Metadata” tab you can enter information in the “key-value” format.
Switch to the “WMS layer” tab, which is presented on Pic. 6.64. and perform the following steps:
Select the WMS connection that was created earlier.
Select the appropriate MIME-type from the dropdown list.
Select the required layers from the list by clicking the underlined names. You can select several layers.
In the last tab you can add vendor parameters. These are special query settings for additional functions. They vary depending on the WMS provider.
After configuring all the parameters click Create.
Warning
Identification requests to external WMS layers from Web Maps are not supported yet.
6.6.6. WMS service
NextGIS Web software can perform as WMS server. This protocol is used to provide images with a requested extent.
To deploy a WMS service you need to add a resource. Press Create resource button and select WMS service (see Pic. 6.67.).
Create resource dialog for WMS service is presented on Pic. 6.68..
Enter the name of the resource that will be displayed in the administrator interface. Do not confuse this name with a name of layers in a database.
“Keyname” field is optional.
On the “Description” tab you can add any text describing the content of this service.
On the “Metadata” tab you can enter information in the “key-value” format.
Switch to “WMS service” tab, which is presented on Pic. 6.71.. Here add links to required layers or layer styles. You can also set the min and max scale for the data visualisation.
After the resource is created, you will see a message with the WMS service URL which you can use in other software, e.g. NextGIS QGIS or JOSM. Then you need to set access permissions for the WMS service (see ngw_access_rights).
NextGIS Web layer can be added to desktop, mobile and Web GIS in different ways.
6.6.6.1. Using WMS service connection
NextGIS Web acts as a WMS server: WMS services created in NextGIS Web can be added to any software that supports WMS protocol. For that you need to know the WMS service URL. You can get it on the WMS service page. The link may look like this:
https://demo.nextgis.com/api/resource/4817/wms?
To use WMS service through GDAL utilities you need to create an XML file for the required layer. Enter these parameters to the ServerUrl string in example below. The rest remains unchanged.
<GDAL_WMS>
<Service name="WMS">
<Version>1.1.1</Version>
<ServerUrl>https://demo.nextgis.com/api/resource/4817/wms?</ServerUrl>
<SRS>EPSG:3857</SRS>
<ImageFormat>image/png</ImageFormat>
<Layers>moscow_boundary_multipolygon</Layers>
<Styles></Styles>
</Service>
<DataWindow>
<UpperLeftX>-20037508.34</UpperLeftX>
<UpperLeftY>20037508.34</UpperLeftY>
<LowerRightX>20037508.34</LowerRightX>
<LowerRightY>-20037508.34</LowerRightY>
<SizeY>40075016</SizeY>
<SizeX>40075016.857</SizeX>
</DataWindow>
<Projection>EPSG:3857</Projection>
<BandsCount>3</BandsCount>
</GDAL_WMS>
If you need an image with transparency (alpha channel) set <BandsCount>4</BandsCount>
.
Here is an example of a GDAL command. The utility gets an image by WMS from NextGIS Web and saves it to a GeoTIFF format.
$ gdal_translate -of "GTIFF" -outsize 1000 0 -projwin 4143247 7497160 \
4190083 7468902 ngw.xml test.tiff
6.6.7. TMS layer
6.6.7.1. TMS Connection
Similarly to WMS, to add a TMS layer, you first need to create a TMS connection. Press Create resource button and select TMS connection (see Pic. 6.72.)
Enter the connection name that will be displayed in the administrator interface (see Pic. 6.73.).
The “Key” field is optional. If needed, you can also add a description and metadata. In the TMS connection tab you need to select the way to connect to the TMS server - custom or via NextGIS GeoServices (see Pic. 6.74.).
In the case of a custom connection method, the user must specify the URL template, API key parameters if needed and the tile scheme used. For NextGIS GeoServices, only a custom API key is specified. After filling in all fields press Create to complete the process of creating a TMS Connection resource.
6.6.7.2. TMS layer
TMS layer resource is created using previously created TMS Connection. Press Create resource button and select TMS layer (see Pic. 6.75.).
Enter the name that will be displayed in the administrator interface (see Pic. 6.76.).
Caching provides faster rendering of Web Map layers. Tile cache settings are described in details in this section.
The main display settings are on the TMS layer tab (см. Pic. 6.77.):
TMS connection - select a TMS connection resource that was created earlier
The range of zoom levels for data display
Extent in degrees or from a layer
Tile size in pixels
After creating a TMS layer, the user can add it to the Web Map to display. No style is needed.
6.6.7.3. Using TMS service
NextGIS Web is a TMS server. Layers and styles created in it can be accessed via any software supporting TMS protocol. You will need the URL for the TMS service.
The link should look like this:
https://demo.nextgis.com/api/component/render/tile?z={z}&x={x}&y={y}&resource=234
To use TMS service through GDAL utilities you need to create an XML file. You will need the TMS link. Enter these parameters to ServerUrl string in example below. The rest remains unchanged.
<GDAL_WMS>
<Service name="TMS">
<ServerUrl>https://demo.nextgis.com/api/component/render/tile?z={z}&x={x}&y={y}&resource=234
</ServerUrl>
</Service>
<DataWindow>
<UpperLeftX>-20037508.34</UpperLeftX>
<UpperLeftY>20037508.34</UpperLeftY>
<LowerRightX>20037508.34</LowerRightX>
<LowerRightY>-20037508.34</LowerRightY>
<TileLevel>18</TileLevel>
<TileCountX>1</TileCountX>
<TileCountY>1</TileCountY>
<YOrigin>top</YOrigin>
</DataWindow>
<Projection>EPSG:3857</Projection>
<BlockSizeX>256</BlockSizeX>
<BlockSizeY>256</BlockSizeY>
<BandsCount>4</BandsCount>
<Cache />
</GDAL_WMS>
6.6.8. Tileset
To add a Tileset, select a Tileset in the “Create Resource” block of operations.
Next, you need to enter the name of the tileset, which will be displayed in the administrative web interface.
The “Key” field is optional. On the appropriate tabs, you can add a resource description and metadata. Typically, metadata is used to develop third-party applications using APIs.
In the “Tileset” tab, you need to upload a tileset in MBTiles format or a zip archive. Tiles must be in PNG or JPEG format and have a size of 256x256 pixels.
In the “Tile Cache” tab, the user can set the caching settings:
Enable - enable/disable tile caching;
Allow using tiles in non-tile requests - when requesting an image (not a tile), use cached tiles if available;
Max zoom level - the threshold value above which the cache is not accessed, the map image is rendered on the fly;
TTL, sec (Time to live) - “time to live” or storage of tiles on the server in seconds, after which the image will be re-formed at the next request. If TTL = 0, then the storage time of tiles is not limited;
Flush - write only - clears the tile cache when saving the style.
After filling in all the fields, clicking the Create button completes the process of creating the resource Tileset.
See how to add a tileset in our video:
Watch on youtube.
6.6.9. WFS Layer
WFS allows to get data published on third-party GIS servers (arcgis, geoserver etc), apply custom styles to them and add them to Web Maps.
First you need to create a WFS connection.
6.6.9.1. WFS connection
Press Create resource button and select WFS connection.
Next you can enter a custom name that will be displayed in the resource list.
“Keyname” field is optional. The “Description” and “Metadata” of the resource can be configured on the corresponding tabs.
On the “WFS connection” tab enter the parameters that will be used to connect to the WFS server providing the data:
URL
Username
Password
WFS version
If the version you selected is not supported, you’ll get an error message after pressing Create:
Next you can create WFS layer resource.
6.6.9.2. WFS Layer
WFS Layer is added using an existing WFS connection. Select the resource type in the Create resource menu.
In the opened window in the “WFS layer” tab select the WFS connection you created. Next select the layer and the geometry field. SRID will be added automatically.
In the “Resource” tab you can set a custom name for the layer. You can also enter description and metadata on the corresponding tabs.
To add a WFS layer to a Web Map, you need to create a style for it. You can create a default QGIS style or a custom QGIS or Mapserver style using “Create resource” menu.
6.6.10. WFS service
WFS layer setup is performed the same way as for WMS service but you add layers instead of styles.
Note
Currently supported filters are Intersects, ResourceId (ObjectId, FeatureId).
NextGIS Web acts as WFS server and publishes WFS services based on vector layers. Third party software can use these services to edit vector data on server. Supported WFS protocol versions are 1.0, 1.1, 2.0, 2.0.2.
To deploy a WFS service press Create resource button and select WFS service (see Pic. 6.88.).
Create resource dialog for WFS service is presented on Pic. 6.89..
Enter the name of the resource that will be displayed in the administrator interface. Do not confuse this name with a name of layers in a database.
“Keyname” field is optional.
On the “Description” tab you can add any text describing the content of this service.
On the “Metadata” tab you can enter information in the “key-value” format.
Switch to “WFS service” tab, which is presented on Pic. 6.92. and add required layers to a list (see Pic. 6.92.). For each layer you can set a limit for the number of features returned from the vector layer. By default the value is 1000. If this parameter is set to empty, the limit will be disabled and all features will be returned to the client. This may result in high server load and significant timeouts in case of large data volume.
6.6.10.1. Using WFS service
After the resource is created, a URL for the WFS service is available. You can use it in other software, for example NextGIS QGIS.
You can set access permissions for WFS service if needed. See this section for details.
WFS services can also be accessed with links of the following type (basic auth is supported):
https://mywebgis.nextgis.com/api/resource/2413/wfs?SERVICE=WFS&TYPENAME=ngw_id_2412&username=administrator&password=mypassword&srsname=EPSG:3857&VERSION=1.0.0&REQUEST=GetFeature
6.6.11. OGC API Features service
The OGC API Features service is configured in the same way as for a WFS service.
NextGIS Web acts as OGC API Features server and publishes OGC API Features services based on vector layers. Third party software can use these services to edit vector data on server. Supported OGC API Features protocol versions is 1.0.0.
To deploy a OGC API Features service press Create resource button and select OGC API Features service (see Pic. 6.93.).
Create resource dialog for OGC API Features service is presented on Pic. 6.94..
Enter the name of the resource that will be displayed in the administrator interface. Do not confuse this name with a name of layers in a database.
“Keyname” field is optional.
On the “Description” tab you can add any text describing the content of this service.
On the “Metadata” tab you can enter information in the “key-value” format.
Switch to “OGC API Features service” tab, which is presented on Pic. 6.97. and add required layers to a list (see Pic. 6.97.). For each layer you can set a limit for the number of features returned from the vector layer. By default the value is 1000. If this parameter is set to empty, the limit will be disabled and all features will be returned to the client. This may result in high server load and significant timeouts in case of large data volume.
6.6.11.1. Using OGC API Features service
After the resource is created, a URL for the OGC API Features service is available. You can use it in other software, for example QGIS.
You can set access permissions for OGC API Features service if needed. See section ngw_access_rights.
OGC API Features services can also be accessed with links of the following type (basic auth is supported):
hhttps://yourwebgis.nextgis.com/api/resource/208/ogcf