1 /*
2 * Copyright 2022 the original author or authors.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17 package org.bremersee.geojson.converter.serialization;
18
19 import static java.util.Objects.isNull;
20 import static org.bremersee.geojson.GeoJsonConstants.POINT;
21
22 import java.io.Serial;
23 import org.locationtech.jts.geom.Point;
24
25 /**
26 * The type Point to json converter.
27 *
28 * @author Christian Bremer
29 */
30 class PointToJsonConverter extends AbstractGeometryToJsonConverter<Point> {
31
32 @Serial
33 private static final long serialVersionUID = 1L;
34
35 /**
36 * The Coordinate converter.
37 */
38 final CoordinateToListConverter coordinateConverter;
39
40 /**
41 * Instantiates a new Point to json converter.
42 *
43 * @param coordinateConverter the coordinate converter
44 * @param withBoundingBox the with bounding box
45 */
46 PointToJsonConverter(CoordinateToListConverter coordinateConverter, boolean withBoundingBox) {
47 super(withBoundingBox);
48 if (isNull(coordinateConverter)) {
49 throw new IllegalArgumentException("Coordinate converter must be present.");
50 }
51 this.coordinateConverter = coordinateConverter;
52 }
53
54 @Override
55 String getGeometryType() {
56 return POINT;
57 }
58
59 @Override
60 Object getGeometryJsonValue(Point source) {
61 return coordinateConverter.convert(source.getCoordinate());
62 }
63 }