Fix position of Tower Icon

V028
Keith Paterson 4 years ago
parent 0bb3021e3c
commit a9b2558cf2

@ -51,10 +51,6 @@ L.Threshold = L.Marker.extend({
} }
} }
}, },
onAdd : function(map) {
var metersPP = this.metersPerPixel(map.getCenter().lat, map.getZoom());
this.updateIcon(map);
},
metersPerPixel: function (latitude, zoomLevel) { metersPerPixel: function (latitude, zoomLevel) {
var earthCircumference = 40075017; var earthCircumference = 40075017;
var latitudeRadians = latitude * (Math.PI / 180); var latitudeRadians = latitude * (Math.PI / 180);

@ -22,18 +22,6 @@ L.TowerMarker = L.Marker.extend({
options: { options: {
zIndexOffset: 10000, zIndexOffset: 10000,
}, },
initialize: function (latlng, options) {
L.Marker.prototype.initialize(latlng, options);
L.Util.setOptions(this, options);
this.svg = this.stripSVG('tower.svg');
this.isDragging = false;
},
updateProperties: function(properties) {
this.heading = properties.heading;
this.updateIcon();
},
stripSVG: function(fName) { stripSVG: function(fName) {
var rx = /<\s*svg[^>]*>([\s\S]*)<\s*\/svg[^>]*>/gm; var rx = /<\s*svg[^>]*>([\s\S]*)<\s*\/svg[^>]*>/gm;
var svg = fs.readFileSync(path.join(__static, '/', fName), 'utf8'); var svg = fs.readFileSync(path.join(__static, '/', fName), 'utf8');
@ -41,27 +29,28 @@ L.TowerMarker = L.Marker.extend({
return svg2[0]; return svg2[0];
}, },
updateIcon : function(map) { updateIcon : function(map) {
console.debug(`Lat Lng Threshold ${this.getLatLng()}`);
if(map !== null) { if(map !== null) {
var metersPP = this.metersPerPixel(map.getCenter().lat, map.getZoom()); var metersPP = this.metersPerPixel(map.getCenter().lat, map.getZoom());
console.debug('Old Meters per pixel ' + this.metersPP);
console.debug('New Meters per pixel ' + metersPP);
if(this._metersPP != metersPP) { if(this._metersPP != metersPP) {
console.debug('Meters per pixel ' + metersPP); var pixelSize = (this.iconSize/2) / metersPP;
var pixelSize = 32 / metersPP; var scale = pixelSize/this.iconSize;
var scale = pixelSize/64; var offset = 0;//-(this.iconSize/2);
var offset = -(64/2);
this.setIcon(L.divIcon({ this.setIcon(L.divIcon({
iconSize: 64, iconSize: 64,
className: 'tower-marker-icon', className: 'threshold-marker-icon',
html: `<div style=\'transform: translateX(${offset}px) translateY(${offset}px) scale(${scale}); border: 1px red\'>${this.svg}</div>`, html: `<div style=\'transform: translateX(${offset}px) translateY(${offset}px) scale(${scale}) rotate(${this.options.heading}deg); border: 1px red\'>${this.svg}</div>`,
})); }));
this.update(this.getLatLng());
console.debug();
this.setLatLng(this.getLatLng());
this._metersPP = metersPP; this._metersPP = metersPP;
} }
} }
}, },
onAdd : function(map) {
var metersPP = this.metersPerPixel(map.getCenter().lat, map.getZoom());
console.debug('Meters per pixel ' + metersPP);
this.updateIcon(map);
},
metersPerPixel: function (latitude, zoomLevel) { metersPerPixel: function (latitude, zoomLevel) {
var earthCircumference = 40075017; var earthCircumference = 40075017;
var latitudeRadians = latitude * (Math.PI / 180); var latitudeRadians = latitude * (Math.PI / 180);
@ -75,10 +64,15 @@ L.TowerMarker = L.Marker.extend({
}); });
L.TowerMarker.addInitHook(function(){
this.svg = this.stripSVG('tower.svg');
this.iconSize = 64;
});
//Builds a marker for a ai or multiplayer aircraft //Builds a marker for a ai or multiplayer aircraft
var tower = function (n, options) { var tower = function (n, options) {
var latlon = convert(n.find('lat/text()').text() + " " + n.find('lon/text()').text()); var latlon = convert(n.find('lat/text()').text() + " " + n.find('lon/text()').text());
return new L.TowerMarker([latlon.decimalLatitude, latlon.decimalLongitude], options); return new L.TowerMarker([latlon.decimalLatitude, latlon.decimalLongitude], {heading: 0});
} }
module.exports = tower; module.exports = tower;

@ -63,12 +63,12 @@ exports.readTowerXML = function (fDir, icao, force) {
towerNodes.map(n => { towerNodes.map(n => {
var towerIcon = tower(n, layerGroup); var towerIcon = tower(n, layerGroup);
towerIcon.addTo(layerGroup); towerIcon.addTo(layerGroup);
var latlon = convert(n.find('lat/text()').text() + " " + n.find('lon/text()').text());
/* /*
//DEBUG Code
var latlon = convert(n.find('lat/text()').text() + " " + n.find('lon/text()').text());
var marker = new L.Circle([latlon.decimalLatitude, latlon.decimalLongitude], 5); var marker = new L.Circle([latlon.decimalLatitude, latlon.decimalLongitude], 5);
marker.addTo(layerGroup); marker.addTo(layerGroup);
*/ */
features.push(towerIcon); features.push(towerIcon);
}).sort(); }).sort();

Loading…
Cancel
Save