绘制一个具有动画效果的图表:红色圆点在正弦曲线上移动

此实验需要完成的要求:

(1)    绘制一条正弦曲线;
(2)    绘制一个红色圆点,该圆点最初位于正弦曲线的左端;
(3)    制作一个圆点沿曲线运动的动画,并时刻显示圆点的坐标位置。

 先导入模块并设置中文字体

%matplotlib notebook 
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation

# 0. 设置中文黑体
plt.rcParams["font.sans-serif"] = ["SimHei"]
plt.rcParams["axes.unicode_minus"] = False

准备数据

x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x)

创建画布和坐标系

fig = plt.figure(tight_layout=True)
ax = fig.add_subplot(111)

绘制正弦曲线

ax.plot(x, y)

创建红色圆点

point, = ax.plot(x[0], y[0], 'ro')#r实现红色,o实现圆点效果

定制坐标文本

text = ax.text(x=4,
               y=0.9,
               s='',#文本先空着
               fontdict={'fontsize':14.88})

定义需要调用的函数

def animate(num):
    point.set_data(x[num], y[num]) # 更新圆点坐标
    text.set_text(f'x={x[num]:.3f}, y={y[num]:.3f}') #写入坐标,保留三位小数点
    return point,

FuncAnimation是基于函数的动画类,它通过重复调用同一函数来制作动画,部分参数含义如下实例

ani = FuncAnimation(fig, #表示动画所在的画布
                    func=animate, #表示每帧动画调用的函数
                    frames=len(x), #表示动画的长度(一次动画包含的帧数,默认无数帧)
                    interval=50, #表示更新动画的频率,以毫秒为单位,默认为200
                    blit=True)#表示是否更新所有的点,默认为False

将动画保存为gif图片

ani.save("pratice7.3.gif", writer='pillow') 

展示动画

plt.show()

运行结果如下:

 

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,根据您的要求,可以使用HTML5中的<canvas>元素和JavaScript来制作这个动画。 首先,在HTML文档中创建一个画布元素,并在JavaScript中获取该元素的上下文对象: ```html <canvas id="myCanvas"></canvas> <script> var canvas = document.getElementById("myCanvas"); var ctx = canvas.getContext("2d"); </script> ``` 接下来,绘制正弦曲线圆点。可以使用数学函数来计算正弦曲线上每个点的坐标,然后使用context.arc()方法绘制圆点: ```javascript //绘制正弦曲线 ctx.beginPath(); for (var x = 0; x < canvas.width; x += 10) { var y = Math.sin(x * Math.PI / 180) * 50 + canvas.height / 2; ctx.lineTo(x, y); } ctx.strokeStyle = "#000"; ctx.stroke(); //绘制圆点 var ball = { x: 0, //圆点的初始横坐标 y: Math.sin(0) * 50 + canvas.height / 2, //计算圆点的纵坐标 radius: 10, //圆点的半径 speed: 1, //圆点移动速度 draw: function () { //绘制圆点的方法 ctx.beginPath(); ctx.arc(this.x, this.y, this.radius, 0, Math.PI * 2); ctx.fillStyle = "red"; ctx.fill(); ctx.closePath(); } }; ball.draw(); //绘制初始位置的圆点 ``` 现在,我们需要通过动画来让圆点沿着正弦曲线移动。可以使用requestAnimationFrame()方法来实现动画。每一次动画帧中,移动圆点的横坐标,并重新绘制圆点: ```javascript function animate() { ctx.clearRect(0, 0, canvas.width, canvas.height); //清除画布 ctx.beginPath(); for (var x = 0; x < canvas.width; x += 10) { var y = Math.sin(x * Math.PI / 180) * 50 + canvas.height / 2; ctx.lineTo(x, y); } ctx.strokeStyle = "#000"; ctx.stroke(); ball.x += ball.speed; //移动圆点的横坐标 ball.y = Math.sin(ball.x * Math.PI / 180) * 50 + canvas.height / 2; //计算圆点的纵坐标 ball.draw(); //重新绘制圆点 //显示圆点的坐标 var coordinate = "x: " + ball.x + " , y: " + ball.y; ctx.font = "20px Arial"; ctx.fillStyle = "black"; ctx.fillText(coordinate, 10, 50); requestAnimationFrame(animate); //递归调用animate()方法,形成动画帧 } animate(); //启动动画 ``` 以上代码可以在浏览器中运行,绘制出一个具有动画效果正弦曲线圆点,并时刻显示圆点的坐标。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值