-
Notifications
You must be signed in to change notification settings - Fork 159
/
live-sat-czml.php
176 lines (166 loc) · 14.4 KB
/
live-sat-czml.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
<?php
require_once('require/class.Connection.php');
require_once('require/class.Common.php');
require_once('require/class.Satellite.php');
date_default_timezone_set('UTC');
//$begintime = microtime(true);
$Satellite = new Satellite();
$Common = new Common();
if (isset($_GET['download'])) {
if ($_GET['download'] == "true")
{
header('Content-disposition: attachment; filename="flightairmap-sat.json"');
}
}
header('Content-Type: text/javascript');
$timeb = time();
//$sqltime = round(microtime(true)-$begintime,2);
$spotter_array = array();
if (isset($_COOKIE['sattypes']) && $_COOKIE['sattypes'] != '') {
$sattypes = explode(',',$_COOKIE['sattypes']);
foreach ($sattypes as $sattype) {
$spotter_array = array_merge($Satellite->position_all_type($sattype,$timeb-$globalLiveInterval,$timeb),$spotter_array);
}
}
if ((isset($_COOKIE['displayiss']) && $_COOKIE['displayiss'] == 'true') || !isset($_COOKIE['displayiss'])) {
$spotter_array = array_merge($Satellite->position('ISS (ZARYA)',time()-$globalLiveInterval,time()),$spotter_array);
$spotter_array = array_merge($Satellite->position('TIANGONG 1',time()-$globalLiveInterval,time()),$spotter_array);
$spotter_array = array_merge($Satellite->position('TIANGONG-2',time()-$globalLiveInterval,time()),$spotter_array);
}
$spotter_array = array_unique($spotter_array,SORT_REGULAR);
/*
$modelsdb = array();
if (file_exists('models/space/space_modelsdb')) {
if (($handle = fopen('models/space/space_modelsdb','r')) !== FALSE) {
while (($row = fgetcsv($handle,1000)) !== FALSE) {
if (isset($row[1]) ){
$model = $row[0];
$modelsdb[$model] = $row[1];
}
}
fclose($handle);
}
}
*/
//print_r($spotter_array);
$j = 0;
$prev_satname = '';
$output = '[';
$output .= '{"id" : "document", "name" : "famsat","version" : "1.0"';
// $output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "LOOP_STOP","step": "SYSTEM_CLOCK_MULTIPLIER"}';
// $output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}';
$output .= ',"clock": {"currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}';
//$output .= ',"clock": {"currentTime" : "%minitime%","multiplier" : 1,"range" : "UNBOUNDED","step": "SYSTEM_CLOCK_MULTIPLIER"}';
// $output .= ',"clock": {"interval" : "'.date("c",time()-$globalLiveInterval).'/'.date("c").'","currentTime" : "'.date("c",time() - $globalLiveInterval).'","multiplier" : 1,"step": "SYSTEM_CLOCK_MULTIPLIER"}';
$output .= '},';
if (!empty($spotter_array) && is_array($spotter_array))
{
foreach($spotter_array as $spotter_item)
{
$j++;
date_default_timezone_set('UTC');
if ($prev_satname != $spotter_item['name']) {
if ($prev_satname != '') {
$output .= ']';
$output .= '}';
//$output .= ', '.$orientation.']}';
$output .= '},';
}
$orientation = '';
$prev_satname = $spotter_item['name'];
$output .= '{';
//$output .= '"id": "'.urlencode(trim(str_replace(array('[+]','[-]'),'',$spotter_item['name']))).'",';
$output .= '"id": "'.urlencode($spotter_item['name']).'",';
$output .= '"properties": {';
// Not yet supported in CZML with Cesium
$output .= '},';
$output .= '"path" : { ';
$output .= '"show" : false, ';
$output .= '"material" : { ';
$output .= '"polylineOutline" : { ';
$output .= '"color" : { "rgba" : [238, 250, 255, 255] }, ';
$output .= '"outlineColor" : { "rgba" : [200, 209, 214, 255] }, ';
$output .= '"outlineWidth" : 5, ';
$output .= '"polylineGlow" : { "color" : { "rgba" : [214, 208, 214, 255] }, "glowPower" : 3 } ';
$output .= '}';
$output .= '}, ';
$output .= '"width" : 6, "leadTime" : 0, "trailTime" : 1000000, "resolution" : 10 },';
//$output .= ' "billboard" : {"image" : "","scale" : 1.5},';
if (file_exists('models/space/iss.glb')) {
if ($spotter_item['name'] == 'ISS (ZARYA)') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/iss.glb'.'","scale" : 1.0,"minimumPixelSize": 50,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'TIANGONG 1') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/tiangong1.glb'.'","scale" : 1.0,"minimumPixelSize": 50,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'TIANGONG-2') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/tiangong1.glb'.'","scale" : 1.0,"minimumPixelSize": 50,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'IBEX') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/ibex.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'SDO') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/sdo.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'INTEGRAL') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/integral.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'AQUA') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/aqua.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'MINXSS') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/cubiesat.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['name'] == 'TERRA') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/terra.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'O3B') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/o3b.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'GLOBALSTAR') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/globalstar.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'GPS') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/gps.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'GENESIS') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/genesis.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'OSCAR 7') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/oscar7.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'FLOCK') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/cubesat.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'PLEIADES') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/pleiades.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'DUCHIFAT') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/duchifat.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif (strpos($spotter_item['name'],'FORMOSAT-2') !== false) {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/formosat2.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['type'] == 'iridium') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/iridium.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['type'] == 'geo') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/geo.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} elseif ($spotter_item['type'] == 'cubesat') {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/cubesat.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
} else {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/sat.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
}
} else {
$output .= '"model": {"gltf" : "'.$globalURL.'/models/space/sat.glb'.'","scale" : 1.0,"minimumPixelSize": 25,"maximunPixelSize": 300 },';
}
$output .= '"heightReference": "CLAMP_TO_GROUND",';
$output .= '"position": {';
$output .= '"type": "Point",';
// $output .= '"interpolationAlgorithm" : "LAGRANGE",';
// $output .= '"interpolationDegree" : 5,';
// $output .= '"epoch" : "'.date("c",strtotime($spotter_item['date'])).'", ';
$output .= '"interpolationAlgorithm":"HERMITE","interpolationDegree":3,';
$output .= '"cartographicDegrees": [';
$output .= '"'.date("c",$spotter_item['timestamp']).'", ';
$output .= $spotter_item['longitude'].', ';
$output .= $spotter_item['latitude'].', ';
$output .= $spotter_item['altitude']*1000;
$orientation = '"orientation" : { ';
$orientation .= '"unitQuaternion": [';
} else {
$output .= ',"'.date("c",$spotter_item['timestamp']).'", ';
$output .= $spotter_item['longitude'].', ';
$output .= $spotter_item['latitude'].', ';
$output .= $spotter_item['altitude']*1000;
}
}
$output = substr($output, 0, -1);
$output .= ']}}';
} else {
$output = substr($output, 0, -1);
}
$output .= ']';
print $output;
?>