1
|
|
|
<?php |
2
|
|
|
require_once('require/class.Connection.php'); |
3
|
|
|
require_once('require/class.Common.php'); |
4
|
|
|
$tracker = false; |
5
|
|
|
$marine = false; |
6
|
|
|
if (isset($_GET['tracker'])) $tracker = true; |
7
|
|
|
if (isset($_GET['marine'])) $marine = true; |
8
|
|
|
if ($tracker) { |
9
|
|
|
require_once('require/class.Tracker.php'); |
10
|
|
|
require_once('require/class.TrackerLive.php'); |
11
|
|
|
//require_once('require/class.SpotterArchive.php'); |
12
|
|
|
$TrackerLive = new TrackerLive(); |
13
|
|
|
$Tracker = new Tracker(); |
14
|
|
|
// $TrackerArchive = new TrackerArchive(); |
15
|
|
|
} elseif ($marine) { |
16
|
|
|
require_once('require/class.Marine.php'); |
17
|
|
|
require_once('require/class.MarineLive.php'); |
18
|
|
|
//require_once('require/class.MarineArchive.php'); |
19
|
|
|
$MarineLive = new MarineLive(); |
20
|
|
|
$Marine = new Marine(); |
21
|
|
|
// $MarineArchive = new MarineArchive(); |
22
|
|
|
} else { |
23
|
|
|
require_once('require/class.Spotter.php'); |
24
|
|
|
require_once('require/class.SpotterLive.php'); |
25
|
|
|
require_once('require/class.SpotterArchive.php'); |
26
|
|
|
$SpotterLive = new SpotterLive(); |
27
|
|
|
$Spotter = new Spotter(); |
28
|
|
|
$SpotterArchive = new SpotterArchive(); |
29
|
|
|
} |
30
|
|
|
|
31
|
|
|
date_default_timezone_set('UTC'); |
32
|
|
|
$begintime = microtime(true); |
33
|
|
|
$Common = new Common(); |
34
|
|
|
|
35
|
|
|
|
36
|
|
|
function quaternionrotate($heading, $attitude = 0, $bank = 0) { |
37
|
|
|
// Assuming the angles are in radians. |
38
|
|
|
$c1 = cos($heading/2); |
39
|
|
|
$s1 = sin($heading/2); |
40
|
|
|
$c2 = cos($attitude/2); |
41
|
|
|
$s2 = sin($attitude/2); |
42
|
|
|
$c3 = cos($bank/2); |
43
|
|
|
$s3 = sin($bank/2); |
44
|
|
|
$c1c2 = $c1*$c2; |
45
|
|
|
$s1s2 = $s1*$s2; |
46
|
|
|
$w =$c1c2*$c3 - $s1s2*$s3; |
47
|
|
|
$x =$c1c2*$s3 + $s1s2*$c3; |
48
|
|
|
$y =$s1*$c2*$c3 + $c1*$s2*$s3; |
49
|
|
|
$z =$c1*$s2*$c3 - $s1*$c2*$s3; |
50
|
|
|
return array('x' => $x,'y' => $y,'z' => $z,'w' => $w); |
51
|
|
|
// return array('x' => '0.0','y' => '-0.931','z' => '0.0','w' => '0.365'); |
52
|
|
|
|
53
|
|
|
} |
54
|
|
|
|
55
|
|
|
|
56
|
|
|
if (isset($_GET['download'])) { |
57
|
|
|
if ($_GET['download'] == "true") |
58
|
|
|
{ |
59
|
|
|
header('Content-disposition: attachment; filename="flightairmap.json"'); |
60
|
|
|
} |
61
|
|
|
} |
62
|
|
|
header('Content-Type: text/javascript'); |
63
|
|
|
|
64
|
|
|
if (!isset($globalJsonCompress)) $compress = true; |
65
|
|
|
else $compress = $globalJsonCompress; |
66
|
|
|
|
67
|
|
|
$from_archive = false; |
68
|
|
|
$min = false; |
69
|
|
|
$allhistory = false; |
70
|
|
|
$filter['source'] = array(); |
71
|
|
|
if ((!isset($globalMapVAchoose) || $globalMapVAchoose) && isset($globalVATSIM) && $globalVATSIM && isset($_COOKIE['filter_ShowVATSIM']) && $_COOKIE['filter_ShowVATSIM'] == 'true') $filter['source'] = array_merge($filter['source'],array('vatsimtxt')); |
72
|
|
|
if ((!isset($globalMapVAchoose) || $globalMapVAchoose) && isset($globalIVAO) && $globalIVAO && isset($_COOKIE['filter_ShowIVAO']) && $_COOKIE['filter_ShowIVAO'] == 'true') $filter['source'] = array_merge($filter['source'],array('whazzup')); |
73
|
|
|
if ((!isset($globalMapVAchoose) || $globalMapVAchoose) && isset($globalphpVMS) && $globalphpVMS && isset($_COOKIE['filter_ShowVMS']) && $_COOKIE['filter_ShowVMS'] == 'true') $filter['source'] = array_merge($filter['source'],array('phpvmacars')); |
74
|
|
|
if ((!isset($globalMapchoose) || $globalMapchoose) && isset($globalSBS1) && $globalSBS1 && isset($_COOKIE['filter_ShowSBS1']) && $_COOKIE['filter_ShowSBS1'] == 'true') $filter['source'] = array_merge($filter['source'],array('sbs','famaprs')); |
75
|
|
|
if ((!isset($globalMapchoose) || $globalMapchoose) && isset($globalAPRS) && $globalAPRS && isset($_COOKIE['filter_ShowAPRS']) && $_COOKIE['filter_ShowAPRS'] == 'true') $filter['source'] = array_merge($filter['source'],array('aprs')); |
76
|
|
|
if (isset($_COOKIE['filter_ident']) && $_COOKIE['filter_ident'] != '') $filter['ident'] = filter_var($_COOKIE['filter_ident'],FILTER_SANITIZE_STRING); |
77
|
|
|
if (isset($_COOKIE['filter_Airlines']) && $_COOKIE['filter_Airlines'] != '') $filter['airlines'] = filter_var_array(explode(',',$_COOKIE['filter_Airlines']),FILTER_SANITIZE_STRING); |
78
|
|
|
if (isset($_COOKIE['filter_Sources']) && $_COOKIE['filter_Sources'] != '') $filter['source_aprs'] = filter_var_array(explode(',',$_COOKIE['filter_Sources']),FILTER_SANITIZE_STRING); |
79
|
|
|
if (isset($_COOKIE['filter_airlinestype']) && $_COOKIE['filter_airlinestype'] != 'all') $filter['airlinestype'] = filter_var($_COOKIE['filter_airlinestype'],FILTER_SANITIZE_STRING); |
80
|
|
|
if (isset($_COOKIE['filter_alliance']) && $_COOKIE['filter_alliance'] != 'all') $filter['alliance'] = filter_var($_COOKIE['filter_alliance'],FILTER_SANITIZE_STRING); |
81
|
|
|
/* |
82
|
|
|
if (isset($globalMapPopup) && !$globalMapPopup && !(isset($_COOKIE['flightpopup']) && $_COOKIE['flightpopup'] == 'true')) { |
83
|
|
|
$min = true; |
84
|
|
|
} |
85
|
|
|
|
86
|
|
|
if (isset($_GET['ident'])) { |
87
|
|
|
$ident = filter_input(INPUT_GET,'ident',FILTER_SANITIZE_STRING); |
88
|
|
|
$spotter_array = $SpotterLive->getLastLiveSpotterDataByIdent($ident); |
89
|
|
|
if (empty($spotter_array)) { |
90
|
|
|
$from_archive = true; |
91
|
|
|
$spotter_array = $SpotterArchive->getLastArchiveSpotterDataByIdent($ident); |
92
|
|
|
} |
93
|
|
|
$allhistory = true; |
94
|
|
|
} elseif (isset($_GET['flightaware_id'])) { |
95
|
|
|
$flightaware_id = filter_input(INPUT_GET,'flightaware_id',FILTER_SANITIZE_STRING); |
96
|
|
|
$spotter_array = $SpotterLive->getLastLiveSpotterDataById($flightaware_id); |
97
|
|
|
if (empty($spotter_array)) { |
98
|
|
|
$from_archive = true; |
99
|
|
|
$spotter_array = $SpotterArchive->getLastArchiveSpotterDataById($flightaware_id); |
100
|
|
|
} |
101
|
|
|
$allhistory = true; |
102
|
|
|
} elseif (isset($_GET['coord'])) { |
103
|
|
|
$coord = explode(',',$_GET['coord']); |
104
|
|
|
$spotter_array = $SpotterLive->getLiveSpotterDatabyCoord($coord,$filter); |
105
|
|
|
} elseif (isset($_GET['archive']) && isset($_GET['begindate']) && isset($_GET['enddate']) && isset($_GET['speed'])) { |
106
|
|
|
$from_archive = true; |
107
|
|
|
// $begindate = filter_input(INPUT_GET,'begindate',FILTER_VALIDATE_REGEXP,array("options"=>array("regexp"=>'~^\d{4}/\d{2}/\d{2}$~'))); |
108
|
|
|
// $enddate = filter_input(INPUT_GET,'enddate',FILTER_VALIDATE_REGEXP,array("options"=>array("regexp"=>'~^\d{4}/\d{2}/\d{2}$~'))); |
109
|
|
|
$begindate = filter_input(INPUT_GET,'begindate',FILTER_SANITIZE_NUMBER_INT); |
110
|
|
|
$enddate = filter_input(INPUT_GET,'enddate',FILTER_SANITIZE_NUMBER_INT); |
111
|
|
|
$archivespeed = filter_input(INPUT_GET,'speed',FILTER_SANITIZE_NUMBER_INT); |
112
|
|
|
$begindate = date('Y-m-d H:i:s',$begindate); |
113
|
|
|
$enddate = date('Y-m-d H:i:s',$enddate); |
114
|
|
|
$spotter_array = $SpotterArchive->getMinLiveSpotterData($begindate,$enddate,$filter); |
115
|
|
|
} elseif ($min) { |
116
|
|
|
//$spotter_array = $SpotterLive->getMinLiveSpotterData($filter); |
117
|
|
|
$spotter_array = $SpotterLive->getMinLastLiveSpotterData($filter); |
118
|
|
|
# $min = true; |
119
|
|
|
} else { |
120
|
|
|
$spotter_array = $SpotterLive->getLiveSpotterData('','',$filter); |
121
|
|
|
} |
122
|
|
|
*/ |
123
|
|
|
if (isset($_GET['archive']) && isset($_GET['begindate']) && isset($_GET['enddate']) && isset($_GET['speed'])) { |
124
|
|
|
$from_archive = true; |
125
|
|
|
// $begindate = filter_input(INPUT_GET,'begindate',FILTER_VALIDATE_REGEXP,array("options"=>array("regexp"=>'~^\d{4}/\d{2}/\d{2}$~'))); |
126
|
|
|
// $enddate = filter_input(INPUT_GET,'enddate',FILTER_VALIDATE_REGEXP,array("options"=>array("regexp"=>'~^\d{4}/\d{2}/\d{2}$~'))); |
127
|
|
|
$begindate = filter_input(INPUT_GET,'begindate',FILTER_SANITIZE_NUMBER_INT); |
128
|
|
|
$enddate = filter_input(INPUT_GET,'enddate',FILTER_SANITIZE_NUMBER_INT); |
129
|
|
|
$archivespeed = filter_input(INPUT_GET,'speed',FILTER_SANITIZE_NUMBER_INT); |
130
|
|
|
$begindate = date('Y-m-d H:i:s',$begindate); |
131
|
|
|
$enddate = date('Y-m-d H:i:s',$enddate); |
132
|
|
|
$spotter_array = $SpotterArchive->getMinLiveSpotterDataPlayback($begindate,$enddate,$filter); |
133
|
|
|
} elseif (isset($_COOKIE['archive']) && isset($_COOKIE['archive_begin']) && isset($_COOKIE['archive_end']) && isset($_COOKIE['archive_speed'])) { |
134
|
|
|
$from_archive = true; |
135
|
|
|
// $begindate = filter_input(INPUT_GET,'begindate',FILTER_VALIDATE_REGEXP,array("options"=>array("regexp"=>'~^\d{4}/\d{2}/\d{2}$~'))); |
136
|
|
|
// $enddate = filter_input(INPUT_GET,'enddate',FILTER_VALIDATE_REGEXP,array("options"=>array("regexp"=>'~^\d{4}/\d{2}/\d{2}$~'))); |
137
|
|
|
// $begindate = filter_var($_COOKIE['archive_begin'],FILTER_SANITIZE_NUMBER_INT); |
138
|
|
|
// $enddate = filter_var($_COOKIE['archive_end'],FILTER_SANITIZE_NUMBER_INT); |
139
|
|
|
$begindate = $_COOKIE['archive_begin']; |
140
|
|
|
$enddate = $_COOKIE['archive_end']; |
141
|
|
|
|
142
|
|
|
$archivespeed = filter_var($_COOKIE['archive_speed'],FILTER_SANITIZE_NUMBER_INT); |
143
|
|
|
$begindate = date('Y-m-d H:i:s',$begindate); |
144
|
|
|
$enddate = date('Y-m-d H:i:s',$enddate); |
145
|
|
|
// echo 'Begin : '.$begindate.' - End : '.$enddate."\n"; |
146
|
|
|
$spotter_array = $SpotterArchive->getMinLiveSpotterData($begindate,$enddate,$filter); |
147
|
|
|
} elseif ($tracker) { |
148
|
|
|
$spotter_array = $TrackerLive->getMinLastLiveTrackerData($filter); |
149
|
|
|
} elseif ($marine) { |
150
|
|
|
$spotter_array = $MarineLive->getMinLastLiveMarineData($filter); |
151
|
|
|
} else { |
152
|
|
|
$spotter_array = $SpotterLive->getMinLastLiveSpotterData($filter); |
153
|
|
|
} |
154
|
|
|
|
155
|
|
|
if (!empty($spotter_array)) { |
156
|
|
|
if (isset($_GET['archive'])) { |
157
|
|
|
$flightcnt = $SpotterArchive->getLiveSpotterCount($begindate,$enddate,$filter); |
158
|
|
|
} elseif ($tracker) { |
159
|
|
|
$flightcnt = $TrackerLive->getLiveTrackerCount($filter); |
160
|
|
|
} elseif ($marine) { |
161
|
|
|
$flightcnt = $MarineLive->getLiveMarineCount($filter); |
162
|
|
|
} else { |
163
|
|
|
$flightcnt = $SpotterLive->getLiveSpotterCount($filter); |
164
|
|
|
} |
165
|
|
|
if ($flightcnt == '') $flightcnt = 0; |
166
|
|
|
} else $flightcnt = 0; |
167
|
|
|
|
168
|
|
|
$sqltime = round(microtime(true)-$begintime,2); |
169
|
|
|
$minitime = time(); |
170
|
|
|
$maxitime = 0; |
171
|
|
|
|
172
|
|
|
|
173
|
|
|
$modelsdb = array(); |
174
|
|
|
if (file_exists('models/modelsdb')) { |
175
|
|
|
if (($handle = fopen('models/modelsdb','r')) !== FALSE) { |
176
|
|
|
while (($row = fgetcsv($handle,1000)) !== FALSE) { |
177
|
|
|
if (isset($row[1]) ){ |
178
|
|
|
$model = $row[0]; |
179
|
|
|
$modelsdb[$model] = $row[1]; |
180
|
|
|
} |
181
|
|
|
} |
182
|
|
|
fclose($handle); |
183
|
|
|
} |
184
|
|
|
} |
185
|
|
|
$heightrelative = 'NONE'; |
186
|
|
|
$j = 0; |
187
|
|
|
$prev_flightaware_id = ''; |
188
|
|
|
$speed = 1; |
189
|
|
|
if (isset($archivespeed)) $speed = $archivespeed; |
190
|
|
|
$output = '['; |
191
|
|
|
if ($tracker) { |
192
|
|
|
$output .= '{"id" : "document", "name" : "tracker","version" : "1.0"'; |
193
|
|
|
} elseif ($marine) { |
194
|
|
|
$output .= '{"id" : "document", "name" : "marine","version" : "1.0"'; |
195
|
|
|
} else { |
196
|
|
|
$output .= '{"id" : "document", "name" : "fam","version" : "1.0"'; |
197
|
|
|
} |
198
|
|
|
// $output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "LOOP_STOP","step": "SYSTEM_CLOCK_MULTIPLIER"}'; |
199
|
|
|
|
200
|
|
|
// $output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}'; |
201
|
|
|
//$output .= ',"clock": {"currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}'; |
202
|
|
|
if ($from_archive === true) { |
203
|
|
|
$output .= ',"clock": {"currentTime" : "%minitime%","multiplier" : '.$speed.',"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER","interval": "%minitime%/%maxitime%"}'; |
204
|
|
|
} else { |
205
|
|
|
if (isset($globalArchive) && $globalArchive === TRUE) { |
206
|
|
|
$output .= ',"clock": {"currentTime" : "'.date("c",time()-$globalLiveInterval).'","multiplier" : '.$speed.',"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}'; |
207
|
|
|
} else { |
208
|
|
|
$output .= ',"clock": {"currentTime" : "%minitime%","multiplier" : '.$speed.',"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}'; |
209
|
|
|
} |
210
|
|
|
} |
211
|
|
|
|
212
|
|
|
// $output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"step": "SYSTEM_CLOCK_MULTIPLIER"}'; |
213
|
|
|
$output .= '},'; |
214
|
|
|
if (!empty($spotter_array) && is_array($spotter_array)) |
215
|
|
|
{ |
216
|
|
|
foreach($spotter_array as $spotter_item) |
217
|
|
|
{ |
218
|
|
|
$j++; |
219
|
|
|
date_default_timezone_set('UTC'); |
220
|
|
|
if (isset($spotter_item['image_thumbnail']) && $spotter_item['image_thumbnail'] != "") |
221
|
|
|
{ |
222
|
|
|
$image = $spotter_item['image_thumbnail']; |
223
|
|
|
} else { |
224
|
|
|
$image = "images/placeholder_thumb.png"; |
225
|
|
|
} |
226
|
|
|
|
227
|
|
|
if (isset($spotter_item['flightaware_id'])) $id = $spotter_item['flightaware_id']; |
228
|
|
|
elseif (isset($spotter_item['famtrackid'])) $id = $spotter_item['famtrackid']; |
229
|
|
|
elseif (isset($spotter_item['fammarine_id'])) $id = $spotter_item['fammarine_id']; |
230
|
|
|
if ($prev_flightaware_id != $id) { |
231
|
|
|
if ($prev_flightaware_id != '') { |
232
|
|
|
$output .= ']'; |
233
|
|
|
$output .= '}'; |
234
|
|
|
//$output .= ', '.$orientation.']}'; |
235
|
|
|
$output .= '},'; |
236
|
|
|
} |
237
|
|
|
$orientation = ''; |
238
|
|
|
$prev_flightaware_id = $id; |
239
|
|
|
$output .= '{'; |
240
|
|
|
$output .= '"id": "'.$id.'",'; |
241
|
|
|
$output .= '"properties": {'; |
242
|
|
|
// Not yet supported in CZML with Cesium |
243
|
|
|
$output .= '},'; |
244
|
|
|
|
245
|
|
|
$output .= '"path" : { '; |
246
|
|
|
$output .= '"show" : false, '; |
247
|
|
|
$output .= '"material" : { '; |
248
|
|
|
$output .= '"polylineOutline" : { '; |
249
|
|
|
$output .= '"color" : { "rgba" : [238, 250, 255, 255] }, '; |
250
|
|
|
$output .= '"outlineColor" : { "rgba" : [200, 209, 214, 255] }, '; |
251
|
|
|
$output .= '"outlineWidth" : 5, '; |
252
|
|
|
$output .= '"polylineGlow" : { "color" : { "rgba" : [214, 208, 214, 255] }, "glowPower" : 3 } '; |
253
|
|
|
$output .= '}'; |
254
|
|
|
$output .= '}, '; |
255
|
|
|
$output .= '"heightReference": "'.$heightrelative.'",'; |
256
|
|
|
$output .= '"width" : 6, "leadTime" : 0, "trailTime" : 1000000, "resolution" : 10 },'; |
257
|
|
|
//$output .= ' "billboard" : {"image" : "","scale" : 1.5},'; |
258
|
|
|
if (isset($spotter_item['aircraft_icao'])) { |
259
|
|
|
$aircraft_icao = $spotter_item['aircraft_icao']; |
260
|
|
|
if (isset($modelsdb[$aircraft_icao])) { |
261
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$aircraft_icao].'","scale" : 1.0,"minimumPixelSize": 20'; |
262
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
263
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
264
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
265
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
266
|
|
|
} |
267
|
|
|
$output .= '},'; |
268
|
|
|
} elseif ($aircraft_icao != '') { |
269
|
|
|
$aircraft_info = $Spotter->getAllAircraftInfo($aircraft_icao); |
270
|
|
|
if (isset($aircraft_info[0]['engine_type'])) { |
271
|
|
|
$aircraft_shadow = $aircraft_info[0]['aircraft_shadow']; |
272
|
|
|
$spotter_item['engine_type'] = $aircraft_info[0]['engine_type']; |
273
|
|
|
$spotter_item['wake_category'] = $aircraft_info[0]['wake_category']; |
274
|
|
|
$spotter_item['engine_count'] = $aircraft_info[0]['engine_count']; |
275
|
|
|
} else $aircraft_shadow = ''; |
276
|
|
|
if ($aircraft_shadow != '') { |
277
|
|
|
if (isset($modelsdb[$aircraft_shadow])) { |
278
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$aircraft_shadow].'","scale" : 1.0,"minimumPixelSize": 20'; |
279
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
280
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
281
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
282
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
283
|
|
|
} |
284
|
|
|
$output .= '},'; |
285
|
|
|
$modelsdb[$aircraft_icao] = $modelsdb[$aircraft_shadow]; |
286
|
|
|
} elseif ($spotter_item['engine_type'] == 'Jet') { |
287
|
|
|
if ($spotter_item['engine_count'] == '1') { |
288
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
289
|
|
|
$model = 'J1M'; |
290
|
|
|
} elseif ($spotter_item['wake_category'] == 'L') { |
291
|
|
|
$model = ''; |
292
|
|
|
} |
293
|
|
|
} elseif ($spotter_item['engine_count'] == '2') { |
294
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
295
|
|
|
$model = 'J2M'; |
296
|
|
|
} elseif ($spotter_item['wake_category'] == 'H') { |
297
|
|
|
$model = 'J2H'; |
298
|
|
|
} elseif ($spotter_item['wake_category'] == 'L') { |
299
|
|
|
$model = 'J2L'; |
300
|
|
|
} |
301
|
|
|
} elseif ($spotter_item['engine_count'] == '3') { |
302
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
303
|
|
|
$model = 'J3M'; |
304
|
|
|
} elseif ($spotter_item['wake_category'] == 'H') { |
305
|
|
|
$model = 'J3H'; |
306
|
|
|
} |
307
|
|
|
} elseif ($spotter_item['engine_count'] == '4') { |
308
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
309
|
|
|
$model = 'J4M'; |
310
|
|
|
} elseif ($spotter_item['wake_category'] == 'H') { |
311
|
|
|
$model = 'J4H'; |
312
|
|
|
} |
313
|
|
|
} |
314
|
|
|
if (isset($modelsdb[$model])) { |
315
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$model].'","scale" : 1.0,"minimumPixelSize": 20'; |
316
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
317
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
318
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
319
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
320
|
|
|
} |
321
|
|
|
$output .= '},'; |
322
|
|
|
$modelsdb[$aircraft_icao] = $modelsdb[$model]; |
323
|
|
|
} else { |
324
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20'; |
325
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
326
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
327
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
328
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
329
|
|
|
} |
330
|
|
|
$output .= '},'; |
331
|
|
|
$modelsdb[$aircraft_icao] = 'Cesium_Air.glb'; |
332
|
|
|
} |
333
|
|
|
} elseif ($spotter_item['engine_type'] == 'Turboprop') { |
334
|
|
|
if ($spotter_item['engine_count'] == '1') { |
335
|
|
|
if ($spotter_item['wake_category'] == 'L') { |
336
|
|
|
$model = 'T1L'; |
337
|
|
|
} |
338
|
|
|
} elseif ($spotter_item['engine_count'] == '2') { |
339
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
340
|
|
|
$model = 'T2M'; |
341
|
|
|
} elseif ($spotter_item['wake_category'] == 'L') { |
342
|
|
|
$model = 'T2L'; |
343
|
|
|
} |
344
|
|
|
} elseif ($spotter_item['engine_count'] == '4') { |
345
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
|
|
|
|
346
|
|
|
} elseif ($spotter_item['wake_category'] == 'H') { |
347
|
|
|
$model = 'T4H'; |
348
|
|
|
} |
349
|
|
|
} |
350
|
|
|
if (isset($modelsdb[$model])) { |
351
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$model].'","scale" : 1.0,"minimumPixelSize": 20'; |
352
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
353
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
354
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
355
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
356
|
|
|
} |
357
|
|
|
$output .= '},'; |
358
|
|
|
$modelsdb[$aircraft_icao] = $modelsdb[$model]; |
359
|
|
|
} else { |
360
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20'; |
361
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
362
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
363
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
364
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
365
|
|
|
} |
366
|
|
|
$output .= '},'; |
367
|
|
|
$modelsdb[$aircraft_icao] = 'Cesium_Air.glb'; |
368
|
|
|
} |
369
|
|
|
} elseif ($spotter_item['engine_type'] == 'Piston') { |
370
|
|
|
if ($spotter_item['engine_count'] == '1') { |
371
|
|
|
if ($spotter_item['wake_category'] == 'L') { |
372
|
|
|
$model = 'P1L'; |
373
|
|
|
} elseif ($spotter_item['wake_category'] == 'M') { |
374
|
|
|
$model = 'P1M'; |
375
|
|
|
} |
376
|
|
|
} elseif ($spotter_item['engine_count'] == '2') { |
377
|
|
|
if ($spotter_item['wake_category'] == 'M') { |
378
|
|
|
$model = 'P2M'; |
379
|
|
|
} elseif ($spotter_item['wake_category'] == 'L') { |
380
|
|
|
$model = 'P2L'; |
381
|
|
|
} |
382
|
|
|
// ju52 = P3M |
383
|
|
|
} |
384
|
|
|
if (isset($modelsdb[$model])) { |
385
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$model].'","scale" : 1.0,"minimumPixelSize": 20'; |
386
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
387
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
388
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
389
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
390
|
|
|
} |
391
|
|
|
$output .= '},'; |
392
|
|
|
$modelsdb[$aircraft_icao] = $modelsdb[$model]; |
393
|
|
|
} else { |
394
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20'; |
395
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
396
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
397
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
398
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
399
|
|
|
} |
400
|
|
|
$output .= '},'; |
401
|
|
|
$modelsdb[$aircraft_icao] = 'Cesium_Air.glb'; |
402
|
|
|
} |
403
|
|
|
} else { |
404
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20'; |
405
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
406
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
407
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
408
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
409
|
|
|
} |
410
|
|
|
$output .= '},'; |
411
|
|
|
//if ($spotter_item['aircraft_shadow'] != '') $output .= '"aircraft_shadow": "'.$spotter_item['aircraft_shadow'].'",'; |
412
|
|
|
if ($spotter_item['aircraft_icao'] != '') $output .= '"aircraft_icao": "'.$spotter_item['aircraft_icao'].'",'; |
413
|
|
|
$modelsdb[$aircraft_icao] = 'Cesium_Air.glb'; |
414
|
|
|
} |
415
|
|
|
} elseif (isset($spotter_item['format_source']) && $spotter_item['format_source'] == 'aprs') { |
416
|
|
|
$aircraft_shadow = 'PA18'; |
417
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$aircraft_shadow].'","scale" : 1.0,"minimumPixelSize": 20'; |
418
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
419
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
420
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
421
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
422
|
|
|
} |
423
|
|
|
$output .= '},'; |
424
|
|
|
$modelsdb[$aircraft_icao] = $modelsdb[$aircraft_shadow]; |
425
|
|
|
} else { |
426
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20'; |
427
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
428
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
429
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
430
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
431
|
|
|
} |
432
|
|
|
$output .= '},'; |
433
|
|
|
//if ($spotter_item['aircraft_shadow'] != '') $output .= '"aircraft_shadow": "'.$spotter_item['aircraft_shadow'].'",'; |
434
|
|
|
if ($spotter_item['aircraft_icao'] != '') $output .= '"aircraft_icao": "'.$spotter_item['aircraft_icao'].'",'; |
435
|
|
|
$modelsdb[$aircraft_icao] = 'Cesium_Air.glb'; |
436
|
|
|
} |
437
|
|
|
} else { |
438
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20'; |
439
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
440
|
|
|
//$output .= ',"color": {"rgba" : [255,0,0,255]}'; |
441
|
|
|
if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) { |
442
|
|
|
$rgb = $Common->hex2rgb($_COOKIE['IconColor']); |
443
|
|
|
$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}'; |
444
|
|
|
} |
445
|
|
|
$output .= '},'; |
446
|
|
|
//if ($spotter_item['aircraft_shadow'] != '') $output .= '"aircraft_shadow": "'.$spotter_item['aircraft_shadow'].'",'; |
447
|
|
|
if ($spotter_item['aircraft_icao'] != '') $output .= '"aircraft_icao": "'.$spotter_item['aircraft_icao'].'",'; |
448
|
|
|
$modelsdb[$aircraft_icao] = 'Cesium_Air.glb'; |
449
|
|
|
} |
450
|
|
|
} elseif ($tracker && isset($spotter_item['type'])) { |
451
|
|
|
|
452
|
|
|
if ($spotter_item['type'] == 'Car') { |
453
|
|
|
//$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/car.glb","scale" : 1.0,"minimumPixelSize": 20,'; |
454
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/car.gltf","scale" : 1.0,"minimumPixelSize": 20'; |
455
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
456
|
|
|
$output .= '},'; |
457
|
|
|
} elseif ($spotter_item['type'] == 'Truck' || $spotter_item['type'] == 'Truck (18 Wheeler)') { |
458
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/truck.gltf","scale" : 1.0,"minimumPixelSize": 20'; |
459
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
460
|
|
|
$output .= '},'; |
461
|
|
|
} elseif ($spotter_item['type'] == 'Firetruck') { |
462
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/firetruck.glb","scale" : 1.0,"minimumPixelSize": 20'; |
463
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
464
|
|
|
$output .= '},'; |
465
|
|
|
} elseif ($spotter_item['type'] == 'Bike') { |
466
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/cycle.glb","scale" : 1.0,"minimumPixelSize": 20'; |
467
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
468
|
|
|
$output .= '},'; |
469
|
|
|
} elseif ($spotter_item['type'] == 'Police') { |
470
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/police.glb","scale" : 1.0,"minimumPixelSize": 20'; |
471
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
472
|
|
|
$output .= '},'; |
473
|
|
|
} elseif ($spotter_item['type'] == 'Balloon') { |
474
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/ball.glb","scale" : 1.0,"minimumPixelSize": 20'; |
475
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
476
|
|
|
$output .= '},'; |
477
|
|
|
} elseif ($spotter_item['type'] == 'Ship (Power Boat)' || $spotter_item['type'] == 'Yatch (Sail)') { |
478
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/boat.glb","scale" : 1.0,"minimumPixelSize": 20'; |
479
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
480
|
|
|
$output .= '},'; |
481
|
|
|
} else { |
482
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/truck.gltf","scale" : 1.0,"minimumPixelSize": 20'; |
483
|
|
|
//$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/Cesium_Ground.glb","scale" : 1.0,"minimumPixelSize": 20'; |
484
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
485
|
|
|
$output .= '},'; |
486
|
|
|
} |
487
|
|
|
} elseif ($marine) { |
488
|
|
|
$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/boat.glb","scale" : 1.0,"minimumPixelSize": 20'; |
489
|
|
|
$output .= ',"heightReference": "'.$heightrelative.'"'; |
490
|
|
|
$output .= '},'; |
491
|
|
|
} |
492
|
|
|
// $output .= '"heightReference": "CLAMP_TO_GROUND",'; |
493
|
|
|
$output .= '"heightReference": "'.$heightrelative.'",'; |
494
|
|
|
// $output .= '"heightReference": "NONE",'; |
495
|
|
|
$output .= '"position": {'; |
496
|
|
|
$output .= '"interpolationAlgorithm":"HERMITE","interpolationDegree":3,'; |
497
|
|
|
$output .= '"type": "Point",'; |
498
|
|
|
// $output .= '"interpolationAlgorithm" : "LAGRANGE",'; |
499
|
|
|
// $output .= '"interpolationDegree" : 5,'; |
500
|
|
|
// $output .= '"epoch" : "'.date("c",strtotime($spotter_item['date'])).'", '; |
501
|
|
|
$output .= '"cartographicDegrees": ['; |
502
|
|
|
if ($minitime > strtotime($spotter_item['date'])) $minitime = strtotime($spotter_item['date']); |
503
|
|
|
if ($maxitime < strtotime($spotter_item['date'])) $maxitime = strtotime($spotter_item['date']); |
504
|
|
|
$output .= '"'.date("c",strtotime($spotter_item['date'])).'", '; |
505
|
|
|
$output .= $spotter_item['longitude'].', '; |
506
|
|
|
$output .= $spotter_item['latitude']; |
507
|
|
|
$prevlong = $spotter_item['longitude']; |
508
|
|
|
$prevlat = $spotter_item['latitude']; |
509
|
|
|
if (!$tracker && !$marine) { |
510
|
|
|
$output .= ', '.round($spotter_item['altitude']*30.48); |
511
|
|
|
$prevalt = round($spotter_item['altitude']*30.48); |
512
|
|
|
} else $output .= ', 0'; |
513
|
|
|
//$orientation = '"orientation" : { '; |
514
|
|
|
//$orientation .= '"unitQuaternion": ['; |
515
|
|
|
//$quat = quaternionrotate(deg2rad($spotter_item['heading']),deg2rad(0),deg2rad(0)); |
516
|
|
|
//$orientation .= '"'.date("c",strtotime($spotter_item['date'])).'",'.$quat['x'].','.$quat['y'].','.$quat['z'].','.$quat['w']; |
517
|
|
|
} else { |
518
|
|
|
$output .= ',"'.date("c",strtotime($spotter_item['date'])).'", '; |
519
|
|
|
if ($maxitime < strtotime($spotter_item['date'])) $maxitime = strtotime($spotter_item['date']); |
520
|
|
|
if ($spotter_item['ground_speed'] == 0) { |
521
|
|
|
$output .= $prevlong.', '; |
522
|
|
|
$output .= $prevlat; |
523
|
|
|
if (!$tracker && !$marine) $output .= ', '.$prevalt; |
524
|
|
|
else $output .= ', 0'; |
525
|
|
|
} else { |
526
|
|
|
$output .= $spotter_item['longitude'].', '; |
527
|
|
|
$output .= $spotter_item['latitude']; |
528
|
|
|
if (!$tracker && !$marine) { |
529
|
|
|
if ($spotter_item['altitude'] == '') { |
530
|
|
|
if ($prevalt != '') { |
531
|
|
|
$output .= ', '.$prevalt; |
532
|
|
|
} else { |
533
|
|
|
$output .= ', 0'; |
534
|
|
|
} |
535
|
|
|
} else { |
536
|
|
|
$output .= ', '.round($spotter_item['altitude']*30.48); |
537
|
|
|
} |
538
|
|
|
} else $output .= ', 0'; |
539
|
|
|
} |
540
|
|
|
//$quat = quaternionrotate(deg2rad($spotter_item['heading']),deg2rad(0),deg2rad(0)); |
541
|
|
|
//$orientation .= ',"'.date("c",strtotime($spotter_item['date'])).'",'.$quat['x'].','.$quat['y'].','.$quat['z'].','.$quat['w']; |
542
|
|
|
} |
543
|
|
|
} |
544
|
|
|
//$output = substr($output, 0, -1); |
545
|
|
|
$output .= ']}}'; |
546
|
|
|
} else { |
547
|
|
|
$output = substr($output, 0, -1); |
548
|
|
|
} |
549
|
|
|
$output .= ']'; |
550
|
|
|
$output = str_replace('%minitime%',date("c",$minitime),$output); |
551
|
|
|
$output = str_replace('%maxitime%',date("c",$maxitime),$output); |
552
|
|
|
print $output; |
553
|
|
|
?> |
554
|
|
|
|
This check looks for the bodies of
if
statements that have no statements or where all statements have been commented out. This may be the result of changes for debugging or the code may simply be obsolete.These
if
bodies can be removed. If you have an empty if but statements in theelse
branch, consider inverting the condition.could be turned into
This is much more concise to read.