forked from rob-murray/os-leaflet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
OSOpenSpace.js
138 lines (123 loc) · 5.57 KB
/
OSOpenSpace.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/**
* os-leaflet ; A [Leafletjs](http://leafletjs.com/) TileLayer to display Ordnance Survey
* data in your Leaflet map via the OS OpenSpace web map service.
*
* https://github.com/rob-murray/os-leaflet
*/
(function (root, factory) {
// UMD for Node, AMD or browser globals
if (typeof define === 'function' && define.amd) {
// AMD. Register as an anonymous module.
define(['leaflet', 'proj4leaflet'], factory);
} else if (typeof exports === 'object') {
// Node & CommonJS-like environments.
var L = require('leaflet'); // eslint-disable-line vars-on-top
require('proj4leaflet');
module.exports = factory(L);
} else {
// Browser globals
if (typeof window.L === 'undefined') {
throw new Error('Leaflet missing');
}
root.returnExports = factory(root.L);
}
}(this, function (L) {
/* This is our namespace for OSOpenSpace on Leaflet js */
L.OSOpenSpace = L.OSOpenSpace || {};
L.OSOpenSpace.CRS = L.extend(
new L.Proj.CRS(
'EPSG:27700',
'+proj=tmerc +lat_0=49 +lon_0=-2 +k=0.9996012717 +x_0=400000 +y_0=-100000 +ellps=airy +datum=OSGB36 +units=m +no_defs', {
resolutions: [2500, 1000, 500, 200, 100, 50, 25, 10, 5, 2.5]
}
), {
distance: function (a, b) {
return L.CRS.Earth.distance(a, b);
}
}
);
L.OSOpenSpace.LogoControl = L.Control.extend({
options: {
position: 'bottomleft'
},
onAdd: function () {
var container = L.DomUtil.create('div', 'os-logo-control');
var logoImage = L.DomUtil.create('img', '', container);
logoImage.title = 'Powered by OS OpenSpace';
logoImage.src = '';
return container;
}
});
/**
* A custom Layer for Ordnance Survey OpenSpace service.
* Note: An API key is needed, see OS website for details
*
*/
L.OSOpenSpace.TileLayer = L.TileLayer.WMS.extend({
initialize: function (apiKey, apiUrl, options) { // (String, String, Object)
if (!apiKey) {
throw new Error('OSOpenSpace layer requires an API Key parameter to function.');
}
apiUrl = typeof apiUrl !== 'undefined' ? apiUrl : 'file:///';
L.TileLayer.WMS.prototype.initialize.call(this,
'https://openspace.ordnancesurvey.co.uk/osmapapi/ts', {
crs: L.OSOpenSpace.CRS,
maxZoom: 14,
minZoom: 0,
tileSize: 200
},
options
);
this.wmsParams = {
KEY: apiKey,
FORMAT: 'image/png',
URL: apiUrl,
REQUEST: 'GetMap',
WIDTH: this.options.tileSize,
HEIGHT: this.options.tileSize
};
},
getAttribution: function () {
return '© Crown copyright and database rights ' +
new Date().getFullYear() +
' Ordnance Survey. ' +
'<a target="_blank" ' +
'href="http://www.ordnancesurvey.co.uk/oswebsite/web-services/os-openspace/developer-agreement.html" ' +
'title="OS OpenSpace Terms of Use">' +
'Terms of Use</a>.';
},
onAdd: function (map) {
if (map.options.attributionControl) {
map.addControl(new L.OSOpenSpace.LogoControl());
}
L.TileLayer.prototype.onAdd.call(this, map);
},
/**
* Return a url for this tile.
* Calculate the bbox for the tilePoint and format the wms request
*/
getTileUrl: function (tilePoint) { // (Point, Number) -> String
var resolutionMpp = this.options.crs.options.resolutions[tilePoint.z],
tileSizeMetres = this.options.tileSize * resolutionMpp,
tileBboxX0 = tileSizeMetres * tilePoint.x,
tileBboxY0 = tileSizeMetres * (-1 - tilePoint.y); // TODO: Is there a missing transformation ? tilePoint appears to be topLeft in this config
// service is a tile based wms format and only requires x0, y0 - ignore other points
this.wmsParams.BBOX = [tileBboxX0, tileBboxY0, 0, 0].join(',');
this.wmsParams.LAYERS = resolutionMpp;
return this._url + L.Util.getParamString(this.wmsParams); // eslint-disable-line no-underscore-dangle
}
});
/*
* Factory method to create a new OSOpenSpace tilelayer.
*
* @public
* @param {string} apiKey Your API key for OSOpenSpace.
* @param {string} apiUrl The URL of your site as provided to OSOpenSpace.
* @param {object} options Any options to pass to the tilelayer.
* @return {L.TileLayer} TileLayer for Ordnance Survey OpenSpace service.
*/
L.OSOpenSpace.tilelayer = function (apiKey, apiUrl, options) {
return new L.OSOpenSpace.TileLayer(apiKey, apiUrl, options);
};
return L.OSOpenSpace;
}));