Separate functions for normalizing and fitting a bbox
`normalize_bbox()` just parses incoming coordinates into a normalized dict `fit_bbox()` will translate any outlying coordinates to ensure they fit the -180, -90, 180, 90 extent
This commit is contained in:
parent
87b723e9de
commit
eebd3954a1
|
@ -24,21 +24,27 @@ def get_srid(crs):
|
|||
return int(srid)
|
||||
|
||||
|
||||
def validate_bbox(bbox_values):
|
||||
def normalize_bbox(bbox_values):
|
||||
"""
|
||||
Ensures a bbox is expressed in a standard dict.
|
||||
Ensures a bbox is expressed in a standard dict
|
||||
|
||||
bbox_values may be:
|
||||
a string: "-4.96,55.70,-3.78,56.43"
|
||||
or a list [-4.96, 55.70, -3.78, 56.43]
|
||||
or a list of strings ["-4.96", "55.70", "-3.78", "56.43"]
|
||||
and returns a dict:
|
||||
{'minx': -4.96,
|
||||
'miny': 55.70,
|
||||
'maxx': -3.78,
|
||||
'maxy': 56.43}
|
||||
|
||||
Any problems and it returns None.
|
||||
ordered as MinX, MinY, MaxX, MaxY.
|
||||
|
||||
Returns a dict with the keys:
|
||||
|
||||
{
|
||||
"minx": -4.96,
|
||||
"miny": 55.70,
|
||||
"maxx": -3.78,
|
||||
"maxy": 56.43
|
||||
}
|
||||
|
||||
If there are any problems parsing the input it returns None.
|
||||
"""
|
||||
|
||||
if isinstance(bbox_values, six.string_types):
|
||||
|
@ -56,4 +62,48 @@ def validate_bbox(bbox_values):
|
|||
except ValueError:
|
||||
return None
|
||||
|
||||
bbox = fit_bbox(bbox)
|
||||
|
||||
return bbox
|
||||
|
||||
|
||||
def fit_bbox(bbox_dict):
|
||||
"""
|
||||
Ensures that all coordinates in a bounding box
|
||||
fall within -180, -90, 180, 90 degrees
|
||||
|
||||
Accepts a dict with the following keys:
|
||||
|
||||
{
|
||||
"minx": -4.96,
|
||||
"miny": 55.70,
|
||||
"maxx": -3.78,
|
||||
"maxy": 56.43
|
||||
}
|
||||
|
||||
"""
|
||||
|
||||
def _adjust_longitude(value):
|
||||
if value < -180 or value > 180:
|
||||
value = value % 360
|
||||
if value < -180:
|
||||
value = 360 + value
|
||||
elif value > 180:
|
||||
value = -360 + value
|
||||
return value
|
||||
|
||||
def _adjust_latitude(value):
|
||||
if value < -90 or value > 90:
|
||||
value = value % 180
|
||||
if value < -90:
|
||||
value = 180 + value
|
||||
elif value > 90:
|
||||
value = -180 + value
|
||||
return value
|
||||
|
||||
return {
|
||||
"minx": _adjust_longitude(bbox_dict["minx"]),
|
||||
"maxx": _adjust_longitude(bbox_dict["maxx"]),
|
||||
"miny": _adjust_latitude(bbox_dict["miny"]),
|
||||
"maxy": _adjust_latitude(bbox_dict["maxy"]),
|
||||
}
|
||||
|
|
|
@ -1,21 +1,45 @@
|
|||
from ckanext.spatial.lib import validate_bbox
|
||||
from ckanext.spatial.lib import normalize_bbox, fit_bbox
|
||||
|
||||
|
||||
class TestValidateBbox(object):
|
||||
bbox_dict = {"minx": -4.96, "miny": 55.70, "maxx": -3.78, "maxy": 56.43}
|
||||
|
||||
def test_string(self):
|
||||
res = validate_bbox("-4.96,55.70,-3.78,56.43")
|
||||
assert res == self.bbox_dict
|
||||
|
||||
def test_list(self):
|
||||
res = validate_bbox([-4.96, 55.70, -3.78, 56.43])
|
||||
assert res == self.bbox_dict
|
||||
def test_string():
|
||||
res = normalize_bbox("-4.96,55.70,-3.78,56.43")
|
||||
assert res == bbox_dict
|
||||
|
||||
def test_bad(self):
|
||||
res = validate_bbox([-4.96, 55.70, -3.78])
|
||||
|
||||
def test_list():
|
||||
res = normalize_bbox([-4.96, 55.70, -3.78, 56.43])
|
||||
assert res == bbox_dict
|
||||
|
||||
|
||||
def test_list_of_strings():
|
||||
res = normalize_bbox(["-4.96", "55.70", "-3.78", "56.43"])
|
||||
assert res == bbox_dict
|
||||
|
||||
|
||||
def test_bad():
|
||||
res = normalize_bbox([-4.96, 55.70, -3.78])
|
||||
assert res is None
|
||||
|
||||
def test_bad_2(self):
|
||||
res = validate_bbox("random")
|
||||
|
||||
def test_bad_2():
|
||||
res = normalize_bbox("random")
|
||||
assert res is None
|
||||
|
||||
|
||||
def test_fit_within_bounds():
|
||||
|
||||
assert fit_bbox(bbox_dict) == bbox_dict
|
||||
|
||||
|
||||
def test_fit_out_of_bounds():
|
||||
|
||||
bbox_dict = {"minx": -185, "miny": -95, "maxx": 195, "maxy": 95}
|
||||
assert fit_bbox(bbox_dict) == {
|
||||
"minx": 175,
|
||||
"miny": 85,
|
||||
"maxx": -165,
|
||||
"maxy": -85,
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue