mirror of
https://github.com/ClemensFischer/XAML-Map-Control.git
synced 2025-12-06 07:12:04 +01:00
84 lines
2.3 KiB
C#
84 lines
2.3 KiB
C#
// XAML Map Control - http://xamlmapcontrol.codeplex.com/
|
|
// Copyright © 2013 Clemens Fischer
|
|
// Licensed under the Microsoft Public License (Ms-PL)
|
|
|
|
using System;
|
|
using System.Globalization;
|
|
|
|
namespace MapControl
|
|
{
|
|
/// <summary>
|
|
/// A geographic location given as latitude and longitude.
|
|
/// </summary>
|
|
public partial class Location : IEquatable<Location>
|
|
{
|
|
private double latitude;
|
|
private double longitude;
|
|
internal double Y;
|
|
|
|
public Location()
|
|
{
|
|
}
|
|
|
|
public Location(double lat, double lon)
|
|
{
|
|
Latitude = lat;
|
|
Longitude = lon;
|
|
}
|
|
|
|
public double Latitude
|
|
{
|
|
get { return latitude; }
|
|
set
|
|
{
|
|
latitude = Math.Min(Math.Max(value, -90d), 90d);
|
|
Y = double.NaN;
|
|
}
|
|
}
|
|
|
|
public double Longitude
|
|
{
|
|
get { return longitude; }
|
|
set { longitude = value; }
|
|
}
|
|
|
|
public bool Equals(Location other)
|
|
{
|
|
return other != null && other.latitude == latitude && other.longitude == longitude;
|
|
}
|
|
|
|
public override bool Equals(object obj)
|
|
{
|
|
return Equals(obj as Location);
|
|
}
|
|
|
|
public override int GetHashCode()
|
|
{
|
|
return latitude.GetHashCode() ^ longitude.GetHashCode();
|
|
}
|
|
|
|
public override string ToString()
|
|
{
|
|
return string.Format(CultureInfo.InvariantCulture, "{0:F5},{1:F5}", latitude, longitude);
|
|
}
|
|
|
|
public static Location Parse(string s)
|
|
{
|
|
var tokens = s.Split(new char[] { ',' });
|
|
if (tokens.Length != 2)
|
|
{
|
|
throw new FormatException("Location string must be a comma-separated pair of double values");
|
|
}
|
|
|
|
return new Location(
|
|
double.Parse(tokens[0], NumberStyles.Float, CultureInfo.InvariantCulture),
|
|
double.Parse(tokens[1], NumberStyles.Float, CultureInfo.InvariantCulture));
|
|
}
|
|
|
|
public static double NormalizeLongitude(double longitude)
|
|
{
|
|
return (longitude >= -180d && longitude <= 180d) ? longitude : ((longitude + 180d) % 360d + 360d) % 360d - 180d;
|
|
}
|
|
}
|
|
}
|