2025-02-27 18:46:32 +01:00
|
|
|
|
using System;
|
2017-06-25 23:05:48 +02:00
|
|
|
|
using System.Globalization;
|
|
|
|
|
|
|
|
|
|
|
|
namespace MapControl
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// A geographic bounding box with south and north latitude and west and east longitude values in degrees.
|
|
|
|
|
|
/// </summary>
|
2024-05-22 11:25:32 +02:00
|
|
|
|
#if UWP || WINUI
|
2024-04-11 15:41:05 +02:00
|
|
|
|
[Windows.Foundation.Metadata.CreateFromString(MethodName = "Parse")]
|
2024-04-11 14:57:54 +02:00
|
|
|
|
#else
|
2018-08-08 23:31:52 +02:00
|
|
|
|
[System.ComponentModel.TypeConverter(typeof(BoundingBoxConverter))]
|
|
|
|
|
|
#endif
|
2026-01-27 20:12:57 +01:00
|
|
|
|
public class BoundingBox(double latitude1, double longitude1, double latitude2, double longitude2, bool projectAxisAligned = false)
|
2017-06-25 23:05:48 +02:00
|
|
|
|
{
|
2026-01-27 20:12:57 +01:00
|
|
|
|
public double South { get; } = Math.Min(Math.Max(Math.Min(latitude1, latitude2), -90d), 90d);
|
|
|
|
|
|
public double North { get; } = Math.Min(Math.Max(Math.Max(latitude1, latitude2), -90d), 90d);
|
|
|
|
|
|
public double West { get; } = Math.Min(longitude1, longitude2);
|
|
|
|
|
|
public double East { get; } = Math.Max(longitude1, longitude2);
|
2017-06-25 23:05:48 +02:00
|
|
|
|
|
2026-01-27 20:12:57 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Indicates whether a MapProjection projects the BoundingBox to an axis-aligned or skewed rectangle.
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public bool ProjectAxisAligned { get; } = projectAxisAligned;
|
2017-06-25 23:05:48 +02:00
|
|
|
|
|
2025-08-14 13:11:25 +02:00
|
|
|
|
public override string ToString()
|
|
|
|
|
|
{
|
|
|
|
|
|
return string.Format(CultureInfo.InvariantCulture, "{0},{1},{2},{3}", South, West, North, East);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-04-11 15:59:07 +02:00
|
|
|
|
/// <summary>
|
2026-01-27 20:12:57 +01:00
|
|
|
|
/// Creates a BoundingBox instance from a string containing a comma-separated sequence of four floating point numbers.
|
2024-04-11 15:59:07 +02:00
|
|
|
|
/// </summary>
|
2022-12-01 22:48:08 +01:00
|
|
|
|
public static BoundingBox Parse(string boundingBox)
|
2017-06-25 23:05:48 +02:00
|
|
|
|
{
|
2022-12-01 22:48:08 +01:00
|
|
|
|
string[] values = null;
|
|
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(boundingBox))
|
|
|
|
|
|
{
|
2026-01-27 20:12:57 +01:00
|
|
|
|
values = boundingBox.Split(',');
|
2022-12-01 22:48:08 +01:00
|
|
|
|
}
|
2017-06-25 23:05:48 +02:00
|
|
|
|
|
2024-09-05 21:27:04 +02:00
|
|
|
|
if (values == null || values.Length != 4 && values.Length != 5)
|
2017-06-25 23:05:48 +02:00
|
|
|
|
{
|
2026-01-27 20:12:57 +01:00
|
|
|
|
throw new FormatException($"{nameof(BoundingBox)} string must contain a comma-separated sequence of four floating point numbers.");
|
2017-06-25 23:05:48 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-27 20:12:57 +01:00
|
|
|
|
return new BoundingBox(
|
2017-06-25 23:05:48 +02:00
|
|
|
|
double.Parse(values[0], NumberStyles.Float, CultureInfo.InvariantCulture),
|
|
|
|
|
|
double.Parse(values[1], NumberStyles.Float, CultureInfo.InvariantCulture),
|
|
|
|
|
|
double.Parse(values[2], NumberStyles.Float, CultureInfo.InvariantCulture),
|
2026-01-27 20:12:57 +01:00
|
|
|
|
double.Parse(values[3], NumberStyles.Float, CultureInfo.InvariantCulture));
|
2017-06-25 23:05:48 +02:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|