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