Completed
Push — master ( 04cf69...7bb360 )
by Yannick
26:49
created

live-czml.php (1 issue)

Severity

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

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" : "data:image/png;base64,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","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') {
0 ignored issues
show
This if statement is empty and can be removed.

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 the else branch, consider inverting the condition.

if (rand(1, 6) > 3) {
//print "Check failed";
} else {
    print "Check succeeded";
}

could be turned into

if (rand(1, 6) <= 3) {
    print "Check succeeded";
}

This is much more concise to read.

Loading history...
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