Python使用matplotlib绘制正多边形逼近圆周

Python使用matplotlib绘制正多边形逼近圆周


对于正多边形,如果边的数量足够多,可以无限接近圆周

  • 参考代码:
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.widgets import Slider, Button

def circleXY(r=20, sideNum=15):
    theta = np.linspace(0, 2 * np.pi,  # 绘制一个完整的园
                        sideNum,  # 边的数量
                        False)  # 划分角度时不包含终点
    x = r * np.sin(theta)  # 圆周上点的
    x = np.append(x, x[0])
    y = r * np.cos(theta)
    y = np.append(y, y[0])
    return (x, y)

fig, ax = plt.subplots()  # 创建图形和轴
plt.subplots_adjust(left=0.1,  # 调整绘制结果图形的位置
                    bottom=0.25)
x, y = circleXY()
l, = plt.plot(x, y,  # 绘制折线图,正多边形
              lw=2, color='red')  # 设置线宽和颜色
axColor = 'lightgoldenrodyellow'

# 创建Slider组件,设置位置/尺寸、背景图和初始值
axSideNum = plt.axes([0.2, 0.1, 0.6, 0.03],  # Slider组件左上角位置和宽度、高度
                     facecolor=axColor)
slideSideNum = Slider(axSideNum, 'side number',
                      valmin=3, valmax=60,  # 最小值、最大值
                      valinit=6,  # 默认值
                      valfmt='%d')  # 数字显示格式

# 为Slider组件设置事件处理函数
def update(event):
    sideNum = int(slideSideNum.val)  # 获取Slider组件的当前值
    x, y = circleXY(sideNum=sideNum)  # 根据边的数量,重新计算圆周上点的坐标
    l.set_data(x, y)  # 更新数据
    plt.draw()  # 重新绘制多边形


slideSideNum.on_changed(update)

# 创建按钮组件,用来恢复Slider组件的初始值
resetax = plt.axes([0.45, 0.03, 0.1, 0.04])
button = Button(resetax, 'Reset', color=axColor, hovercolor='yellow')

def reset(event):
    slideSideNum.reset()

button.on_clicked(reset)
ax.set_aspect('equal')          #设置坐标轴纵横比相等
ax.set_xlim(-22, 22)            #设置x轴刻度起止值
ax.set_ylim(-22, 22)

plt.show()              #显示图形
  • 运行截图:
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值