mirror of
https://github.com/webbukkit/dynmap.git
synced 2025-01-14 03:31:21 +01:00
97 lines
3.3 KiB
JavaScript
97 lines
3.3 KiB
JavaScript
componentconstructors['playermarkers'] = function(dynmap, configuration) {
|
|
var me = this;
|
|
$(dynmap).bind('playeradded', function(event, player) {
|
|
// Create the player-marker.
|
|
var markerPosition = dynmap.map.getProjection().fromWorldToLatLng(player.location.x, player.location.y, player.location.z);
|
|
player.marker = new CustomMarker(markerPosition, dynmap.map, function(div) {
|
|
var playerImage;
|
|
|
|
player.marker.toggle(dynmap.world === player.location.world);
|
|
|
|
$(div)
|
|
.addClass('Marker')
|
|
.addClass('playerMarker')
|
|
.append(playerImage = $('<img/>')
|
|
.attr({ src: 'images/player.png' }))
|
|
.append($('<span/>')
|
|
.addClass('playerName')
|
|
.text(player.name));
|
|
|
|
if (configuration.showplayerfaces) {
|
|
getMinecraftHead(player.account, 32, function(head) {
|
|
$(head)
|
|
.addClass('playericon')
|
|
.prependTo(div);
|
|
playerImage.remove();
|
|
});
|
|
}
|
|
if (configuration.showplayerhealth) {
|
|
if(!configuration.showplayerfaces) /* Need 32 high */
|
|
playerImage.css('margin-bottom','16px');
|
|
|
|
player.healthContainer = $('<div/>')
|
|
.addClass('healthContainer')
|
|
.appendTo(div);
|
|
if (player.health !== undefined && player.armor !== undefined) {
|
|
player.healthBar = $('<div/>')
|
|
.addClass('playerHealth')
|
|
.css('width', (player.health/2*5) + 'px');
|
|
player.armorBar = $('<div/>')
|
|
.addClass('playerArmor')
|
|
.css('width', (player.armor/2*5) + 'px');
|
|
|
|
$('<div/>')
|
|
.addClass('playerHealthBackground')
|
|
.append(player.healthBar)
|
|
.appendTo(player.healthContainer);
|
|
$('<div/>')
|
|
.addClass('playerArmorBackground')
|
|
.append(player.armorBar)
|
|
.appendTo(player.healthContainer);
|
|
} else {
|
|
player.healthContainer.css('display','none');
|
|
}
|
|
}
|
|
});
|
|
});
|
|
$(dynmap).bind('playerremoved', function(event, player) {
|
|
// Remove the marker.
|
|
player.marker.remove();
|
|
});
|
|
$(dynmap).bind('playerupdated', function(event, player) {
|
|
// Update the marker.
|
|
var markerPosition = dynmap.map.getProjection().fromWorldToLatLng(player.location.x, player.location.y, player.location.z);
|
|
player.marker.toggle(dynmap.world === player.location.world);
|
|
player.marker.setPosition(markerPosition);
|
|
// Update health
|
|
if (configuration.showplayerhealth) {
|
|
if (player.health !== undefined && player.armor !== undefined) {
|
|
player.healthContainer.css('display','block');
|
|
player.healthBar.css('width', (player.health/2*5) + 'px');
|
|
player.armorBar.css('width', (player.armor/2*5) + 'px');
|
|
} else {
|
|
player.healthContainer.css('display','none');
|
|
}
|
|
}
|
|
});
|
|
// Remove marker on start of map change
|
|
$(dynmap).bind('mapchanging', function(event) {
|
|
var name;
|
|
for(name in dynmap.players) {
|
|
var player = dynmap.players[name];
|
|
// Turn off marker - let update turn it back on
|
|
player.marker.hide();
|
|
}
|
|
});
|
|
// Remove marker on map change - let update place it again
|
|
$(dynmap).bind('mapchanged', function(event) {
|
|
var name;
|
|
for(name in dynmap.players) {
|
|
var player = dynmap.players[name];
|
|
var markerPosition = dynmap.map.getProjection().fromWorldToLatLng(player.location.x, player.location.y, player.location.z);
|
|
player.marker.setPosition(markerPosition);
|
|
player.marker.toggle(dynmap.world === player.location.world);
|
|
}
|
|
});
|
|
};
|