Project

General

Profile

1
Metacat's Use of Geoserver
2
==========================
3

    
4
GeoServer 2.0.2, an open source Web Mapping Service (WMS) written in Java, is 
5
bundled with Metacat and can be used to render spatial data as web-deliverable 
6
maps. Metacat uses OpenLayers (http://openlayers.org/) to provide a web-based 
7
user interface for interacting with the generated maps. You can use any 
8
WMS-compatible client (e.g., ArcGIS, QGIS, JUMP, UDig, OpenLayers, Mapbender, 
9
Map Builder). 
10

    
11
IMPORTANT: Regardless of whether you plan on using the mapping functionality 
12
you should, for security purposes, configure GeoServer so that it doesn't 
13
use the default password. For instructions, please see 
14
Geoserver Configuration.
15

    
16
.. figure:: images/screenshots/image051.jpg
17
   :align: center
18
   
19
   A map generated by Metacat's GeoServer. Points and "bounding boxes" 
20
   represent the geographic extent of datasets stored in the KNB Metacat repository.
21

    
22
GeoServer supports a wide variety of vector GIS data sources, which can be 
23
styled using Styled Layer Descriptors (SLDs) and output as images (the default) 
24
or raw vector data (GML or KML).
25

    
26
Currently, GeoServer can be used with the following limitations:
27

    
28
* GeoServer will only map documents that are publicly available. This is 
29
  because the mapping server's support for permissions control is not as 
30
  fine-grained as Metacat's.
31

    
32
Metacat developers plan to continue extending and improving Metacat's mapping 
33
capabilities. If you are interested in contributing to those efforts, or if 
34
you are interested in learning more about the architecture and future plans for 
35
the mapping software, please contact the Metacat  development 
36
team  (metacat-dev@ecoinformatics.org).
37

    
38
Installing and Configuring
39
--------------------------
40
The GeoServer webapp should be installed as a sibling of Metacat. If you do 
41
NOT wish to run GeoServer, the deployment can be skipped, but any skins that 
42
use maps will not render correctly. (NOTE: Geoserver recommends using a PermGen 
43
space setting of at least 128MB.). 
44

    
45
Metacat comes with a pre-configured data directory to be used by GeoServer. 
46
This includes a world-countries base layer and a default configuration that 
47
is already aware of Metacat's spatial cache. The Metacat configuration interface 
48
is used to configure GeoServer to use this shared data directory. To further 
49
configure GeoServer, use the Web-based configuration utility, 
50
which is available at: http://your.server.com/<geoserver_context>
51
(e.g., http://knb.ecoinformatics.org/geoserver). 
52

    
53
Common configuration tasks include:
54

    
55
* Adding a Map to a Web Page or Skin
56
* Configuring the Size and Initial Extent of the Map
57
* Configuring the Layout of the HTML Mapping Interface
58
* Configuring the "Select Location Drop-down Menu
59
* Configuring the Visual Portrayal of Geospatial Data (e.g., symbology and color)
60
* Adding Other Spatial Datasets to the Web Map
61

    
62
.. figure:: images/screenshots/image053.png
63
   :align: center
64
   
65
   GeoServer's Web-based administrative interface.
66

    
67
Note: Some configurations may need to be made to the XML files as well.
68

    
69
OpenLayers, which Metacat uses as the front-end for GeoServer's WMS service, 
70
provides interface components or "widgets" (e.g., the map, a box zoom, layer 
71
list, "Select Location" drop-down menu, scale bar, lat/long coordinates, and 
72
a query form) that make it easy to deploy web-based mapping applications with 
73
minimal coding.
74

    
75
OpenLayers has three main configuration files used to customize the map interface.
76
Default configurations are in::
77

    
78
  $METACAT/lib/style/common/spatial/
79
  
80
+----------------------------------+---------------+-------------------------------------------------------------+
81
| Document                         | Location      | Description                                                 |
82
+==================================+===============+=============================================================+
83
| The named location file          | locations.jsp | The list of pre-defined locations (name and lat/lon bounds) |
84
+----------------------------------+---------------+-------------------------------------------------------------+
85
| Main map rendering functions     | maps.js       | Defines the map, widgets and their behavior                 |
86
+----------------------------------+---------------+-------------------------------------------------------------+
87
| The rendered map and page layout | map.jsp       | Loads the map and controls the HTML layout of the widgets.  |
88
+----------------------------------+---------------+-------------------------------------------------------------+
89

    
90
NOTE: By default, the first time Metacat is restarted, it generates a 
91
"spatial cache" containing geographic information about documents in its 
92
repository. This default behavior is specified in lib/metacat.properties, 
93
where the regenerateCacheOnRestart parameter is set to true. The information 
94
in the spatial cache is stored in a GIS-compatible format (the ESRI Shapefile) 
95
and consists of the document name and its geographic coverage. When documents 
96
are inserted, deleted, and updated in the Metacat repository, Metacat 
97
automatically syncs the spatial cache to reflect the changes. Because 
98
generating the cache can take a considerable amount of time (several minutes 
99
in the case of a few thousand documents), Metacat resets the 
100
regenerateCacheOnRestart property to false after the spatial cache has been 
101
generated. Note that if you upgrade or reinstall Metacat, the spatial cache 
102
will be regenerated again.
103

    
104
Adding a Map to a Web Page or Skin
105
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
106
To add a map to a Web page, simply include the map interface using an iframe:: 
107

    
108
  <iframe scrolling="no" frameborder="0" width="780" height="420" 
109
          src="/metacat/style/common/spatial/map.jsp">
110
  </iframe>
111

    
112
The map URL, ``/metacat/style/common/spatial/map.jsp``, is 
113
the default map interface. If you plan to customize the map interface, copy
114
the map.jsp file into your skin's directory (either the default or 
115
customized skin directory). 
116

    
117
::
118

    
119
  cp -r style/common/spatial/map.jsp /style/skins/<myskin>/spatial
120

    
121
You can access the customized map with the URL: ``/metacat/style/skins/<myskin>/spatial/map.jsp`` 
122

    
123
Configuring the Size and Initial Extent of the Map
124
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
125
Before you configure the size and initial extent of the map, make sure that you 
126
have copied the map layout page into your skin's directory (See 
127
:doc:`configuration` for directions). Once the file has been copied, you can 
128
modify the map's initial extent in: ``${skin.dir}/spatial/map.jsp``.
129

    
130
To change the map's initial extent, edit the bounding box. The default is to 
131
show the entire globe. The ``initMap()`` function should also be given the skin 
132
name so that spatial search results can be correctly styled.
133

    
134
::
135

    
136
  <script type="text/javascript">
137
      function init() {
138
         var bounds = new OpenLayers.Bounds(-180,-90,180,90); 
139
         // make the map for this skin 
140
         initMap("<%=GEOSERVER_URL%>", "<%=SERVLET_URL%>", "default", bounds);
141
      }
142
  </script>
143

    
144
The size (height/width) of the map can be controlled by the ``#map`` CSS entry 
145
included in the ``map.jsp`` page.
146

    
147
Configuring the Layout of the HTML Mapping Interface
148
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
149
The size and initial extent of the map can be edited in : ${skin.dir}/spatial/map.jsp.
150

    
151
The map.jsp is a simple container that can be included in other more complex 
152
pages if desired. It contains the map, widgets and location dropdown list.
153

    
154
Configuring the "Select Location" Drop-down Menu
155
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
156
The locations that appear in the "Select Location" drop-down menu are specified 
157
in the ``locations.jsp`` file. The locations.jsp can be copied from the common 
158
spatial template into your skin directory. Each location is defined as an 
159
HTML ``<option/>`` tag. Edit the value and label to edit or add new locations.
160

    
161
::
162

    
163
  <option value="-149.725,68.475 -149.3254,68.725"> Arctic LTER (ARC)</option>
164

    
165
Configuring the Visual Portrayal of Geospatial Data (e.g., symbology and color)
166
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
167
Geospatial data sets are styled through the use of Styled Layer Descriptors 
168
(SLD). The default SLDs used for the data points and data bounding boxes are in
169
``/lib/spatial/geoserver/data/styles/`` and are named data_points_style.sld and 
170
data_bounds_style.sld, respectively. 
171

    
172
You can find a more detailed tutorial on using SLD with GeoServer in the GeoServer documentation::
173

    
174
  http://docs.geoserver.org/
175

    
176
Adding Other Spatial Datasets to the Web Map
177
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
178
If you have vector GIS data sets, such as weather or topographical information, 
179
on your server that you'd like to include in the interactive map, you must 
180
first register the data set with GeoServer. After the data set has been 
181
registered, you can add the layer to the map. You can also add spatial layers 
182
that have been made publically available through WMS (There are hundreds of 
183
spatial data sets available. Check out wms-sites.com for good catalog). 
184
Instructions for adding publically available layers are included at the end 
185
of this section. 
186

    
187
To register the data set and add it to the map:
188

    
189
1. Point your browser to ``http://your.server/geoserver``, log in to GeoServer, 
190
   and navigate to the "Data Stores" configuration page under ``Data > Stores``. 
191
2. Create a new vector data source from a Shapefile in the "metacat" workspace.
192

    
193
.. figure:: images/screenshots/image055.png
194
   :align: center
195
   
196
   Creating a new shapefile using GeoServers web-based administrative interface.
197

    
198
3. The Description, if specified, is mostly used internally to provide other 
199
   administrators with information about the DataStore. Click Submit.
200
4. Navigate to the "Layers" configuration page under Data > Layers. 
201
   Add a new Layer from your new data source.
202
5. You should also define a spatial reference system (SRS) number for the new 
203
   layer. Most lat/long data is "4326". If your data is in another projection, 
204
   determine its spatial reference system using the help links provided.
205

    
206
.. figure:: images/screenshots/image057.png
207
   :align: center
208
   
209
   GeoServer's FeatureType configuration. The SRS settings discussed in step 5 are highlighted.
210

    
211
6. Style the layer using a style from the drop-down menu on the Publishing tab, 
212
   or create a new SLD to create a new style object and corresponding SLD 
213
   (this option provides more control over the style). 
214
7. Try out the styled data set as a WMS layer using a the Layer Preview.
215

    
216
.. figure:: images/screenshots/image058.png
217
   :align: center
218
   
219
   GeoServer's Layer Preview allows you to see an OpenLayer rendering of the new layer.
220

    
221
8. Copy the default ``map.js`` file that assembles the map in OpenLayers 
222
   (``style/common/spatial/map.js``) to your skin's spatial directory.
223
9. Edit the init() method to include your new layer in the map - either as an 
224
   overlay or as a base layer.
225
10. Point your browser to the map interface. Your new layer should appear with 
226
    the existing ones.
227

    
228
Adding External Spatial Data Made Publically Available through WMS
229
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
230
There are hundreds of sources of spatial data made publically available 
231
through WMS (check out http://wms-sites.com for a good catalog). To add these 
232
data sources to your map, add the layers in your skin's ``spatial/map.js`` file.
233

    
234
Spatial Queries
235
---------------
236
To find out which documents in the Metacat repository lie in a specified 
237
geographic region, query the spatial cache using Metacat's spatial_query action. 
238
Metacat can perform any query supported by the WFS/WMS standards.
239

    
240
An example of a spatial query string is::
241

    
242
  http://localhost/metacat/metacat?action=spatial_query&xmin=-117.5&xmax=-64&ymin=3&ymax=46&skin=default
243

    
244
Where ``xmin``, ``xmax``, ``ymin`` and ``ymax`` represent the western, eastern, 
245
southern and northern bounding coordinates (the "bounding box"), respectively. 
246
The spatial query action returns all documents that overlap or that are 
247
contained inside the specified spatial coordinates. The result set is returned 
248
as HTML using the style of the specified skin (in this example, default).
249

    
(9-9/25)