如何使用python tu绘制smily(arc)

2024-05-16 21:55:15 发布

您现在位置:Python中文网/ 问答频道 /正文

我想用Python龟画一个笑脸。圆形范围为120。 我试着跟着

import turtle
turtle.circle(100)
turtle.up()
turtle.goto(0, 30)
turtle.down()
turtle.circle(40, 120)

问题是微笑部分。如何画出笑脸?


Tags: import圆形downupturtle笑脸circlegoto
3条回答
import turtle
bob = turtle.Turtle()
bob.circle(100)
bob.penup()
bob.goto(50,100)
bob.pendown()
bob.circle(10)
bob.penup()
bob.goto(-50,100)
bob.pendown()
bob.circle(10)
bob.penup()
bob.goto(0,50)
bob.pendown()
bob.circle(100,30)
bob.penup()
bob.goto(0,50)
bob.pendown()
bob.circle(0,-30)
bob.circle(100,-30)

虽然turtle模块不提供绘制圆或抛物线弧的高级方法,但不难得出正确的方程。

原点位于(x0, y0)且半径为r的圆C由以下方程式描述:

(x-x0)^2 + (y-y0)^2 = r^2

我们可以将其扩展为:

x^2 -2x·x0 + x0^2 + y^2 -2y·y0 + y0^2 - r^2 = 0

现在我们可以把y作为变量,得到二次方程:

y^2 -2y0·y +(x^2-2x0·x+x0^2+y0^2-r^2) = 0

d = x^2-2x0·x+x0^2+y0^2-r^2。我们可以用通常的公式来解决这个问题:

y1 = (2y0 + sqrt(4y0^2 - 4d))/2 = y0 + sqrt(y0^2 - d)
y2 = (2y0 - sqrt(4y0^2 - 4d))/2 = y0 - sqrt(y0^2 - d)

现在你可以写下一个函数,给定圆心和半径的坐标,以及x的值,它返回坐标y,并使用这些坐标移动海龟:

def find_circle_coord(x0, y0, r, x):
    d = x**2 - 2*x0*x + x0**2 + y0**2 - r**2
    D = y0**2 - d
    if D < 0:
        raise ValueError("Value for x is outside the circle!")
    return y0 - D**.5, y0 + D**.5

如所示:

>>> # bob is a turtle
>>> bob.pendown()
>>> for x in range(-50, 50):
...     y1, _ = find_circle_coord(0, 0, 100, x)
...     bob.goto(x, y1)

通过选择返回的两个坐标之一,可以选择是绘制“上”还是“下”圆弧。

要画出一个微笑,你只需要画出两个圆圈,一个小一点,一个大一点,但中心要比前一个稍微高一点,这样他们就有了这样的交集。

所以你必须选择一个以x0, y0为中心,半径为r的圆和一个以x0, y0+K为中心,半径为R > r的圆。 注意,C2的中心与C1的中心垂直对齐(因此中心的坐标是相同的x),但它在它的上方(注意:我不确定y轴的方向,所以+K可能是-K…)

要找到交叉点,必须解其方程组:

(x-x0)^2 + (y-y0)^2-r^2 = 0
(x-x0^2) + (y-y0-K)^2-R^2 = 0

现在从第一个方程中减去第二个方程:

(y-y0)^2 - (y-y0-K)^2 -r^2 + R^2 = 0
y^2 -2y·y0 +y0^2 - y^2 -y0^2 -K^2 +2y·y0 +2K·y -2K·y0 -r^2 + R^2 = 0
-K^2 +2K·y -2K·y0 -r^2 + R^2 = 0

从哪里可以得到:

y = (K^2 +2K·y0 +r^2 -R^2)/(2K)

你可以用其中一个圆方程中的y代替,得到对应于这种yx。然后您就知道使用find_circle_coord绘制哪个x

如果你想让嘴巴更张开,你可以用一个圆和一个抛物线。要找到抛物线上某点的y值很容易:

def find_parabola_coord(a, b, c, x):
    return a*x**2 + b*x + c

或者你可以使用抛物线方程的形式给出它的顶点V = (xv, yv)

y - yv = a(x - xv)^2

其中a控制抛物线的陡峭程度。

您可以使用turtle模块提供的命令来进行微笑(和笑脸)。正确绘制圆弧(圆)的关键在于goto()setheading()的组合,请参见以下内容:

import turtle

turtle.up()
turtle.goto(0, -100)  # center circle around origin
turtle.down()

turtle.begin_fill()
turtle.fillcolor("yellow")  # draw head
turtle.circle(100)
turtle.end_fill()

turtle.up()
turtle.goto(-67, -40)
turtle.setheading(-60)
turtle.width(5)
turtle.down()
turtle.circle(80, 120)  # draw smile

turtle.fillcolor("black")

for i in range(-35, 105, 70):
    turtle.up()
    turtle.goto(i, 35)
    turtle.setheading(0)
    turtle.down()
    turtle.begin_fill()
    turtle.circle(10)  # draw eyes
    turtle.end_fill()

turtle.hideturtle()
turtle.done()

我不会说我已经掌握了定位弧,我仍然在做太多的尝试和错误,但如果你花时间学习海龟操作员是如何工作的,那是有可能的。

Have a nice day!

相关问题 更多 >