function fmod (x, y) { // discuss at: https://locutus.io/php/fmod/ // original by: Onno Marsman (https://twitter.com/onnomarsman) // input by: Brett Zamir (https://brett-zamir.me) // bugfixed by: Kevin van Zonneveld (https://kvz.io) // example 1: fmod(5.7, 1.3) // returns 1: 0.5 let tmp let tmp2 let p = 0 let pY = 0 let l = 0.0 let l2 = 0.0 tmp = x.toExponential().match(/^.\.?(.*)e(.+)$/) p = parseInt(tmp[2], 10) - (tmp[1] + '').length tmp = y.toExponential().match(/^.\.?(.*)e(.+)$/) pY = parseInt(tmp[2], 10) - (tmp[1] + '').length if (pY > p) { p = pY } tmp2 = (x % y) if (p < -100 || p > 20) { // toFixed will give an out of bound error so we fix it like this: l = Math.round(Math.log(tmp2) / Math.log(10)) l2 = Math.pow(10, l) return (tmp2 / l2).toFixed(l - p) * l2 } else { return parseFloat(tmp2.toFixed(-p)) } } const TAILLE_SPRITE = 32; var places = document.getElementsByClassName('place'); var map = document.getElementById('map'); var origLat = map.getAttribute('data-orig-lat'); var origLon = map.getAttribute('data-orig-lon'); var radius = map.getAttribute('data-radius'); function computeLatDistanceInKm (dest, orig) { // Approximation française return ((dest - orig) * 111); } function computeLonDistanceInKm (dest, orig) { // Approximation française return ((dest - orig) * 79); } // Position places on map for (place of places) { var placeLat = place.getAttribute("data-place-lat"); var placeLon = place.getAttribute("data-place-lon"); var latDistanceKm = computeLatDistanceInKm(placeLat, origLat); var lonDistanceKm = computeLonDistanceInKm(placeLon, origLon); var latDistancePcts = latDistanceKm / (2 * radius) * 100; var lonDistancePcts = lonDistanceKm / (2 * radius) * 100; var leftPcts = 50 + lonDistancePcts; var topPcts = 50 - latDistancePcts; var cssLeft = 'calc(' + leftPcts + '% - ' + (TAILLE_SPRITE / 2) + 'px)'; var cssTop = 'calc(' + topPcts + '% - ' + (TAILLE_SPRITE / 2) + 'px)'; place.style.left = cssLeft; place.style.top = cssTop; }