๐Ÿ“ฆ Turbo87 / aeroscore

๐Ÿ“„ show-aat-path.ts ยท 36 lines
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
36import * as turf from '@turf/helpers';

import {Fix, readFlight} from '../src/read-flight';
import {readTask} from '../src/read-task';
import {taskToGeoJSON} from '../src/task-to-geojson';
import AreaTaskSolver from '../src/task/solver/area-task-solver';
import {viewGeoJSON} from './utils/view-geojson';

if (process.argv.length < 4) {
  console.log('Usage: ts-node examples/show-aat-path.ts TASK_PATH IGC_PATH');
  process.exit(1);
}

let taskPath = process.argv[2];
let task = readTask(taskPath);

if (!task.options.isAAT) {
  console.log('Only AAT tasks are supported');
  process.exit(1);
}

let flightPath = process.argv[3];
let flight = readFlight(flightPath);

let solver = new AreaTaskSolver(task);

solver.consume(flight);

let path = solver.result.path as Fix[];

let json = taskToGeoJSON(task);
json.features.push(turf.lineString(flight.map(it => it.coordinate), { color: 'red', opacity: 0.85 }));
json.features.push(turf.lineString(path.map(it => it.coordinate), { color: '#00ff00', opacity: 0.85 }));

viewGeoJSON(json);