Skip to content

Latest commit

 

History

History
195 lines (148 loc) · 6.64 KB

README.md

File metadata and controls

195 lines (148 loc) · 6.64 KB

FOSS IOW GIS

This project is created as an academic assignment for the SDI Module on CU. The website incorporates a number of proprietary and free GIS mapping solutions.

The site is created to present a prototype website to showcase the possible transformation from the currently used proprietary web mapping tools used by the IoW Council to free and open-source alternatives.

Approach

The site generation is implemented in Jekyll. The layout is generated with the Liquid template language. Hosted on Github Pages, the layout is based on Bootstrap and jQuery and inspired by the Clean blog Bootstrap theme by David Miller.

Maps as a collection

Each map is stored in a Jekyll Collection, therefore the pages presenting the various maps are created using for loops, such as:

{% for map in site.maps %}
    {% map.sample_content %}
{% endfor %}

Map variables

The maps have several variables that are utilized later. An important variable is the map type, that can be either "current" or "proposed".

An example of using this variable is as follows:

{% assign current_map = site.maps | where:"type","current" %}
{% for map in current_map limit:3 %}
    {% include map_list.html %}
{% endfor %}

A rather comprehensive example is the use of Bootstrap Popovers to show information about the maps in the map list at a glance by hovering above the picture.

<a href="{{ map.url }}" data-toggle="popover" data-html="true" data-trigger="hover" data-placement="top"
data-content="<b>Map type:</b> {{ map.application }} <br />
<b>Layer(s):</b> {{ map.layer }} <br />
<b>Base layer:</b> {{ map.base_layer }} <br />
<b>Description:</b> {{ map.purpose }}" title="Map details"><img src="{{ site.baseurl }}/img/{{ map.img }}" alt="{{ map.title }}"></a>

alt text

Global variables

The site also makes use of Jekyll "global" variables, and stores them in the configuration file. Later these variables are used as:

{{ site.gm_api_key }}

This way the Google maps API key can be referenced from every page of the site that requires it.

Modular html files

The site is created with modular design approach, therefore to avoid repetition, the common elements are included in the following way:

{% include secure_warning.html %}

An example is the following warning:

alt text

Custom functions

A set of custom functions were implemented to control layers from Google Maps and OpenLayers. This includes toggle buttons:

alt text

function toggleLayers(layer, div) {
if (layer.getMap() == map) {
layer.setMap(null);
document.getElementById(div).className += "btn btn-default";
} else {
layer.setMap(map);
document.getElementById(div).className += "btn btn-default active";
}
}

Controlled by the buttons:

<div class="row" style="margin-bottom:20px">
    <button id="mastPylonButton" type="button" class="btn btn-default active" onclick="toggleLayers(mastpylon, this.id);">Toggle masts and pylons</button>
    <button id="elecSubButton" type="button" class="btn btn-default active" onclick="toggleLayers(elsubstation, this.id);">Toggle electricity sub stations</button>
    <button id="elecPoleButton" type="button" class="btn btn-default active" onclick="toggleLayers(elpoles, this.id);">Toggle electricity poles</button>
</div>

And buttons to control layer opacity:

alt text

The buttons can be controlled via the Javascript functions:

// Increasing layer opacity.
function increaseLayerOpacity(layer) {
console.log(layer.getOpacity());
	if (layer.getOpacity()<0.91) {
		layer.setOpacity(layer.getOpacity() + 0.1);
console.log(layer.getOpacity());
}
}

// Decreasing layer opacity.
function decreaseLayerOpacity(layer) {
console.log(layer.getOpacity());
	if (layer.getOpacity()>0.09) {
		layer.setOpacity(layer.getOpacity() - 0.1);
console.log(layer.getOpacity());
}
}

And the functions are called by the HTML elements:

<strong>Flood area opacity:</strong>
<button type="button" class="btn btn-default" onclick="increaseLayerOpacity(flood);">+</button>
<button type="button" class="btn btn-default" onclick="decreaseLayerOpacity(flood);">-</button>

Used mapping tools and base layer providers

Proprietary tools used:

  • ESRI ArcGIS Online
  • ArcGIS Web App
  • ESRI server

Tools with available free plans:

  • Google maps
  • CartoDb
  • ArcGIS JS API
  • MapBox
  • Bing Maps

Open-Source tools:

  • OpenLayers
  • LeafletJS
  • OpenStreetMap

Site structure

Home

The home page intends to present the project and to give a short introduction about the current state of web mapping tools used by the Isle of Wight. In addition the general description of the proposed web mapping solutions is explained.

alt text

Current maps

The current maps page shows a list of the current maps. alt text

Proposed maps

The proposed maps page shows a list of the proposed maps to the Isle of Wight Council in the same layout as the current maps page.

Tourist maps

The tourist map page shows a proposed image map for the Isle of Wight with tourist information. The destinations are presented with Bootstrap Modals. alt text

Filter

The filter page shows the current and proposed maps categorized by the layer data source and the used web mapping technology. alt text

Warning

Modern browsers do not allow HTTP requests in sites using HTTPS. Since Github Pages uses HTTPS and the CU server uses HTTP, some requests are blocked. To overcome this issue, the following approach is suggested:

Start Google Chrome with allowed insecure content:

On *nix systems:

google-chrome --allow-running-insecure-content

On Windows:

"C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" --allow-running-insecure-content

Please make sure to close every chrome instance before, otherwise chrome will just start a new tab in the current session.

To examine the project locally:

  • Clone or download the repository
  • Install Ruby and Jekyll
  • Cd into the folder
  • Start the server with 'jekyll serve --watch'
  • Navigate to 127.0.0.1:4000

License

MIT license.