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

com.azure.core.models.GeoPosition 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.core.util.logging.ClientLogger;

import java.util.Objects;

/**
 * Represents a geo position.
 */
@Immutable
public final class GeoPosition {
    // GeoPosition is a commonly used model, use a static logger.
    private static final ClientLogger LOGGER = new ClientLogger(GeoPosition.class);

    private final double longitude;
    private final double latitude;

    private final Double altitude;

    /**
     * Constructs a geo position.
     *
     * @param longitude Longitudinal position.
     * @param latitude Latitudinal position.
     */
    public GeoPosition(double longitude, double latitude) {
        this(longitude, latitude, null);
    }

    /**
     * Constructs a geo position.
     *
     * @param longitude Longitudinal position.
     * @param latitude Latitudinal position.
     * @param altitude Altitude position.
     */
    public GeoPosition(double longitude, double latitude, Double altitude) {
        this.longitude = longitude;
        this.latitude = latitude;
        this.altitude = altitude;
    }

    /**
     * The longitudinal position of the geometric position.
     *
     * @return The longitudinal position.
     */
    public double getLongitude() {
        return longitude;
    }

    /**
     * The latitudinal position of the geometric position.
     *
     * @return The latitudinal position.
     */
    public double getLatitude() {
        return latitude;
    }

    /**
     * The altitude of the geometric position.
     *
     * @return The altitude.
     */
    public Double getAltitude() {
        return altitude;
    }

    /**
     * Gets the number of coordinates used to compose the position.
     * 

* This will return either 2 or 3 depending on whether {@link #getAltitude() altitude is set}. * * @return The number of coordinates used to compose the position. */ public int count() { return (altitude == null) ? 2 : 3; } /** * Array accessor for the coordinates of this position. *

* * * * * * * * * * * * * * * * * * * * * *
Operation result mapping
IndexResult
0{@link #getLongitude() Longitude}
1{@link #getLatitude() Latitude}
2{@link #getAltitude() Altitude} if non-null, otherwise {@link IndexOutOfBoundsException}
3+{@link IndexOutOfBoundsException}
* * @param index Coordinate index to access. * @return The coordinate value for the index. * @throws IndexOutOfBoundsException If {@code index} is equal to or greater than {@link #count()}. */ double get(int index) { switch (index) { case 0: return longitude; case 1: return latitude; case 2: if (altitude == null) { throw LOGGER.logExceptionAsError(new IndexOutOfBoundsException("Index out of range: " + index)); } return altitude; default: throw LOGGER.logExceptionAsError(new IndexOutOfBoundsException("Index out of range: " + index)); } } @Override public int hashCode() { return Objects.hash(longitude, latitude, altitude); } @Override public boolean equals(Object obj) { if (!(obj instanceof GeoPosition)) { return false; } if (obj == this) { return true; } GeoPosition other = (GeoPosition) obj; return Double.compare(longitude, other.longitude) == 0 && Double.compare(latitude, other.latitude) == 0 && Objects.equals(altitude, other.altitude); } @Override public String toString() { return (altitude != null) ? String.format("[%s, %s, %s]", longitude, latitude, altitude) : String.format("[%s, %s]", longitude, latitude); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy