index.html
<!DOCTYPE html>
<html>
<head>
<title>Regional elections 2013, Chairman - 2nd round</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="initial-scale=1.0, user-scalable=no"/>
<script src="//code.jquery.com/jquery-1.8.2.min.js"></script>
<script>
L_PREFER_CANVAS = true;
</script>
<link rel="stylesheet" href="//netdna.bootstrapcdn.com/bootstrap/3.0.2/css/bootstrap.min.css">
<link rel="stylesheet" href="//cdn.leafletjs.com/leaflet-0.6.4/leaflet.css" />
<script src="//cdn.leafletjs.com/leaflet-0.6.4/leaflet.js"></script>
<style type="text/css">
html, body, #map {
width: 100%;
height: 100%;
margin: 0;
padding: 0;
}
.marian-kotleba {
color: #080;
}
.smer {
color: #f00;
}
.jozsef-berenyi {
color: #0b0;
}
.pavol-freso, .tomas-galbavy {
color: #00b;
}
.rudolf-bauer{
color: #808;
}
</style>
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top" role="navigation">
<div class="container">
<div class="navbar-header">
<a class="navbar-brand" href="#">Regional elections 2013, Chairman - 2nd round</a>
</div>
</div>
</div>
<div style="position:fixed;top:50px;z-index:1000;">
<div class="alert alert-info" >The <strong>size</strong> of bubbles represents number of voters, the <strong>color</strong> represents the winner and the <strong>oppacity</strong> the margin of victory.</div>
<div class="alert alert-info" style="width:50%">
Banská Bystrica: <span class="marian-kotleba">Kotleba</span> vs. <span class="smer">Maňka</span><br/>
Bratislava: <span class="pavol-freso">Frešo</span> vs. <span class="smer">Flašíková-Beňová</span><br/>
Košice: <span class="smer">Trebuľa</span> vs. <span class="rudolf-bauer">Bauer</span><br/>
Nitra: <span class="smer">Belica</span> vs. <span class="tomas-galbavy">Galbavý</span><br/>
Trnava: <span class="smer">Mikuš</span> vs. <span class="jozsef-berenyi">Berényi</span><br/>
</div>
</div>
<div id="map" style="margin-top:40px;"></div>
<script type="text/javascript">
var map = L.map('map',{zoomControl: false}).setView([48.695493,19.467773], 8);
map.addControl( L.control.zoom({position: 'topright'}) );
L.tileLayer('//{s}.www.toolserver.org/tiles/bw-mapnik/{z}/{x}/{y}.png', {
attribution: '© <a href="//osm.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map);
$.getJSON( "sk_vuc_2013_2_ring.json", function (data) {
$.each(data.features, function (index, value) {
circle = L.circle([value.coordinates[1], value.coordinates[0]], Math.sqrt((parseInt(value.population.p6)+parseInt(value.population.p9))*2750), {
color: class2color(value.classname),
fillColor: class2color(value.classname),
fillOpacity: 2*(Math.max(parseInt(value.population.p6),parseInt(value.population.p9)) / (parseInt(value.population.p6)+parseInt(value.population.p9)) - 0.45),
weight: 0.1,
className: value.classname,
}).addTo(map);
perc1 = Math.round(Math.max(parseInt(value.population.p6),parseInt(value.population.p9)) / (parseInt(value.population.p6)+parseInt(value.population.p9)) * 100);
perc2 = 100 - perc1;
circle.bindPopup(value.name + "<br>" + value.winner + " vyhral/a " + perc1 + " % vs. " + perc2 + " % <br>(" +Math.max(value.population.p6,value.population.p9) + " : " + Math.min(value.population.p6,value.population.p9) + " hlasov)");
});
});
function class2color(className) {
if (className == 'marian-kotleba') return "#040";
if (className == 'jozsef-berenyi') return "#0b0";
if (className == 'rudolf-bauer') return "#808";
if ((className == 'pavol-freso') | (className == 'tomas-galbavy')) return "#00b";
else return "#f00";
}
</script>
</body>
</html>