From: John Firebaugh Date: Wed, 24 Jul 2013 00:30:24 +0000 (-0700) Subject: Refactor URL generating methods X-Git-Tag: live~4819^2~4 X-Git-Url: https://git.openstreetmap.org/rails.git/commitdiff_plain/b5800b4c2f51e265b51f6b0cd45728b8d7db86aa Refactor URL generating methods --- diff --git a/app/assets/javascripts/application.js b/app/assets/javascripts/application.js index 44858506b..e54498834 100644 --- a/app/assets/javascripts/application.js +++ b/app/assets/javascripts/application.js @@ -120,65 +120,6 @@ function updatelinks(loc, zoom, layers, bounds, object) { } } -function getShortUrl(map) { - return (window.location.hostname.match(/^www\.openstreetmap\.org/i) ? - 'http://osm.org/go/' : 'http://' + window.location.hostname + '/go/') + - makeShortCode(map); -} - -function getUrl(map) { - var center = map.getCenter(), - zoom = map.getZoom(), - toZoom = zoomPrecision(zoom); - - return (window.location.hostname.match(/^www\.openstreetmap\.org/i) ? - 'http://openstreetmap.org/?' : 'http://' + window.location.hostname + '/?') + - querystring.stringify({ - lat: toZoom(center.lat), - lon: toZoom(center.lng), - zoom: zoom, - layers: map.getLayersCode() - }); -} - -// Called to create a short code for the short link. -function makeShortCode(map) { - var zoom = map.getZoom(), - str = '', - char_array = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_~", - x = Math.round((map.getCenter().lng + 180.0) * ((1 << 30) / 90.0)), - y = Math.round((map.getCenter().lat + 90.0) * ((1 << 30) / 45.0)), - // JavaScript only has to keep 32 bits of bitwise operators, so this has to be - // done in two parts. each of the parts c1/c2 has 30 bits of the total in it - // and drops the last 4 bits of the full 64 bit Morton code. - c1 = interlace(x >>> 17, y >>> 17), c2 = interlace((x >>> 2) & 0x7fff, (y >>> 2) & 0x7fff); - - for (var i = 0; i < Math.ceil((zoom + 8) / 3.0) && i < 5; ++i) { - digit = (c1 >> (24 - 6 * i)) & 0x3f; - str += char_array.charAt(digit); - } - for (i = 5; i < Math.ceil((zoom + 8) / 3.0); ++i) { - digit = (c2 >> (24 - 6 * (i - 5))) & 0x3f; - str += char_array.charAt(digit); - } - for (i = 0; i < ((zoom + 8) % 3); ++i) str += "-"; - - // Called to interlace the bits in x and y, making a Morton code. - function interlace(x, y) { - x = (x | (x << 8)) & 0x00ff00ff; - x = (x | (x << 4)) & 0x0f0f0f0f; - x = (x | (x << 2)) & 0x33333333; - x = (x | (x << 1)) & 0x55555555; - y = (y | (y << 8)) & 0x00ff00ff; - y = (y | (y << 4)) & 0x0f0f0f0f; - y = (y | (y << 2)) & 0x33333333; - y = (y | (y << 1)) & 0x55555555; - return (x << 1) | y; - } - - return str; -} - // generate a cookie-safe string of map state function cookieContent(map) { var center = map.getCenter().wrap(); diff --git a/app/assets/javascripts/index.js b/app/assets/javascripts/index.js index 2f0c16097..452cc0bca 100644 --- a/app/assets/javascripts/index.js +++ b/app/assets/javascripts/index.js @@ -81,8 +81,6 @@ $(document).ready(function () { L.OSM.share({ position: position, - getShortUrl: getShortUrl, - getUrl: getUrl, sidebar: sidebar, short: true }).addTo(map); diff --git a/app/assets/javascripts/leaflet.extend.js.erb b/app/assets/javascripts/leaflet.extend.js.erb index 3b505302f..f1abfb4ba 100644 --- a/app/assets/javascripts/leaflet.extend.js.erb +++ b/app/assets/javascripts/leaflet.extend.js.erb @@ -10,22 +10,86 @@ L.extend(L.LatLngBounds.prototype, { }); L.extend(L.Map.prototype, { - getLayersCode: function() { - var layerConfig = ''; - for (var i in this._layers) { // TODO: map.eachLayer - var layer = this._layers[i]; - if (layer.options && layer.options.code) { - layerConfig += layer.options.code; - } - } - return layerConfig; - }, - getMapBaseLayerId: function() { - for (var i in this._layers) { // TODO: map.eachLayer - var layer = this._layers[i]; - if (layer.options && layer.options.keyid) return layer.options.keyid; - } + getLayersCode: function () { + var layerConfig = ''; + for (var i in this._layers) { // TODO: map.eachLayer + var layer = this._layers[i]; + if (layer.options && layer.options.code) { + layerConfig += layer.options.code; + } } + return layerConfig; + }, + + getMapBaseLayerId: function () { + for (var i in this._layers) { // TODO: map.eachLayer + var layer = this._layers[i]; + if (layer.options && layer.options.keyid) return layer.options.keyid; + } + }, + + getUrl: function(marker) { + var center = this.getCenter(), + zoom = this.getZoom(), + toZoom = zoomPrecision(zoom), + params = { + lat: toZoom(center.lat), + lon: toZoom(center.lng), + zoom: zoom, + layers: this.getLayersCode() + }; + + if (marker && this.hasLayer(marker)) { + params.mlat = toZoom(marker.getLatLng().lat); + params.mlon = toZoom(marker.getLatLng().lng); + } + + return 'http://' + OSM.SERVER_URL + '/?' + querystring.stringify(params); + }, + + getShortUrl: function(marker) { + var zoom = this.getZoom(), + latLng = marker && this.hasLayer(marker) ? marker.getLatLng() : this.getCenter(), + str = '', + char_array = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_~", + x = Math.round((latLng.lng + 180.0) * ((1 << 30) / 90.0)), + y = Math.round((latLng.lat + 90.0) * ((1 << 30) / 45.0)), + // JavaScript only has to keep 32 bits of bitwise operators, so this has to be + // done in two parts. each of the parts c1/c2 has 30 bits of the total in it + // and drops the last 4 bits of the full 64 bit Morton code. + c1 = interlace(x >>> 17, y >>> 17), c2 = interlace((x >>> 2) & 0x7fff, (y >>> 2) & 0x7fff), + digit; + + for (var i = 0; i < Math.ceil((zoom + 8) / 3.0) && i < 5; ++i) { + digit = (c1 >> (24 - 6 * i)) & 0x3f; + str += char_array.charAt(digit); + } + for (i = 5; i < Math.ceil((zoom + 8) / 3.0); ++i) { + digit = (c2 >> (24 - 6 * (i - 5))) & 0x3f; + str += char_array.charAt(digit); + } + for (i = 0; i < ((zoom + 8) % 3); ++i) str += "-"; + + // Called to interlace the bits in x and y, making a Morton code. + function interlace(x, y) { + x = (x | (x << 8)) & 0x00ff00ff; + x = (x | (x << 4)) & 0x0f0f0f0f; + x = (x | (x << 2)) & 0x33333333; + x = (x | (x << 1)) & 0x55555555; + y = (y | (y << 8)) & 0x00ff00ff; + y = (y | (y << 4)) & 0x0f0f0f0f; + y = (y | (y << 2)) & 0x33333333; + y = (y | (y << 1)) & 0x55555555; + return (x << 1) | y; + } + + if (marker && this.hasLayer(marker)) { + str += '?m' + } + + return (window.location.hostname.match(/^www\.openstreetmap\.org/i) ? + 'http://osm.org/go/' : 'http://' + window.location.hostname + '/go/') + str; + } }); L.Icon.Default.imagePath = <%= "#{asset_prefix}/images".to_json %>; diff --git a/app/assets/javascripts/leaflet.share.js b/app/assets/javascripts/leaflet.share.js index b808bc435..bea877e66 100644 --- a/app/assets/javascripts/leaflet.share.js +++ b/app/assets/javascripts/leaflet.share.js @@ -60,8 +60,8 @@ L.OSM.share = function (options) { } function update() { - $shortLink.attr('href', options.getShortUrl(map)); - $longLink.attr('href', options.getUrl(map)); + $shortLink.attr('href', map.getShortUrl()); + $longLink.attr('href', map.getUrl()); } function select() {