我有一个基本的想法,虽然我怀疑你需要做更多的工作,这取决于你想要结果的灵活性.
from numpy import cos, sin
import numpy as np
import matplotlib.pyplot as plt
def plot_hatches(ax, angle, offset=.1):
angle_radians = np.radians(angle)
x = np.linspace(-2, 2, 10)
for c in np.arange(-2, 2, offset):
yprime = cos(angle_radians) * c + sin(angle_radians) * x
xprime = sin(angle_radians) * c - cos(angle_radians) * x
ax.plot(xprime, yprime, color="k")
ax.set_ylim(0, 1)
ax.set_xlim(0, 1)
return ax
fig, axes = plt.subplots(nrows=4, ncols=4, figsize=(8,8), sharex=True, sharey=True)
for i in range(len(axes.flat)):
plot_hatches(axes.flat[i], np.random.uniform(0, 90))
fig.subplots_adjust(hspace=0, wspace=0)
这里有两个部分:首先是一个函数plot_hatches,它在轴ax上的单位正方形上绘制阴影.这是通过获取单行x,y = c并使用rotation matrix旋转它来获得xprime和yprime,它们是与x轴成一定角度的线的坐标,偏移量为c.迭代几个c的值覆盖单位平方,通过使偏移参数更小,可以使线更密集.
其次,我们需要一种方法来绘制彼此相邻的轴.我已经使用了子图.这将返回fig,轴是轴实例的数组,因此我们通过它们进行迭代,将它们传递给函数以绘制阴影并每次给它一个随机角度.
编辑我已经将plot_hatches代码更改为以逆时针方式旋转(在此编辑之前是顺时针方向).现在,这将生成具有数组[0,-45,0,45,0]的问题中给出的图像: