Completed
Push — master ( 0ab128...e37ce2 )
by Yannick
07:35
created

live-czml.php ➔ quaternionrotate()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 18
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

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