2012-10-21 20:50:44 +02:00
|
|
|
<!DOCTYPE HTML>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<title>Tilelist-viewer</title>
|
|
|
|
<style type="text/css">
|
2012-10-22 23:07:49 +02:00
|
|
|
html, body {
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
margin: 0;
|
|
|
|
font-family:sans-serif;
|
|
|
|
}
|
|
|
|
#container{
|
|
|
|
height: 100%;
|
|
|
|
background-color:#fff;
|
|
|
|
overflow:hidden;
|
|
|
|
margin:0 10px;
|
|
|
|
padding-right:250px; /* The width of the rail */
|
|
|
|
}
|
|
|
|
#menu {
|
|
|
|
text-align:center;
|
|
|
|
height: 100%;
|
|
|
|
background-color:#fff;
|
|
|
|
width:240px;
|
|
|
|
float:left;
|
|
|
|
margin-right:-250px;
|
|
|
|
font-family:sans-serif;
|
|
|
|
font-size: 0.8em;
|
|
|
|
overflow:auto;
|
|
|
|
}
|
|
|
|
#basicMap {
|
|
|
|
background-color:#fff;
|
|
|
|
width:100%;
|
|
|
|
height: 100%;
|
|
|
|
margin-right:-250px;
|
|
|
|
float:left;
|
|
|
|
font-family:sans-serif;
|
|
|
|
font-size: 0.7em;
|
|
|
|
}
|
|
|
|
#form {
|
|
|
|
background-color:#eee;
|
|
|
|
}
|
2012-10-21 20:50:44 +02:00
|
|
|
</style>
|
|
|
|
<script src="http://www.openlayers.org/api/OpenLayers.js"></script>
|
|
|
|
<script src="tilelist-viewer.js"></script>
|
|
|
|
<script type="text/javascript">
|
|
|
|
function get_xml(file){
|
|
|
|
var oRequest = new XMLHttpRequest();
|
|
|
|
oRequest.open("GET",file,false);
|
|
|
|
oRequest.setRequestHeader("User-Agent",navigator.userAgent);
|
|
|
|
oRequest.send()
|
|
|
|
return oRequest.responseXML;
|
|
|
|
}
|
|
|
|
|
|
|
|
var xmlDoc = get_xml('tiles-tree.xml');
|
|
|
|
var selectcont;
|
|
|
|
var selectcount;
|
|
|
|
var selectcregi;
|
|
|
|
var vectorLayer;
|
|
|
|
var feature;
|
|
|
|
var fromProjection = new OpenLayers.Projection("EPSG:4326"); // Transform from WGS 1984
|
|
|
|
var toProjection = new OpenLayers.Projection("EPSG:900913"); // to Spherical Mercator Projection
|
|
|
|
|
|
|
|
function setContinents(){
|
|
|
|
|
|
|
|
var el = document.createElement("option");
|
|
|
|
el.textContent = '';
|
|
|
|
el.value = '';
|
|
|
|
selectcont.appendChild(el);
|
|
|
|
var conts=xmlDoc.getElementsByTagName("continent")
|
|
|
|
for(var i = 0; i < conts.length; i++) {
|
|
|
|
opt = conts[i].getAttribute("name");
|
|
|
|
el = document.createElement("option");
|
|
|
|
el.textContent = opt;
|
|
|
|
el.value = opt;
|
|
|
|
selectcont.appendChild(el);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function setCountries(cont){
|
|
|
|
selectcount.options.length = 0;
|
|
|
|
selectregi.options.length = 0;
|
|
|
|
|
|
|
|
var el = document.createElement("option");
|
|
|
|
el.textContent = '';
|
|
|
|
el.value = '';
|
|
|
|
selectcount.appendChild(el);
|
|
|
|
|
|
|
|
var conts=xmlDoc.getElementsByTagName("continent");
|
|
|
|
for(var i = 0; i < conts.length; i++) {
|
|
|
|
if (conts[i].getAttribute("name") == cont){
|
|
|
|
counts=conts[i].getElementsByTagName("country");
|
|
|
|
for(var j = 0; j < counts.length; j++) {
|
|
|
|
opt = counts[j].getAttribute("name");
|
|
|
|
el = document.createElement("option");
|
|
|
|
el.textContent = opt;
|
|
|
|
el.value = opt;
|
|
|
|
selectcount.appendChild(el);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function setRegions(count){
|
|
|
|
selectregi.options.length = 0;
|
|
|
|
|
|
|
|
var el = document.createElement("option");
|
|
|
|
el.textContent = '';
|
|
|
|
el.value = '';
|
|
|
|
selectregi.appendChild(el);
|
|
|
|
|
|
|
|
var counts=xmlDoc.getElementsByTagName("country");
|
|
|
|
for(var j = 0; j < counts.length; j++) {
|
|
|
|
if (counts[j].getAttribute("name") == count){
|
|
|
|
regis=counts[j].getElementsByTagName("region");
|
|
|
|
for(var k = 0; k < regis.length; k++) {
|
|
|
|
var opt = regis[k].getAttribute("name");
|
|
|
|
var el = document.createElement("option");
|
|
|
|
el.textContent = opt;
|
|
|
|
el.value = opt;
|
|
|
|
selectregi.appendChild(el);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
function show(){
|
|
|
|
continent=selectcont.value;
|
|
|
|
country=selectcount.value;
|
|
|
|
region=selectregi.value;
|
|
|
|
if (continent != '' && country!= '' && region != '') {
|
|
|
|
list=getTilelist(continent,country,region);
|
|
|
|
}
|
|
|
|
else if (continent != '' && country!= '' && region == '') {
|
|
|
|
list=getTilelist(continent,country, '');
|
|
|
|
}
|
2012-10-22 23:07:49 +02:00
|
|
|
document.getElementById('tiles').innerHTML =list;
|
2012-10-21 20:50:44 +02:00
|
|
|
// remove features
|
|
|
|
var x;
|
|
|
|
var y;
|
|
|
|
var lonlat;
|
|
|
|
for(var i = 0; i < list.length; i++) {
|
|
|
|
x = parseFloat(list[i].split(' ')[0]);
|
|
|
|
y = parseFloat(list[i].split(' ')[1]);
|
|
|
|
|
|
|
|
if (i==0) {var center = new OpenLayers.LonLat(x,y).transform( fromProjection, toProjection);}
|
|
|
|
|
|
|
|
geom = new OpenLayers.Geometry.LinearRing();
|
|
|
|
|
|
|
|
geom.addComponent(new OpenLayers.Geometry.Point(x,y))
|
|
|
|
geom.addComponent(new OpenLayers.Geometry.Point(x,y+1))
|
|
|
|
geom.addComponent(new OpenLayers.Geometry.Point(x+1,y+1))
|
|
|
|
geom.addComponent(new OpenLayers.Geometry.Point(x+1,y))
|
|
|
|
geom.addComponent(new OpenLayers.Geometry.Point(x,y))
|
|
|
|
feature = new OpenLayers.Feature.Vector(geom.transform(fromProjection,toProjection));
|
|
|
|
vectorLayer.addFeatures([feature]);
|
|
|
|
}
|
|
|
|
map.setCenter(center, map.getZoom() );
|
|
|
|
//~ vectors.addFeatures([new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(lonLat))]);
|
|
|
|
|
|
|
|
}
|
|
|
|
function getTilelist(continent,country,region){
|
|
|
|
var tilelist='';
|
|
|
|
var conts=xmlDoc.getElementsByTagName("continent");
|
|
|
|
for(var i = 0; i < conts.length; i++) {
|
|
|
|
if (conts[i].getAttribute("name") == continent){
|
|
|
|
var counts=conts[i].getElementsByTagName("country");
|
|
|
|
for(var j = 0; j < counts.length; j++) {
|
|
|
|
if (counts[j].getAttribute("name") == country){
|
|
|
|
if (region == '') {
|
|
|
|
tilelist=counts[j].getElementsByTagName("tiles")[0].childNodes[0].nodeValue.split(';');
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
regis=counts[j].getElementsByTagName("region");
|
|
|
|
for(var k = 0; k < regis.length; k++) {
|
|
|
|
if (regis[k].getAttribute("name") == region){
|
|
|
|
tilelist=regis[k].getElementsByTagName("tiles")[0].childNodes[0].nodeValue.split(';');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return tilelist
|
|
|
|
}
|
|
|
|
|
|
|
|
function init() {
|
|
|
|
|
|
|
|
selectcont = document.getElementById("continents");
|
|
|
|
selectcount = document.getElementById("countries");
|
|
|
|
selectregi = document.getElementById("regions");
|
|
|
|
setContinents();
|
|
|
|
map_init();
|
|
|
|
}
|
|
|
|
|
|
|
|
function map_init() {
|
|
|
|
var options = {
|
|
|
|
controls: [
|
|
|
|
new OpenLayers.Control.Navigation(),
|
|
|
|
new OpenLayers.Control.PanZoomBar(),
|
|
|
|
new OpenLayers.Control.Attribution(),
|
|
|
|
new OpenLayers.Control.Graticule({
|
|
|
|
labelled: true,
|
|
|
|
labelformat: 'd',
|
|
|
|
targetSize: 200
|
|
|
|
})
|
|
|
|
]
|
|
|
|
};
|
|
|
|
map = new OpenLayers.Map("basicMap", options);
|
|
|
|
var mapnik = new OpenLayers.Layer.OSM();
|
|
|
|
var position = new OpenLayers.LonLat(5,46).transform( fromProjection, toProjection);
|
|
|
|
var zoom = 3;
|
|
|
|
|
|
|
|
map.addLayer(mapnik);
|
|
|
|
|
|
|
|
vectorLayer = new OpenLayers.Layer.Vector( "vectors");
|
|
|
|
map.addLayers([vectorLayer])
|
|
|
|
|
|
|
|
map.setCenter(position, zoom );
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</head>
|
2012-10-22 23:07:49 +02:00
|
|
|
<body onload="init();">
|
|
|
|
<div id="container">
|
|
|
|
<div id="basicMap"></div>
|
2012-10-21 20:50:44 +02:00
|
|
|
<div id="menu">
|
2012-10-22 23:07:49 +02:00
|
|
|
<div id="form">
|
|
|
|
<hr>
|
|
|
|
Choose a region below:</br>
|
|
|
|
<form>
|
|
|
|
<select id="continents" onchange="setCountries(this.value);"></select></br>
|
|
|
|
<select id="countries" onchange="setRegions(this.value);"></select></br>
|
|
|
|
<select id="regions"></select></br>
|
|
|
|
<input type="button" value="Show" onclick="show();"></br>
|
|
|
|
</form>
|
|
|
|
<hr>
|
|
|
|
<!--
|
|
|
|
Right-click on tile to add to or remove from the tile list:
|
|
|
|
-->
|
|
|
|
<hr>
|
|
|
|
</div>
|
|
|
|
<div id="tiles"></div>
|
2012-10-21 20:50:44 +02:00
|
|
|
</div>
|
2012-10-22 23:07:49 +02:00
|
|
|
</div>
|
|
|
|
</body>
|
2012-10-21 20:50:44 +02:00
|
|
|
</html>
|