RegionChooserCommandLineInterface.java 2.87 KB
Newer Older
Eric Duminil's avatar
Eric Duminil committed
1
2
package eu.simstadt.regionchooser;

Eric Duminil's avatar
Eric Duminil committed
3
import java.nio.charset.StandardCharsets;
Eric Duminil's avatar
Eric Duminil committed
4
import java.nio.file.Files;
Eric Duminil's avatar
Eric Duminil committed
5
import java.nio.file.Path;
Eric Duminil's avatar
Eric Duminil committed
6
import java.nio.file.Paths;
Eric Duminil's avatar
Eric Duminil committed
7
import java.util.Scanner;
Eric Duminil's avatar
Eric Duminil committed
8
import java.util.concurrent.Callable;
Eric Duminil's avatar
Eric Duminil committed
9
import org.osgeo.proj4j.CoordinateReferenceSystem;
Eric Duminil's avatar
Eric Duminil committed
10
11
import picocli.CommandLine;
import picocli.CommandLine.Command;
Eric Duminil's avatar
Eric Duminil committed
12
import picocli.CommandLine.Option;
Eric Duminil's avatar
Eric Duminil committed
13
14


Eric Duminil's avatar
Eric Duminil committed
15
@Command(name = "region_chooser", mixinStandardHelpOptions = true, version = "regionChooser x.x", description = "Extracts a region from one or more citygmls.", sortOptions = false)
Eric Duminil's avatar
Eric Duminil committed
16
class RegionChooserCommandLineInterface implements Callable<Integer>
Eric Duminil's avatar
Eric Duminil committed
17
{
Eric Duminil's avatar
Eric Duminil committed
18
19
	@Option(names = { "-i",
			"--input" }, required = true, split = ",", description = "Citygml files to extract from", paramLabel = "input.gml")
Eric Duminil's avatar
Eric Duminil committed
20
	Path[] citygmls;
Eric Duminil's avatar
Eric Duminil committed
21

Eric Duminil's avatar
Eric Duminil committed
22
23
	@Option(names = { "-o",
			"--output" }, required = true, description = "Output file", paramLabel = "output.gml")
Eric Duminil's avatar
Eric Duminil committed
24
	Path outputCityGML;
Eric Duminil's avatar
Eric Duminil committed
25

Eric Duminil's avatar
Eric Duminil committed
26
27
	@Option(names = { "-e", "--epsg" }, description = "EPSG id for coordinate reference system", paramLabel = "31467")
	Integer espgId;
Eric Duminil's avatar
Eric Duminil committed
28

Eric Duminil's avatar
Eric Duminil committed
29
30
31
	@Option(names = { "-l",
			"--local" }, description = "Are WKT coordinates in local CRS?", paramLabel = "local_coordinates?")
	boolean localCoordinates;
Eric Duminil's avatar
Eric Duminil committed
32

Eric Duminil's avatar
Eric Duminil committed
33
34
	@Option(names = { "-w",
			"--wkt" }, description = "File containing WKT polygon, or - for stdin", paramLabel = "polygon.wkt")
Eric Duminil's avatar
Eric Duminil committed
35
36
	String wktFile = "-";

Eric Duminil's avatar
Eric Duminil committed
37
	@Override
Eric Duminil's avatar
Eric Duminil committed
38
	public Integer call() throws Exception {
Eric Duminil's avatar
Eric Duminil committed
39
		CoordinateReferenceSystem localCRS;
Eric Duminil's avatar
Eric Duminil committed
40

Eric Duminil's avatar
Eric Duminil committed
41
		if (espgId == null) {
Eric Duminil's avatar
Eric Duminil committed
42
			localCRS = RegionChooserUtils.crsFromCityGMLHeader(citygmls[0]);
Eric Duminil's avatar
Eric Duminil committed
43
		} else {
Eric Duminil's avatar
Eric Duminil committed
44
			localCRS = RegionChooserUtils.crsFromSrsName("EPSG:" + espgId);
Eric Duminil's avatar
Eric Duminil committed
45
		}
Eric Duminil's avatar
Eric Duminil committed
46

Eric Duminil's avatar
Eric Duminil committed
47
		String wktPolygon;
Eric Duminil's avatar
Eric Duminil committed
48

Eric Duminil's avatar
Eric Duminil committed
49
50
		if (wktFile.equals("-")) {
			if (System.in.available() == 0) {
Eric Duminil's avatar
Eric Duminil committed
51
				throw new IllegalArgumentException("Please provide \"POLYGON((x1 y1, x2 y2, ...))\" to standard input.");
Eric Duminil's avatar
Eric Duminil committed
52
			} else {
Eric Duminil's avatar
Eric Duminil committed
53
				wktPolygon = getInput();
Eric Duminil's avatar
Eric Duminil committed
54
			}
Eric Duminil's avatar
Eric Duminil committed
55
		} else {
Eric Duminil's avatar
Eric Duminil committed
56
57
58
59
			wktPolygon = new String(Files.readAllBytes(Paths.get(wktFile)), StandardCharsets.UTF_8);
			if (wktPolygon.isEmpty()) {
				throw new IllegalArgumentException("Please write \"POLYGON((x1 y1, x2 y2, ...))\" inside " + wktFile);
			}
Eric Duminil's avatar
Eric Duminil committed
60
		}
Eric Duminil's avatar
Eric Duminil committed
61

Eric Duminil's avatar
Eric Duminil committed
62
63
64
65
		if (!localCoordinates) {
			// WKT coordinates are in WGS84, so should be first converted to srsName
		}

Eric Duminil's avatar
Eric Duminil committed
66
67
		System.out.println("WKT Polygon : " + wktPolygon);

Eric Duminil's avatar
Eric Duminil committed
68
		StringBuilder sb = RegionExtractor.selectRegionDirectlyFromCityGML(wktPolygon, localCRS.toString(), citygmls);
Eric Duminil's avatar
Eric Duminil committed
69
70
71

		RegionChooserUtils.writeStringBuilderToFile(sb, outputCityGML);

Eric Duminil's avatar
Eric Duminil committed
72
		return 0;
Eric Duminil's avatar
Eric Duminil committed
73
74
	}

Eric Duminil's avatar
Eric Duminil committed
75
	private static String getInput() {
Eric Duminil's avatar
Eric Duminil committed
76
77
78
		try (Scanner myObj = new Scanner(System.in)) {
			return myObj.nextLine();
		}
Eric Duminil's avatar
Eric Duminil committed
79
80
	}

Eric Duminil's avatar
Eric Duminil committed
81
82
83
84
85
	// this example implements Callable, so parsing, error handling and handling user
	// requests for usage help or version help can be done with one line of code.
	public static void main(String... args) {
		int exitCode = new CommandLine(new RegionChooserCommandLineInterface()).execute(args);
		System.exit(exitCode);
Eric Duminil's avatar
Eric Duminil committed
86
	}
Eric Duminil's avatar
Eric Duminil committed
87
}