gpt4 book ai didi

python - Matplotlib basemap Hexbin 动画 : Clear hexbins between frames

转载 作者:行者123 更新时间:2023-12-01 09:25:00 25 4
gpt4 key购买 nike

我正在 basemap 图像上制作六边形热图的动画,但无法弄清楚如何在开始下一帧之前删除先前的六边形。我想用一些累积来制作动画,但以选定的时间间隔重置(我的数据有时间维度,我想显示给定年份的所有点,日复一日,然后删除六角形并显示下一年)。我想我需要存储该图层,并使用其 .remove() 方法,但我无法弄清楚。

def update_hex(i, prev_layer):
if i == (len(years) - 1):
ani.event_source.stop()
print("End animation: Update Hex")

x, y = [mm.xmin, mm.xmax], [mm.ymin, mm.ymax]
x1, y1 = mm(df["LONGITUDE"][df["YEAR"] == years[i]].values, df["LATITUDE"][df["YEAR"] == years[i]].values)
x += x1.tolist()
y += y1.tolist()
x = np.array(x)
y = np.array(y)
if prev_layer:
prev_layer.remove()

hexlayer = mm.hexbin(x, y, gridsize = 75, bins = 100, mincnt = 0, cmap = 'my_cmap', linewidth = 0)

prev_layer = None
ani = animation.FuncAnimation(fig, update_hex, interval = 10, frames = range(len(years)), fargs = (prev_layer, ))
plt.show()

最佳答案

在本例中,我将使用全局数组来存储 hexbin() 返回的对象。按照预定义的时间间隔,我将删除这些对象,并清空数组的内容,然后重复。

fig, ax = plt.subplots()

def animate(i):
x0,y0 = np.random.random(size=(2,))*4-2
x = np.random.normal(loc=x0, size=(1000,))
y = np.random.normal(loc=y0, size=(1000,))

if len(prevlayers)>=maxlayers:
for layer in prevlayers:
layer.remove()
prevlayers[:] = []

hexlayer = ax.hexbin(x,y, gridsize=10, alpha=0.5)
prevlayers.append(hexlayer)
return hexlayer,

maxlayers = 3
prevlayers = []
ani = matplotlib.animation.FuncAnimation(fig, animate, frames=12)

enter image description here

关于python - Matplotlib basemap Hexbin 动画 : Clear hexbins between frames,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50504447/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com