cartopy:更高的大圆距离线分辨率

2024-04-27 16:11:06 发布

您现在位置:Python中文网/ 问答频道 /正文

我试着在两点之间画一个很大的圆距离。我在cartopy docs中找到了一个(介绍性的_examples/01_圆.html)公司名称:

import matplotlib.pyplot as plt
import cartopy.crs as ccrs

ax = plt.axes(projection=ccrs.Robinson())

ax.set_global()

ax.coastlines()

plt.plot([-0.08, 132], [51.53, 43.17], color='red',      transform=ccrs.Geodetic())
plt.plot([-0.08, 132], [51.53, 43.17], color='blue', transform=ccrs.PlateCarree())

plt.show()

这就形成了下面的图像:

great circle example

问题是,在我自己的工作中,这两个点更接近,而且在不同的投影中(尽管我认为这在这里并不重要)。如果我将此代码更改为较小区域中的一行,例如:

^{pr2}$

这将生成以下图像:shorter line

这个例子中的红色大圆线看起来很糟糕,看起来是因为分辨率太低。如何增加构成大圆线的点数?在


Tags: 图像import距离docsplothtmlastransform
1条回答
网友
1楼 · 发布于 2024-04-27 16:11:06

这个问题是由于投影中的硬编码阈值造成的。目前,这不是用户可控制的参数,但您可以通过定义自己的子类来解决此问题:

class LowerThresholdRobinson(ccrs.Robinson):

    @property
    def threshold(self):
        return 1e3

如果在定义轴时使用LowerThresholdRobinson()而不是ccrs.Robinson(),这应该可以消除这个问题。在

相关问题 更多 >