Imported existing sources

This commit is contained in:
Daniel Brunner
2016-08-02 20:27:48 +02:00
parent fa7f1a2689
commit 8d21e94ee2
15 changed files with 166 additions and 0 deletions

BIN
src/img/gym_blue.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.5 KiB

BIN
src/img/gym_blue_battle.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

BIN
src/img/gym_neutral.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.1 KiB

BIN
src/img/gym_red.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.7 KiB

BIN
src/img/gym_red_battle.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

BIN
src/img/gym_yellow.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.5 KiB

BIN
src/img/pokestop.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.4 KiB

BIN
src/img/pokestop_lure.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.2 KiB

18
src/index.html Normal file
View File

@ -0,0 +1,18 @@
<!doctype html>
<html class="no-js" lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title></title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="style.css">
</head>
<body>
<div id="map"></div>
<script src="https://maps.googleapis.com/maps/api/js?callback=initMap" async defer></script>
<script src="script.js"></script>
</body>
</html>

138
src/script.js Normal file
View File

@ -0,0 +1,138 @@
var websocketAddress = ((window.location.protocol === "https:") ? "wss:" : "ws:") + "//" + window.location.host + "/websocket";
if (typeof String.prototype.contains === 'undefined') {
String.prototype.contains = function(it) {
return this.indexOf(it) != -1;
};
}
var TeamColor = { Neutral: 0, Blue: 1, Red: 2, Yellow: 3 };
var FortRenderingType = { Default: 0, InternalTest: 1 };
var FortSponsor = { UnsetSponsor: 0, Mcdonalds: 1, PokemonStore: 2 };
var FortType = { Gym: 0, Checkpoint: 1 };
function initMap() {
var map = new google.maps.Map(document.getElementById('map'), {
settings: {
draggable: false
}
});
var playerMarker = new google.maps.Marker({
map: map
});
var fortPath = new google.maps.Polyline({
path: [],
geodesic: true,
strokeColor: '#FF0000',
strokeOpacity: 1.0,
strokeWeight: 2
});
var playerPos;
var fortPathTarget;
var fortMarkers;
var intervalId;
var handleMessage = function(e) {
var message = JSON.parse(e.data);
var type = message.$type;
if(type.contains('UpdatePositionEvent')) {
var pos = {lat: message.Latitude, lng: message.Longitude};
if(playerPos.lat == 0 && playerPos.lng == 0) {
map.setCenter(pos);
playerMarker.setPosition(pos);
}
playerPos = pos;
} else if(type.contains('PokeStopListEvent')) {
var now = new Date();
for(var i in message.Forts.$values) {
var fort = message.Forts.$values[i];
if(!(fort.Id in fortMarkers)) {
fortMarkers[fort.Id] = new google.maps.Marker({
map: map
});
}
fortMarkers[fort.Id].setPosition({lat: fort.Latitude, lng: fort.Longitude});
if(fort.Type == FortType.Gym) {
if(fort.OwnedByTeam == TeamColor.Neutral) {
fortMarkers[fort.Id].setIcon('img/' + (fort.IsInBattle ? 'gym_neutral_battle.png' : 'gym_neutral.png'));
} else if(fort.OwnedByTeam == TeamColor.Red) {
fortMarkers[fort.Id].setIcon('img/' + (fort.IsInBattle ? 'gym_red_battle.png' : 'gym_red.png'));
} else if(fort.OwnedByTeam == TeamColor.Blue) {
fortMarkers[fort.Id].setIcon('img/' + (fort.IsInBattle ? 'gym_blue_battle.png' : 'gym_blue.png'));
} else if(fort.OwnedByTeam == TeamColor.Yellow) {
fortMarkers[fort.Id].setIcon('img/' + (fort.IsInBattle ? 'gym_yellow_battle.png' : 'gym_yellow.png'));
} else {
console.warn('Unknown FortData.OwnedByTeam: ' + fort.OwnedByTeam);
}
} else if(fort.Type == FortType.Checkpoint) {
fortMarkers[fort.Id].lure = fort.LureInfo == null;
if(new Date(fort.CooldownCompleteTimestampMs) < now) {
fortMarkers[fort.Id].setIcon('img/' + (fortMarkers[fort.Id].lure ? 'pokestop.png' : 'pokestop_lure.png'));
} else {
fortMarkers[fort.Id].setIcon('img/' + (fortMarkers[fort.Id].lure ? 'pokestop_cooldown.png' : 'pokestop_cooldown_lure.png'));
}
} else {
console.warn('Unknown FortData.Type: ' + fort.Type);
}
}
} else if(type.contains("FortTargetEvent")) {
fortPath.setMap(map);
fortPathTarget = { lat: message.Latitude, lng: message.Longitude };
fortPath.setPath([
{ lat: playerMarker.position.lat(), lng: playerMarker.position.lng() },
fortPathTarget
]);
} else if(type.contains("FortUsedEvent")) {
fortPath.setMap(null);
fortPathTarget = null;
fortMarkers[message.Id].setIcon('img/' + (fortMarkers[message.Id].lure ? 'pokestop_cooldown.png' : 'pokestop_cooldown_lure.png'));
} /* else {
console.warn('Unknown message: ' + message['$type']);
console.warn(message);
} */
};
var connect = function() {
var ws = new WebSocket(websocketAddress);
ws.onopen = function() {
map.setCenter(null);
map.setZoom(17);
playerMarker.setPosition(null);
playerPos = { lat: 0, lng: 0 };
fortPathTarget = null;
fortMarkers = {};
intervalId = setInterval(function(){
var oldPos = playerMarker.position;
var newPos = {
lat: ((oldPos.lat() * 30) + playerPos.lat) / 31,
lng: ((oldPos.lng() * 30) + playerPos.lng) / 31
};
map.setCenter(newPos);
playerMarker.setPosition(newPos);
if(fortPathTarget != null) {
fortPath.setPath([
newPos,
fortPathTarget
]);
}
}, 50);
};
ws.onclose = function() {
console.log("onclose");
clearInterval(intervalId);
setTimeout(connect, 500);
};
ws.onmessage = handleMessage;
};
connect();
}

10
src/style.css Normal file
View File

@ -0,0 +1,10 @@
html, body, #map, #connecting {
position: absolute;
left: 0;
top: 0;
right: 0;
bottom: 0;
margin: 0;
padding: 0;
}