forked from MTSR/mapserver
train display/icons
This commit is contained in:
parent
2035803541
commit
5dcac0c320
@ -51,6 +51,9 @@ function send_stats()
|
||||
--print(dump(train))--XXX
|
||||
|
||||
local t = {
|
||||
text_outside = train.text_outside,
|
||||
text_inside = train.text_inside,
|
||||
line = train.line,
|
||||
pos = train.last_pos,
|
||||
velocity = train.velocity,
|
||||
off_track = train.off_track,
|
||||
|
BIN
pics/trains.png
Normal file
BIN
pics/trains.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 18 KiB |
BIN
pics/trains2.png
Normal file
BIN
pics/trains2.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 23 KiB |
@ -42,6 +42,7 @@ type MapObjectConfig struct {
|
||||
Smartshop bool `json:"smartshop"`
|
||||
Fancyvend bool `json:"fancyvend"`
|
||||
ATM bool `json:"atm"`
|
||||
Train bool `json:"train"`
|
||||
}
|
||||
|
||||
type WebApiConfig struct {
|
||||
@ -110,6 +111,7 @@ func ParseConfig(filename string) (*Config, error) {
|
||||
Smartshop: true,
|
||||
Fancyvend: true,
|
||||
ATM: true,
|
||||
Train: true,
|
||||
}
|
||||
|
||||
mapblockaccessor := MapBlockAccessorConfig{
|
||||
|
@ -1,5 +1,5 @@
|
||||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<html style="height: 100%">
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
||||
@ -36,6 +36,7 @@
|
||||
<script src="js/overlays/PoiOverlay.js"></script>
|
||||
<script src="js/overlays/LabelOverlay.js"></script>
|
||||
<script src="js/overlays/PlayerOverlay.js"></script>
|
||||
<script src="js/overlays/TrainOverlay.js"></script>
|
||||
<script src="js/overlays/ProtectorOverlay.js"></script>
|
||||
<script src="js/overlays/BonesOverlay.js"></script>
|
||||
<script src="js/overlays/LcdOverlay.js"></script>
|
||||
|
@ -45,4 +45,8 @@ function Overlaysetup(cfg, map, overlays, wsChannel, layerMgr){
|
||||
if (cfg.mapobjects.mission) {
|
||||
overlays["Missions"] = new MissionOverlay(wsChannel, layerMgr);
|
||||
}
|
||||
|
||||
if (cfg.mapobjects.train) {
|
||||
overlays["Trains"] = new TrainOverlay(wsChannel, layerMgr);
|
||||
}
|
||||
}
|
||||
|
@ -1,13 +1,24 @@
|
||||
'use strict';
|
||||
|
||||
//TODO
|
||||
var TrainIcon = L.icon({
|
||||
iconUrl: 'pics/sam.png',
|
||||
|
||||
iconSize: [16, 32],
|
||||
iconAnchor: [8, 16],
|
||||
popupAnchor: [0, -16]
|
||||
});
|
||||
function getTrainImageUrlForType(type){
|
||||
switch(type){
|
||||
case "advtrains:subway_wagon":
|
||||
return "pics/advtrains/advtrains_subway_wagon_inv.png";
|
||||
case "advtrains:engine_japan":
|
||||
return "pics/advtrains/advtrains_engine_japan_inv.png";
|
||||
case "advtrains:engine_steam":
|
||||
return "pics/advtrains/advtrains_engine_steam_inv.png";
|
||||
case "advtrains:engine_industrial":
|
||||
return "pics/advtrains/advtrains_engine_industrial_inv.png";
|
||||
case "advtrains:wagon_wood":
|
||||
return "pics/advtrains/advtrains_wagon_wood_inv.png";
|
||||
case "advtrains:wagon_box":
|
||||
return "pics/advtrains/advtrains_wagon_box_inv.png";
|
||||
default:
|
||||
//TODO: fallback image
|
||||
return "pics/advtrains/advtrains_subway_wagon_inv.png";
|
||||
}
|
||||
}
|
||||
|
||||
var TrainOverlay = L.LayerGroup.extend({
|
||||
initialize: function(wsChannel, layerMgr) {
|
||||
@ -29,8 +40,40 @@ var TrainOverlay = L.LayerGroup.extend({
|
||||
},
|
||||
|
||||
createMarker: function(train){
|
||||
var marker = L.marker([train.pos.z, train.pos.x], {icon: TrainIcon});
|
||||
marker.bindPopup("Train");
|
||||
|
||||
//search for wagin in front (whatever "front" is...)
|
||||
var type;
|
||||
var lowest_pos = 100;
|
||||
train.wagons.forEach(function(w){
|
||||
if (w.pos_in_train < lowest_pos){
|
||||
lowest_pos = w.pos_in_train;
|
||||
type = w.type;
|
||||
}
|
||||
});
|
||||
|
||||
var Icon = L.icon({
|
||||
iconUrl: getTrainImageUrlForType(type),
|
||||
|
||||
iconSize: [16, 16],
|
||||
iconAnchor: [8, 8],
|
||||
popupAnchor: [0, -16]
|
||||
});
|
||||
|
||||
var marker = L.marker([train.pos.z, train.pos.x], {icon: Icon});
|
||||
|
||||
var html = "<b>Train</b><hr>";
|
||||
|
||||
html += "<b>Name:</b> " + train.text_outside + "<br>";
|
||||
html += "<b>Line:</b> " + train.line + "<br>";
|
||||
html += "<b>Velocity:</b> "+ Math.floor(train.velocity*10)/10 + "<br>";
|
||||
|
||||
html += "<b>Composition: </b>";
|
||||
train.wagons.forEach(function(w){
|
||||
var iconUrl = getTrainImageUrlForType(w.type);
|
||||
html += "<img src='"+iconUrl+"'>";
|
||||
});
|
||||
|
||||
marker.bindPopup(html);
|
||||
|
||||
return marker;
|
||||
},
|
||||
|
Binary file not shown.
Before Width: | Height: | Size: 900 B After Width: | Height: | Size: 1.1 KiB |
@ -26,6 +26,9 @@ type Train struct {
|
||||
Wagons []*Wagon `json:"wagons"`
|
||||
OffTrack bool `json:"off_track"`
|
||||
Velocity float64 `json:"velocity"`
|
||||
Line string `json:"line"`
|
||||
TextOutside string `json:"text_outside"`
|
||||
TextInside string `json:"text_inside"`
|
||||
}
|
||||
|
||||
type Player struct {
|
||||
|
Loading…
Reference in New Issue
Block a user