mirror of
https://github.com/webbukkit/dynmap.git
synced 2024-11-28 21:25:46 +01:00
40 lines
1.2 KiB
JavaScript
40 lines
1.2 KiB
JavaScript
var HDProjection = DynmapProjection.extend({
|
|
fromLocationToLatLng: function(location) {
|
|
var wtp = this.options.worldtomap;
|
|
var xx = wtp[0]*location.x + wtp[1]*location.y + wtp[2]*location.z;
|
|
var yy = wtp[3]*location.x + wtp[4]*location.y + wtp[5]*location.z;
|
|
return new L.LatLng(
|
|
xx / (1 << this.options.mapzoomout)
|
|
, (128-yy) / (1 << this.options.mapzoomout)
|
|
, true);
|
|
}
|
|
});
|
|
|
|
var HDMapType = DynmapTileLayer.extend({
|
|
projection: undefined,
|
|
options: {
|
|
minZoom: 0,
|
|
maxZoom: 0
|
|
},
|
|
initialize: function(options) {
|
|
options.maxZoom = options.mapzoomin + options.mapzoomout;
|
|
L.Util.setOptions(this, options);
|
|
this.projection = new HDProjection($.extend({map: this}, options));
|
|
},
|
|
getTileName: function(tilePoint, zoom) {
|
|
var info = this.getTileInfo(tilePoint, zoom);
|
|
// Y is inverted for HD-map.
|
|
info.y = -info.y;
|
|
info.scaledy = info.y >> 5;
|
|
return namedReplace('{prefix}{nightday}/{scaledx}_{scaledy}/{zoom}{x}_{y}.png', info);
|
|
},
|
|
zoomprefix: function(amount) {
|
|
// amount == 0 -> ''
|
|
// amount == 1 -> 'z_'
|
|
// amount == 2 -> 'zz_'
|
|
return 'zzzzzzzzzzzzzzzzzzzzzz'.substr(0, amount) + (amount === 0 ? '' : '_');
|
|
}
|
|
});
|
|
|
|
maptypes.HDMapType = function(options) { return new HDMapType(options); };
|