是否可以在 x 轴(经度)上移动 geopandas 世界地图?
Is it possible to shift a geopandas world map on the x axis (longitude)?
我想知道是否有办法将 geopandas 世界地图置于特定经度点的中心。基本上,只是想将它移动约 ~5-10 度左右。
上一个问题是几个月前发布的,但没有得到答复。想知道是否有人知道解决方案。 (Link 在 Whosebug 上的原始问题是 here)
world = geopandas.read_file(geopandas.datasets.get_path('naturalearth_lowres'))
fig, ax = plt.subplots()
world.plot(ax=ax, color=(0.8,0.5,0.5))
如果有人能提供帮助,将不胜感激。
提前致谢
我知道怎么做了:
from shapely.geometry import LineString
from shapely.ops import split
from shapely.affinity import translate
import geopandas
world = geopandas.read_file(geopandas.datasets.get_path('naturalearth_lowres'))
def shift_map(shift):
shift -= 180
moved_map = []
splitted_map = []
border = LineString([(shift,90),(shift,-90)])
for row in world["geometry"]:
splitted_map.append(split(row, border))
for element in splitted_map:
items = list(element)
for item in items:
minx, miny, maxx, maxy = item.bounds
if minx >= shift:
moved_map.append(translate(item, xoff=-180-shift))
else:
moved_map.append(translate(item, xoff=180-shift))
gdf = geopandas.GeoDataFrame({"geometry":moved_map})
fig, ax = plt.subplots()
gdf.plot(ax=ax)
plt.show()
第一步,您创建自己的世界并将其拆分到您的预定义边界上。
然后你得到所有元素的边界并检查边界是否与你想要的转变相匹配。之后,您将每个大于边界的元素平移到地图的左侧,并将所有其他元素移动到右侧,以便它们与 +180° 对齐。
例如:
地图偏移了120°
我想知道是否有办法将 geopandas 世界地图置于特定经度点的中心。基本上,只是想将它移动约 ~5-10 度左右。
上一个问题是几个月前发布的,但没有得到答复。想知道是否有人知道解决方案。 (Link 在 Whosebug 上的原始问题是 here)
world = geopandas.read_file(geopandas.datasets.get_path('naturalearth_lowres'))
fig, ax = plt.subplots()
world.plot(ax=ax, color=(0.8,0.5,0.5))
如果有人能提供帮助,将不胜感激。
提前致谢
我知道怎么做了:
from shapely.geometry import LineString
from shapely.ops import split
from shapely.affinity import translate
import geopandas
world = geopandas.read_file(geopandas.datasets.get_path('naturalearth_lowres'))
def shift_map(shift):
shift -= 180
moved_map = []
splitted_map = []
border = LineString([(shift,90),(shift,-90)])
for row in world["geometry"]:
splitted_map.append(split(row, border))
for element in splitted_map:
items = list(element)
for item in items:
minx, miny, maxx, maxy = item.bounds
if minx >= shift:
moved_map.append(translate(item, xoff=-180-shift))
else:
moved_map.append(translate(item, xoff=180-shift))
gdf = geopandas.GeoDataFrame({"geometry":moved_map})
fig, ax = plt.subplots()
gdf.plot(ax=ax)
plt.show()
第一步,您创建自己的世界并将其拆分到您的预定义边界上。 然后你得到所有元素的边界并检查边界是否与你想要的转变相匹配。之后,您将每个大于边界的元素平移到地图的左侧,并将所有其他元素移动到右侧,以便它们与 +180° 对齐。
例如:
地图偏移了120°