All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.azure.core.models.GeoPoint Maven / Gradle / Ivy

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.core.models;

import com.azure.core.annotation.Immutable;
import com.azure.json.JsonReader;
import com.azure.json.JsonSerializable;
import com.azure.json.JsonToken;
import com.azure.json.JsonWriter;

import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Objects;

/**
 * 

Represents a geometric point in GeoJSON format.

* *

This class encapsulates a point defined by a {@link GeoPosition} which includes the longitude, latitude, and * optionally the altitude of the point.

* *

This class also provides a {@link #toJson(JsonWriter)} method to serialize the geometric point to JSON, and * a {@link #fromJson(JsonReader)} method to deserialize a geometric point from JSON.

* * @see GeoPosition * @see GeoObject * @see JsonSerializable */ @Immutable public final class GeoPoint extends GeoObject { private final GeoPosition coordinates; /** * Constructs a {@link GeoPoint}. * * @param longitude The longitudinal position of the point. * @param latitude The latitudinal position of the point. */ public GeoPoint(double longitude, double latitude) { this(longitude, latitude, null); } /** * Constructs a {@link GeoPoint}. * * @param longitude The longitudinal position of the point. * @param latitude The latitudinal position of the point. * @param altitude The altitude of the point. */ public GeoPoint(double longitude, double latitude, Double altitude) { this(new GeoPosition(longitude, latitude, altitude)); } /** * Constructs a geometric point. * * @param position The {@link GeoPosition geometric position} of the point. * @throws NullPointerException If {@code position} is {@code null}. */ public GeoPoint(GeoPosition position) { this(position, null, null); } /** * Constructs a geometric point. * * @param position The {@link GeoPosition geometric position} of the point. * @param boundingBox Bounding box for the point. * @param customProperties Additional properties of the geometric point. * @throws NullPointerException If {@code position} is {@code null}. */ public GeoPoint(GeoPosition position, GeoBoundingBox boundingBox, Map customProperties) { super(boundingBox, customProperties); this.coordinates = Objects.requireNonNull(position, "'position' cannot be null."); } /** * The {@link GeoPosition geometric position} of the point. * * @return The {@link GeoPosition geometric position} of the point. */ public GeoPosition getCoordinates() { return coordinates; } @Override public GeoObjectType getType() { return GeoObjectType.POINT; } @Override public int hashCode() { return Objects.hash(coordinates, super.hashCode()); } @Override public boolean equals(Object obj) { if (!(obj instanceof GeoPoint)) { return false; } if (this == obj) { return true; } GeoPoint other = (GeoPoint) obj; return super.equals(obj) && Objects.equals(coordinates, other.coordinates); } @Override public JsonWriter toJson(JsonWriter jsonWriter) throws IOException { jsonWriter.writeStartObject() .writeStringField("type", GeoObjectType.POINT.toString()) .writeJsonField("coordinates", coordinates) .writeJsonField("bbox", getBoundingBox()); return writeCustomProperties(jsonWriter).writeEndObject(); } /** * Reads a JSON stream into a {@link GeoPoint}. * * @param jsonReader The {@link JsonReader} being read. * @return The {@link GeoPoint} that the JSON stream represented, or null if it pointed to JSON null. * @throws IllegalStateException If the {@code type} node exists and isn't equal to {@code Point}. * @throws IOException If a {@link GeoPoint} fails to be read from the {@code jsonReader}. */ public static GeoPoint fromJson(JsonReader jsonReader) throws IOException { return jsonReader.readObject(reader -> { GeoPosition position = null; GeoBoundingBox boundingBox = null; Map customProperties = null; while (reader.nextToken() != JsonToken.END_OBJECT) { String fieldName = reader.getFieldName(); reader.nextToken(); if ("type".equals(fieldName)) { String type = reader.getString(); if (!GeoObjectType.POINT.toString().equals(type)) { throw new IllegalStateException("'type' was expected to be non-null and equal to 'Point'. The " + "found 'type' was '" + type + "'."); } } else if ("coordinates".equals(fieldName)) { position = GeoPosition.fromJson(reader); } else if ("bbox".equals(fieldName)) { boundingBox = GeoBoundingBox.fromJson(reader); } else { if (customProperties == null) { customProperties = new LinkedHashMap<>(); } customProperties.put(fieldName, reader.readUntyped()); } } return new GeoPoint(position, boundingBox, customProperties); }); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy