使用 fill 或 fill_ Between 绘制甜甜圈,在 matplotlib 中使用 pyplot

问题描述 投票:0回答:4

我想绘制一个甜甜圈,我的脚本是

import numpy as np
import matplotlib.pyplot as plt
pi,sin,cos = np.pi,np.sin,np.cos

r1 = 1
r2 = 2

theta = np.linspace(0,2*pi,36)

x1 = r1*cos(theta)
y1 = r1*sin(theta)

x2 = r2*cos(theta)
y2 = r2*sin(theta)

如何获得红色填充区域的甜甜圈?

python matplotlib fill
4个回答
16
投票

可以遍历封闭曲线区域的边界,并使用

fill
方法填充该封闭区域内的区域:

import numpy as np
import matplotlib.pyplot as plt

n, radii = 50, [.7, .95]
theta = np.linspace(0, 2*np.pi, n, endpoint=True)
xs = np.outer(radii, np.cos(theta))
ys = np.outer(radii, np.sin(theta))

# in order to have a closed area, the circles
# should be traversed in opposite directions
xs[1,:] = xs[1,::-1]
ys[1,:] = ys[1,::-1]

ax = plt.subplot(111, aspect='equal')
ax.fill(np.ravel(xs), np.ravel(ys), edgecolor='#348ABD')

plt.show()

这可以轻松应用于任何形状,例如圆形内部或外部的五边形:

pentagon


3
投票

您可以通过分别绘制上半部分和下半部分来完成此操作:

import numpy as np
import matplotlib.pyplot as plt

inner = 5.
outer = 10.

x = np.linspace(-outer, outer, 1000, endpoint=True)

yO = outer*np.sin(np.arccos(x/outer)) # x-axis values -> outer circle
yI = inner*np.sin(np.arccos(x/inner)) # x-axis values -> inner circle (with nan's beyond circle)
yI[np.isnan(yI)] = 0.                 # yI now looks like a boulder hat, meeting yO at the outer points

ax = plt.subplot(111)
ax.fill_between(x, yI, yO, color="red")
ax.fill_between(x, -yO, -yI, color="red")

plt.show()

enter image description here

或者您可以使用极坐标,尽管这是否有益取决于更广泛的背景:

import numpy as np
import matplotlib.pyplot as plt

theta = np.linspace(0., 2.*np.pi, 80, endpoint=True)
ax = plt.subplot(111, polar=True)
ax.fill_between(theta, 5., 10., color="red")

plt.show()

enter image description here


1
投票

这有点麻烦,但以下方法有效:

import numpy as np
import matplotlib.pyplot as plt
pi,sin,cos = np.pi,np.sin,np.cos

r1 = 1
r2 = 2

theta = np.linspace(0,2*pi,36)

x1 = r1*cos(theta)
y1 = r1*sin(theta)

x2 = r2*cos(theta)
y2 = r2*sin(theta)

fig, ax = plt.subplots()

ax.fill_between(x2, -y2, y2, color='red')
ax.fill_between(x1, y1, -y1, color='white')

plt.show()

它将甜甜圈的整个区域绘制为红色,然后将中心“洞”绘制为白色。

Example plot


0
投票

tom10给出的答案是十;) 但如果你想定义圆(甜甜圈)原点很简单,只需在 x、yI、yO 和 -yO 和 -yI 中添加位置 x,y 即可:

    ax.fill_between(x+pos[0], yI+pos[1], yO+pos[1], color=color)
    ax.fill_between(x+pos[0], -yO+pos[1], -yI+pos[1], color=color)

如下图:

import numpy as np
import matplotlib.pyplot as plt
import math
 
 
def plot_circle_donut(pos, inner, outer, color):
    """
     REF: https://stackoverflow.com/questions/22789356/plot-a-donut-with-fill-or-fill-between-use-pyplot-in-matplotlib
     ton10's answer
    """
    x = np.linspace(-outer, outer, 300, endpoint=True)
 
    yO = outer * np.sin(np.arccos(x/ outer )) # x-axis values -> outer circle
    yI = inner * np.sin(np.arccos(x/ inner )) # x-axis values -> inner circle (with nan's beyond circle)
    yI[np.isnan(yI)] = 0.                 # yI now looks like a boulder hat, meeting yO at the outer points
 
    ax = plt.subplot(111)
    ax.fill_between(x+pos[0], yI+pos[1], yO+pos[1], color=color)
    ax.fill_between(x+pos[0], -yO+pos[1], -yI+pos[1], color=color)
 
    plt.show()
#
 
def plot_circle(r, pos):
    """ REF: https://math.stackexchange.com/questions/260096/find-the-coordinates-of-a-point-on-a-circle """
    arrx = []
    arry = []
    for theta in xrange(1000):
        x,y = r * math.sin(theta), r * math.cos(theta)
        arrx.append(x)
        arry.append(y)
    #
    plt.plot(arrx, arry, color='red')
 
    plt.show()
#
 
 
#r = 3
#pos = 2,2
#plot_circle(r, pos)
 
r1, r2 = 2, 2.1
position = [4,2]
color = 'b'
plot_circle_donut(position, r1, r2, color)

参考示例:https://pastebin.com/8Ew4Vthb

© www.soinside.com 2019 - 2024. All rights reserved.