用FuncAnimation()绘制一个圆点在正弦曲线上移动的折线图,并在右上角显示圆点坐标

uncAnimation是基于函数的动画类,它通过重复调用同一函数来制作动画。FuncAnimation类的构造方法的语法格式如下所示:
FuncAnimation (fig, func, frames-None, init_func=None, fargs=None,
save_count=None, *, cache_frame_data=True, **kwargs)
该方法常用参数的含义如下。
fig:表示动画所在的画布。
func:表示每一帧动画调用的函数。
frames:表示完成一个动画所需的帧数,interval频率一定,frames帧数越高画面越流畅
init_func:表示用于开始绘制帧的函数,它会在第一帧动画之前调用一次。若未设置该参数,则程序将使用frames序列中第一项的绘图结果。
interval:表示更新动画的频率,frames帧数一定,interval帧率越高画面越流畅,以毫秒为单位,默认为200。
blit:表示是否更新所有的点,默认为False。官方推荐将blit参数设为True,但建议macOS的用户将blit参数设为False,否则将无法显示动画,在pycharm中建议是True,不然图表可能会出错,在anacanda中建议用False。
 

代码如下

"""
 绘制一个具有动画效果的图表,具体要求如下:
(1)    绘制一条正弦曲线;
(2)    绘制一个红色圆点,该圆点最初位于正弦曲线的左端;
(3)    制作一个圆点沿曲线运动的动画,并时刻显示圆点的坐标位置。
     (具体效果参考运行结果gif图)
"""
 
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from matplotlib.animation import FuncAnimation
# 0. 设置中文黑体
plt.rcParams["font.sans-serif"] = ["SimHei"]
plt.rcParams["axes.unicode_minus"] = False
 
# 1. 准备正弦曲线数据
x = np.linspace(0, 2*np.pi, 100,)
y = np.sin(x)
 
# 2. 创建画布和坐标系
fig = plt.figure(tight_layout=True)
ax = fig.add_subplot(111)
 
# 3. 绘制正弦曲线
line, = ax.plot(x, y)
 
# 定义一个圆点
point, = ax.plot([ ], [ ], "ro")
 
# 4. 动画设计
# 定义一个空的注释
text = ax.text(x=4, y=0.7, s='', fontdict={'fontsize': 20})
 
def animate(i):
    text_x = format(x[i], '1.3f')   # 将x轴数据转为保留三位小数
    text_y = format(y[i], '1.3f')   # 将y轴数据转为保留三位小数
    point.set_data([x[i]], [y[i]])  # 让圆点在正弦曲线移动
    text.set_text(f'x={text_x},y={text_y}')     # 将圆点的位置显示在右上角
 
    return point,text
 
# 定义初始化帧的函数
def init():
    line.set_ydata(np.sin(x))
    return line,

 
 
ani = FuncAnimation(fig=fig, func=animate, frames=len(x), init_func=init, interval=20, blit=False)
 
 
# 5.将动画保存为gif图片(用于上传博客)
ani.save("pratice7.3.gif", writer='pillow')
 
# 6.展示图表
plt.show()
 
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值