参阅:生命之花/平衡轮:一个实用的人生规划的工具
先画一个圆圈,编写 draw_circle1.py 如下
# -*- coding: utf-8 -*-
""" 画一个圆圈 """
import numpy as np
from matplotlib import pyplot as plt
# 用于正常显示中文标题,负号
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
# 圆的半径
R = np.sqrt(2.0)
# 参数方程
theta = np.arange(0, 2*np.pi, 0.01)
# 圆心坐标
a, b = (0., 0.)
x = a + R * np.cos(theta)
y = b + R * np.sin(theta)
# 直径:坐标 (x,y)
x1 = np.arange(-1., 1., 0.01)
y1 = np.arange(-1., 1., 0.01)
y_1= np.arange(1., -1., -0.01)
r = np.arange(-R, R, 0.01)
z = np.zeros(len(r))
# 可视化
fig = plt.figure()
axes = fig.add_subplot(111)
axes.plot(x, y) # 画圆圈
# 画直径线段
axes.plot(x1, y1)
axes.plot(x1, y_1)
axes.plot(r, z)
axes.plot(z, r)
axes.axis('equal')
plt.title('绘制1个圆圈')
plt.grid()
plt.show()
运行 python draw_circle1.py
绘制生命之花图案,编写 draw_circle16.py 如下
# -*- coding: utf-8 -*-
import numpy as np
from matplotlib import pyplot as plt
# 用于正常显示中文标题,负号
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
fig = plt.figure()
axes = fig.add_subplot(111)
# 圆的半径
r = np.sqrt(2.0)
# 参数方程
theta = np.arange(0, 2*np.pi, 0.01)
# 圆心坐标
a, b = (0., 0.)
for a in [-3., -1., 1., 3.]:
for b in [-3., -1., 1., 3.]:
x = a + r * np.cos(theta)
y = b + r * np.sin(theta)
axes.plot(x, y)
axes.axis('equal')
plt.title('绘制圆圈16--生命之花图案')
plt.grid()
plt.show()
运行 python draw_circle16.py