Completed
Push — master ( 4c9919...b817a3 )
by Yannick
121:29 queued 94:05
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
$modelsdb = array();
178
if (file_exists(dirname(__FILE__).'/models/modelsdb')) {
179
	if (($handle = fopen(dirname(__FILE__).'/models/modelsdb','r')) !== FALSE) {
180
		while (($row = fgetcsv($handle,1000)) !== FALSE) {
181
			if (isset($row[1]) ){
182
				$model = $row[0];
183
				$modelsdb[$model] = $row[1];
184
			}
185
		}
186
		fclose($handle);
187
	}
188
}
189
$heightrelative = 'NONE';
190
//$heightrelative = 'RELATIVE_TO_GROUND';
191
$j = 0;
192
$prev_flightaware_id = '';
193
$speed = 1;
194
if (isset($archivespeed)) $speed = $archivespeed;
195
$output = '[';
196
if ($tracker) {
197
	$output .= '{"id" : "document", "name" : "tracker","version" : "1.0"';
198
} elseif ($marine) {
199
	$output .= '{"id" : "document", "name" : "marine","version" : "1.0"';
200
} else {
201
	$output .= '{"id" : "document", "name" : "fam","version" : "1.0"';
202
}
203
//	$output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "LOOP_STOP","step": "SYSTEM_CLOCK_MULTIPLIER"}';
204
205
//	$output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}';
206
//$output .= ',"clock": {"currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}';
207
if ($from_archive === true) {
208
	$output .= ',"clock": {"currentTime" : "%minitime%","multiplier" : '.$speed.',"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER","interval": "%minitime%/%maxitime%"}';
209
} else {
210
	$output .= ',"clock": {"currentTime" : "%minitime%","multiplier" : '.$speed.',"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}';
211
}
212
213
//	$output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"step": "SYSTEM_CLOCK_MULTIPLIER"}';
214
$output .= '},';
215
if (!empty($spotter_array) && is_array($spotter_array))
216
{
217
	foreach($spotter_array as $spotter_item)
218
	{
219
		$j++;
220
		//if (isset($spotter_item['format_source']) && $spotter_item['format_source'] == 'airwhere') $heightrelative = 'RELATIVE_TO_GROUND';
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
			$output .= '"onground": %onground%,';
245
			$output .= '"format": "'.$spotter_item['format_source'].'"';
246
			$output .= '},';
247
248
			$output .= '"path" : { ';
249
			$output .= '"show" : false, ';
250
			//$output .= '"heightReference": "'.$heightrelative.'",';
251
			$output .= '"material" : { ';
252
			$output .= '"polylineOutline" : { ';
253
			$output .= '"color" : { "rgba" : [238, 250, 255, 255] }, ';
254
			$output .= '"outlineColor" : { "rgba" : [200, 209, 214, 255] }, ';
255
			$output .= '"outlineWidth" : 5, ';
256
			$output .= '"polylineGlow" : { "color" : { "rgba" : [214, 208, 214, 255] }, "glowPower" : 3 } ';
257
			$output .= '}';
258
			$output .= '}, ';
259
			//$output .= '"heightReference": "'.$heightrelative.'",';
260
			$output .= '"width" : 6, "leadTime" : 0, "trailTime" : 100000000, "resolution" : 20 },';
261
			//$output .= '"heightReference": "'.$heightrelative.'",';
262
			//$output .= ' "billboard" : {"image" : "","scale" : 1.5},';
263
			if ($no3dmodels) {
264
				if (isset($spotter_item['aircraft_icao'])) {
265
					$aircraft_icao = $spotter_item['aircraft_icao'];
266
					if ($aircraft_icao != '') {
267
						$aircraft_info = $Spotter->getAllAircraftInfo($aircraft_icao);
268
						if (isset($aircraft_info[0]['engine_type'])) {
269
							$aircraft_shadow = $aircraft_info[0]['aircraft_shadow'];
270
							$spotter_item['engine_type'] = $aircraft_info[0]['engine_type'];
271
							$spotter_item['wake_category'] = $aircraft_info[0]['wake_category'];
272
							$spotter_item['engine_count'] = $aircraft_info[0]['engine_count'];
273
						} else $aircraft_shadow = '';
274
	    					$output .= ' "billboard" : {"image" : "'.$globalURL.'/images/aircrafts/new/'.$aircraft_shadow.'","scale" : 0.5';
275
						if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
276
							$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
277
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
278
						}
279
						$output .= '},';
280
					}
281
				} else $output .= ' "billboard" : {"image" : "","scale" : 0.5},';
282
			} elseif ($one3dmodel) {
283
				if (isset($globalMap3DForceModel) && $globalMap3DForceModel != '') {
284
					$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$globalMap3DForceModel.'","scale" : 1.0,"minimumPixelSize": 20';
285
				} else {
286
					$output .= '"model": {"gltf" : "'.$globalURL.'/models/737.glb","scale" : 1.0,"minimumPixelSize": 20';
287
				}
288
				$output .= ',"heightReference": "'.$heightrelative.'"';
289
				if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
290
					$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
291
					$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
292
				}
293
				$output .= '},';
294
			} else {
295
				if (isset($spotter_item['aircraft_icao'])) {
296
					$aircraft_icao = $spotter_item['aircraft_icao'];
297
					if (isset($modelsdb[$aircraft_icao])) {
298
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$aircraft_icao].'","scale" : 1.0,"minimumPixelSize": 20';
299
						$output .= ',"heightReference": "'.$heightrelative.'"';
300
						if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
301
							$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
302
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
303
						}
304
    						$output .= '},';
305
					} elseif ($aircraft_icao != '') {
306
						$aircraft_info = $Spotter->getAllAircraftInfo($aircraft_icao);
307
						if (isset($aircraft_info[0]['engine_type'])) {
308
							$aircraft_shadow = $aircraft_info[0]['aircraft_shadow'];
309
							$spotter_item['engine_type'] = $aircraft_info[0]['engine_type'];
310
							$spotter_item['wake_category'] = $aircraft_info[0]['wake_category'];
311
							$spotter_item['engine_count'] = $aircraft_info[0]['engine_count'];
312
						} else $aircraft_shadow = '';
313
						if ($aircraft_shadow != '') {
314
							if (isset($modelsdb[$aircraft_shadow])) {
315
								$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$aircraft_shadow].'","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[$aircraft_shadow];
323
							} elseif ($spotter_item['engine_type'] == 'Jet') {
324
								if ($spotter_item['engine_count'] == '1') {
325
									if ($spotter_item['wake_category'] == 'M') {
326
										$model = 'J1M';
327
									} elseif ($spotter_item['wake_category'] == 'L') {
328
										$model = '';
329
									}
330
								} elseif ($spotter_item['engine_count'] == '2') {
331
									if ($spotter_item['wake_category'] == 'M') {
332
										$model = 'J2M';
333
									} elseif ($spotter_item['wake_category'] == 'H') {
334
										$model = 'J2H';
335
									} elseif ($spotter_item['wake_category'] == 'L') {
336
										$model = 'J2L';
337
									}
338
								} elseif ($spotter_item['engine_count'] == '3') {
339
									if ($spotter_item['wake_category'] == 'M') {
340
										$model = 'J3M';
341
									} elseif ($spotter_item['wake_category'] == 'H') {
342
										$model = 'J3H';
343
									}
344
								} elseif ($spotter_item['engine_count'] == '4') {
345
									if ($spotter_item['wake_category'] == 'M') {
346
										$model = 'J4M';
347
									} elseif ($spotter_item['wake_category'] == 'H') {
348
										$model = 'J4H';
349
									}
350
								}
351
								if (isset($modelsdb[$model])) {
352
									$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$model].'","scale" : 1.0,"minimumPixelSize": 20';
353
									$output .= ',"heightReference": "'.$heightrelative.'"';
354
									if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
355
										$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
356
										$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
357
									}
358
									$output .= '},';
359
									$modelsdb[$aircraft_icao] = $modelsdb[$model];
360
								} else {
361
									$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20';
362
									$output .= ',"heightReference": "'.$heightrelative.'"';
363
									if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
364
										$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
365
										$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
366
									}
367
									$output .= '},';
368
									$modelsdb[$aircraft_icao] = 'Cesium_Air.glb';
369
								}
370
							} elseif ($spotter_item['engine_type'] == 'Turboprop') {
371
								if ($spotter_item['engine_count'] == '1') {
372
									if ($spotter_item['wake_category'] == 'L') {
373
										$model = 'T1L';
374
									}
375
								} elseif ($spotter_item['engine_count'] == '2') {
376
									if ($spotter_item['wake_category'] == 'M') {
377
										$model = 'T2M';
378
									} elseif ($spotter_item['wake_category'] == 'L') {
379
										$model = 'T2L';
380
									}
381
								} elseif ($spotter_item['engine_count'] == '4') {
382
									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...
383
									} elseif ($spotter_item['wake_category'] == 'H') {
384
										$model = 'T4H';
385
									}
386
								}
387
								if (isset($modelsdb[$model])) {
388
									$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$model].'","scale" : 1.0,"minimumPixelSize": 20';
389
									$output .= ',"heightReference": "'.$heightrelative.'"';
390
									if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
391
										$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
392
										$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
393
									}
394
									$output .= '},';
395
									$modelsdb[$aircraft_icao] = $modelsdb[$model];
396
								} else {
397
									$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20';
398
									$output .= ',"heightReference": "'.$heightrelative.'"';
399
									if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
400
										$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
401
										$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
402
									}
403
									$output .= '},';
404
									$modelsdb[$aircraft_icao] = 'Cesium_Air.glb';
405
								}
406
							} elseif ($spotter_item['engine_type'] == 'Piston') {
407
								if ($spotter_item['engine_count'] == '1') {
408
									if ($spotter_item['wake_category'] == 'L') {
409
										$model = 'P1L';
410
									} elseif ($spotter_item['wake_category'] == 'M') {
411
										$model = 'P1M';
412
									}
413
								} elseif ($spotter_item['engine_count'] == '2') {
414
									if ($spotter_item['wake_category'] == 'M') {
415
										$model = 'P2M';
416
									} elseif ($spotter_item['wake_category'] == 'L') {
417
										$model = 'P2L';
418
									}
419
									// ju52 = P3M
420
								}
421
								if (isset($modelsdb[$model])) {
422
									$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$model].'","scale" : 1.0,"minimumPixelSize": 20';
423
									$output .= ',"heightReference": "'.$heightrelative.'"';
424
									if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
425
										$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
426
										$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
427
									}
428
									$output .= '},';
429
									$modelsdb[$aircraft_icao] = $modelsdb[$model];
430
								} else {
431
									$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20';
432
									$output .= ',"heightReference": "'.$heightrelative.'"';
433
									if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
434
										$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
435
										$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
436
									}
437
									$output .= '},';
438
									$modelsdb[$aircraft_icao] = 'Cesium_Air.glb';
439
								}
440
							} else {
441
								$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20';
442
								$output .= ',"heightReference": "'.$heightrelative.'"';
443
								if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
444
									$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
445
									$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
446
								}
447
								$output .= '},';
448
								//if ($spotter_item['aircraft_shadow'] != '') $output .= '"aircraft_shadow": "'.$spotter_item['aircraft_shadow'].'",';
449
								if ($spotter_item['aircraft_icao'] != '') $output .= '"aircraft_icao": "'.$spotter_item['aircraft_icao'].'",';
450
								$modelsdb[$aircraft_icao] = 'Cesium_Air.glb';
451
							}
452
						} elseif (isset($spotter_item['format_source']) && $spotter_item['format_source'] == 'aprs') {
453
							$aircraft_shadow = 'PA18';
454
							$output .= '"model": {"gltf" : "'.$globalURL.'/models/'.$modelsdb[$aircraft_shadow].'","scale" : 1.0,"minimumPixelSize": 20';
455
							$output .= ',"heightReference": "'.$heightrelative.'"';
456
							if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
457
								$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
458
								$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
459
							}
460
							$output .= '},';
461
							$modelsdb[$aircraft_icao] = $modelsdb[$aircraft_shadow];
462
						} else {
463
							$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20';
464
							$output .= ',"heightReference": "'.$heightrelative.'"';
465
							if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
466
								$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
467
								$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
468
							}
469
							$output .= '},';
470
							//if ($spotter_item['aircraft_shadow'] != '') $output .= '"aircraft_shadow": "'.$spotter_item['aircraft_shadow'].'",';
471
							if ($spotter_item['aircraft_icao'] != '') $output .= '"aircraft_icao": "'.$spotter_item['aircraft_icao'].'",';
472
							$modelsdb[$aircraft_icao] = 'Cesium_Air.glb';
473
						}
474
					} else {
475
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/Cesium_Air.glb","scale" : 1.0,"minimumPixelSize": 20';
476
						$output .= ',"heightReference": "'.$heightrelative.'"';
477
						//$output .= ',"color": {"rgba" : [255,0,0,255]}';
478
						if (isset($_COOKIE['IconColorForce']) && $_COOKIE['IconColorForce'] && isset($_COOKIE['IconColor'])) {
479
							$rgb = $Common->hex2rgb($_COOKIE['IconColor']);
480
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
481
						}
482
						$output .= '},';
483
						//if ($spotter_item['aircraft_shadow'] != '') $output .= '"aircraft_shadow": "'.$spotter_item['aircraft_shadow'].'",';
484
						if ($spotter_item['aircraft_icao'] != '') $output .= '"aircraft_icao": "'.$spotter_item['aircraft_icao'].'",';
485
						$modelsdb[$aircraft_icao] = 'Cesium_Air.glb';
486
					}
487
				} elseif ($tracker && isset($spotter_item['type'])) {
488
					if ($spotter_item['type'] == 'Car' || $spotter_item['type'] == 'Van') {
489
						$onground = true;
490
						//$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/car.glb","scale" : 1.0,"minimumPixelSize": 20,';
491
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/car.gltf","scale" : 1.0,"minimumPixelSize": 20';
492
						//$output .= ',"heightReference": "'.$heightrelative.'"';
493
						$output .= ',"heightReference": "CLAMP_TO_GROUND"';
494
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
495
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
496
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
497
							$output .= ',"colorBlendMode" : "MIX"';
498
						}
499
						$output .= '},';
500
					} elseif ($spotter_item['type'] == 'Truck' || $spotter_item['type'] == 'Truck (18 Wheeler)') {
501
						$onground = true;
502
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/truck.gltf","scale" : 1.0,"minimumPixelSize": 10';
503
						//$output .= ',"heightReference": "'.$heightrelative.'"';
504
						$output .= ',"heightReference": "CLAMP_TO_GROUND"';
505
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
506
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
507
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
508
							$output .= ',"colorBlendMode" : "MIX"';
509
						}
510
						$output .= '},';
511
					} elseif ($spotter_item['type'] == 'Firetruck') {
512
						$onground = true;
513
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/firetruck.glb","scale" : 1.0,"minimumPixelSize": 0';
514
						//$output .= ',"heightReference": "'.$heightrelative.'"';
515
						$output .= ',"heightReference": "CLAMP_TO_GROUND"';
516
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
517
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
518
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
519
							$output .= ',"colorBlendMode" : "MIX"';
520
						}
521
						$output .= '},';
522
					} elseif ($spotter_item['type'] == 'Bike') {
523
						$onground = true;
524
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/cycle.glb","scale" : 1.0,"minimumPixelSize": 20';
525
						//$output .= ',"heightReference": "'.$heightrelative.'"';
526
						$output .= ',"heightReference": "CLAMP_TO_GROUND"';
527
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
528
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
529
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
530
							$output .= ',"colorBlendMode" : "MIX"';
531
						}
532
						$output .= '},';
533
					} elseif ($spotter_item['type'] == 'Police') {
534
						$onground = true;
535
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/police.glb","scale" : 1.0,"minimumPixelSize": 20';
536
						//$output .= ',"heightReference": "'.$heightrelative.'"';
537
						$output .= ',"heightReference": "CLAMP_TO_GROUND"';
538
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
539
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
540
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
541
							$output .= ',"colorBlendMode" : "MIX"';
542
						}
543
						$output .= '},';
544
					} elseif ($spotter_item['type'] == 'Balloon') {
545
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/ball.glb","scale" : 1.0,"minimumPixelSize": 20';
546
						$output .= ',"heightReference": "'.$heightrelative.'"';
547
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
548
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
549
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
550
							$output .= ',"colorBlendMode" : "MIX"';
551
						}
552
						$output .= '},';
553
					} elseif ($spotter_item['type'] == 'Ship (Power Boat)' || $spotter_item['type'] == 'Yatch (Sail)') {
554
						$onground = true;
555
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/boat.glb","scale" : 1.0,"minimumPixelSize": 20';
556
						//$output .= ',"heightReference": "'.$heightrelative.'"';
557
						$output .= ',"heightReference": "CLAMP_TO_GROUND"';
558
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
559
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
560
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
561
							$output .= ',"colorBlendMode" : "MIX"';
562
						}
563
						$output .= '},';
564
					} else {
565
						$onground = true;
566
						$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/car.gltf","scale" : 1.0,"minimumPixelSize": 20';
567
						//$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/Cesium_Ground.glb","scale" : 1.0,"minimumPixelSize": 20';
568
						$output .= ',"heightReference": "'.$heightrelative.'"';
569
						if (isset($_COOKIE['TrackerIconColorForce']) && $_COOKIE['TrackerIconColorForce'] && isset($_COOKIE['TrackerIconColor'])) {
570
							$rgb = $Common->hex2rgb($_COOKIE['TrackerIconColor']);
571
							$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
572
							$output .= ',"colorBlendMode" : "MIX"';
573
						}
574
						$output .= '},';
575
					}
576
				} elseif ($marine) {
577
					$output .= '"model": {"gltf" : "'.$globalURL.'/models/vehicules/boat.glb","scale" : 1.0,"minimumPixelSize": 20';
578
					$output .= ',"heightReference": "'.$heightrelative.'"';
579
					//$output .= ',"heightReference": "CLAMP_TO_GROUND"';
580
					if (isset($_COOKIE['MarineIconColorForce']) && $_COOKIE['MarineIconColorForce'] && isset($_COOKIE['MarineIconColor'])) {
581
						$rgb = $Common->hex2rgb($_COOKIE['MarineIconColor']);
582
						$output .= ',"color": {"rgba" : ['.$rgb[0].','.$rgb[1].','.$rgb[2].',255]}';
583
						$output .= ',"colorBlendMode" : "MIX"';
584
					}
585
					$output .= '},';
586
				}
587
			}
588
			if ($onground) $output = str_replace('%onground%','true',$output);
589
			else $output = str_replace('%onground%','false',$output);
590
591
	//		$output .= '"heightReference": "CLAMP_TO_GROUND",';
592
			//$output .= '"heightReference": "'.$heightrelative.'",';
593
	//		$output .= '"heightReference": "NONE",';
594
			$output .= '"position": {';
595
			$output .= '"interpolationAlgorithm":"HERMITE","interpolationDegree":3,';
596
			//$output .= '"heightReference": "'.$heightrelative.'",';
597
			$output .= '"type": "Point",';
598
	//		$output .= '"interpolationAlgorithm" : "LAGRANGE",';
599
	//		$output .= '"interpolationDegree" : 5,';
600
	//		$output .= '"epoch" : "'.date("c",strtotime($spotter_item['date'])).'", ';
601
			$output .= '"cartographicDegrees": [';
602
			if ($minitime > strtotime($spotter_item['date'])) $minitime = strtotime($spotter_item['date']);
603
			if ($maxitime < strtotime($spotter_item['date'])) $maxitime = strtotime($spotter_item['date']);
604
			$output .= '"'.date("c",strtotime($spotter_item['date'])).'", ';
605
			$output .= $spotter_item['longitude'].', ';
606
			$output .= $spotter_item['latitude'];
607
			$prevlong = $spotter_item['longitude'];
608
			$prevlat = $spotter_item['latitude'];
609
			//if (!$tracker && !$marine) {
610
			//if (!$marine && (!isset($onground) || !$onground)) {
611
			if (!$marine) {
612
				if (isset($spotter_item['real_altitude']) && $spotter_item['real_altitude'] != '') {
613
					$output .= ', '.round($spotter_item['real_altitude']*0.3048);
614
					if ($tracker) {
615
						$prevalt = round($spotter_item['real_altitude']*0.3048);
616
					} else {
617
						$prevalt = round($spotter_item['real_altitude']*30.48);
618
					}
619
				} elseif ($tracker) {
620
					$output .= ', '.round($spotter_item['altitude']*0.3048);
621
					$prevalt = round($spotter_item['altitude']*0.3048);
622
				} else {
623
					$output .= ', '.round($spotter_item['altitude']*30.48);
624
					$prevalt = round($spotter_item['altitude']*30.48);
625
				}
626
			} else $output .= ', 0';
627
			//$orientation = '"orientation" : { ';
628
			//$orientation .= '"unitQuaternion": [';
629
			//$quat = quaternionrotate(deg2rad($spotter_item['heading']),deg2rad(0),deg2rad(0));
630
			//$orientation .= '"'.date("c",strtotime($spotter_item['date'])).'",'.$quat['x'].','.$quat['y'].','.$quat['z'].','.$quat['w'];
631
		} else {
632
			$output .= ',"'.date("c",strtotime($spotter_item['date'])).'", ';
633
			if ($maxitime < strtotime($spotter_item['date'])) $maxitime = strtotime($spotter_item['date']);
634
			if ($spotter_item['ground_speed'] == 0) {
635
				$output .= $prevlong.', ';
636
				$output .= $prevlat;
637
				//if (!$marine && (!isset($onground) || !$onground)) $output .= ', '.$prevalt;
638
				if (!$marine) $output .= ', '.$prevalt;
639
				else $output .= ', 0';
640
			} else {
641
				$output .= $spotter_item['longitude'].', ';
642
				$output .= $spotter_item['latitude'];
643
				//if (!$marine && (!isset($onground) || !$onground)) {
644
				if (!$marine) {
645
					if ($spotter_item['altitude'] == '') {
646
						if ($prevalt != '') {
647
							$output .= ', '.$prevalt;
648
						} else {
649
							$output .= ', 0';
650
						}
651
					} else {
652
						if (isset($spotter_item['real_altitude']) && $spotter_item['real_altitude'] != '') $output .= ', '.round($spotter_item['real_altitude']*0.3048);
653
						elseif ($tracker) {
654
							$output .= ', '.round($spotter_item['altitude']*0.3048);
655
						} else {
656
							$output .= ', '.round($spotter_item['altitude']*30.48);
657
						}
658
					}
659
				} else $output .= ', 0';
660
			}
661
			//$quat = quaternionrotate(deg2rad($spotter_item['heading']),deg2rad(0),deg2rad(0));
662
			//$orientation .= ',"'.date("c",strtotime($spotter_item['date'])).'",'.$quat['x'].','.$quat['y'].','.$quat['z'].','.$quat['w'];
663
		}
664
	}
665
	//$output  = substr($output, 0, -1);
666
	$output .= ']}}';
667
} else {
668
	$output  = substr($output, 0, -1);
669
}
670
$output .= ']';
671
if (isset($globalArchive) && $globalArchive === TRUE) {
672
	if ((time()-$globalLiveInterval) > $minitime) {
673
		if (time()-$globalLiveInterval > $maxitime) {
674
			$output = str_replace('%minitime%',date("c",$maxitime),$output);
675
		} else {
676
			$output = str_replace('%minitime%',date("c",time()-$globalLiveInterval),$output);
677
		}
678
	}
679
	else $output = str_replace('%minitime%',date("c",$minitime),$output);
680
} else $output = str_replace('%minitime%',date("c",$minitime),$output);
681
$output = str_replace('%maxitime%',date("c",$maxitime),$output);
682
print $output;
683
?>
684