forked from vicchi/maps-api-demos
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathovi-events.js
113 lines (94 loc) · 3.26 KB
/
ovi-events.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
var map;
function initialize() {
var map_loaded = false;
var eventStates = {
"center": false,
"zoom": false,
"mapsize": false
};
var bubbleContainer = new ovi.mapsapi.map.component.InfoBubbles();
var coords = new ovi.mapsapi.geo.Coordinate(52.530390, 13.385190);
var position_disp = document.getElementById('position');
var event_disp = document.getElementById('events');
var counter = 0;
position_disp.innerHTML = '0.0000 / 0.0000';
map = new ovi.mapsapi.map.Display(
document.getElementById("map"),
{
'zoomLevel': 12,
'center': [52.530390, 13.385190],
components: [
new ovi.mapsapi.map.component.Behavior(),
new ovi.mapsapi.map.component.ZoomBar(),
bubbleContainer
]
});
map.addListener('mousemove', function(event){
var move_coords = map.pixelToGeo(event.targetX, event.targetY);
position_disp.innerHTML = move_coords.latitude.toFixed(4)
+ ' / '
+ move_coords.longitude.toFixed(4);
position_disp.scrollTop = position_disp.scrollHeight - position_disp.clientHeight;
});
map.addListener("click", function(event) {
var click_coords = map.pixelToGeo(event.displayX, event.displayY);
var marker;
var text;
var bubble;
event_disp.innerHTML += "\n" + ++counter + ". Mouse Click at: " +
click_coords.latitude.toFixed(4) + ' / ' +
click_coords.longitude.toFixed(4);
event_disp.scrollTop = event_disp.scrollHeight - event_disp.clientHeight;
marker = new ovi.mapsapi.map.StandardMarker(click_coords);
map.objects.add(marker);
text = "<p>Lat: " + click_coords.latitude.toFixed(4) +
" Lon: " + click_coords.longitude.toFixed(4) + "</p>";
bubble = bubbleContainer.addBubble(text, click_coords);
});
map.addListener('mapviewchangestart', function(event){
if (event.data & event.MAPVIEWCHANGE_CENTER) {
eventStates.center = true;
}
if (event.data & event.MAPVIEWCHANGE_ZOOM) {
eventStates.zoom = true;
}
if (event.data & event.MAPVIEWCHANGE_SIZE) {
eventStates.mapsize = true;
}
});
map.addListener('mapviewchangeupdate', function(event){
if (event.data & event.MAPVIEWCHANGE_CENTER) {
eventStates.center = true;
}
if (event.data & event.MAPVIEWCHANGE_ZOOM) {
eventStates.zoom = true;
}
if (event.data & event.MAPVIEWCHANGE_SIZE) {
eventStates.mapsize = true;
}
});
map.addListener('mapviewchangeend', function(event){
// The Ovi Maps API doesn't (currently) support a "map loaded" event, but both a
// "centre" and "size" mapviewchangestart/mapviewchangeupdate/mapviewchangeend
// event sequence will be fired as part of the initial loading so we can trap
// this ...
if (!map_loaded) {
if (eventStates.center && eventStates.mapsize) {
map_loaded = true;
eventStates.mapsize = false;
event_disp.innerHTML += "\n" + ++counter + ". Map loaded";
event_disp.scrollTop = event_disp.scrollHeight - event_disp.clientHeight;
}
}
if (eventStates.center) {
eventStates.center = false;
event_disp.innerHTML += "\n" + ++counter + ". Map panned";
event_disp.scrollTop = event_disp.scrollHeight - event_disp.clientHeight;
}
if (eventStates.zoom) {
eventStates.zoom = false;
event_disp.innerHTML += "\n" + ++counter + ". Zoom level changed";
event_disp.scrollTop = event_disp.scrollHeight - event_disp.clientHeight;
}
});
}