Когда я запускаю игру Python Turtle, графическое окно перестает отвечать - PullRequest
0 голосов
/ 02 мая 2019

Я новичок в черепахе и программировании в целом и хотел создать игру в теги. Есть два пользователя, один из которых - бегун, а второй - преследователь (Боб и Фил). Когда преследователь находится рядом с бегуном (определяется по формуле расстояния), программа возвращает их в исходное исходное положение. Однако всякий раз, когда я запускаю программу, графическое окно Turtle замирает и перестает отвечать, что в итоге приводит к закрытию программы. Может ли кто-нибудь помочь мне определить проблему?

import turtle
import math
bob = turtle.Turtle()

wn = turtle.Screen()
wn.bgcolor("black")
wn.setup(width = 700, height = 700)
wn.tracer()

border_pen = turtle.Turtle()
border_pen.speed(0)
border_pen.color("white")
border_pen.penup()
border_pen.setposition(-300,-300)
border_pen.pendown()
border_pen.pensize(3)
for side in range(4):
    border_pen.fd(600)
    border_pen.lt(90)
border_pen.hideturtle()

bob.shape("triangle")
bob.speed(0)
bob.color("blue")
bob.penup()
bob.setpos(-50, 0)
def draw():
    bob.penup()
def nodraw():
    bob.pendown()

def fd():
    bob.fd(20)
    if bob.xcor() > 280:
        bob.setx(280)
    if bob.ycor() > 280:
        bob.sety(280)

    if bob.xcor() < -280:
        bob.setx(-280)
    if bob.ycor() <- 280:
        bob.sety(-280)
def right():
    bob.right(90)

def left():
    bob.left(90)

turtle.listen()
turtle.onkey(left, "Left")
turtle.onkey(fd, "Up")
turtle.onkey(right, "Right")

phil = turtle.Turtle()
phil.speed(0)
phil.penup()
phil.shape("triangle")
phil.color("red")
phil.setpos(50, 0)

def fdp():
    phil.fd(20)
    if phil.xcor() > 280:
        phil.setx(280)
    if phil.ycor() > 280:
        phil.sety(280)

    if phil.xcor() < -280:
        phil.setx(-280)
    if phil.ycor() <- 280:
        phil.sety(-280)
def rightp():
    phil.right(90)

def leftp():
    phil.left(90)

turtle.listen()
turtle.onkey(leftp, "a")
turtle.onkey(fdp, "w")
turtle.onkey(rightp, "d")


def isCollision(t1, t2):
    distance = math.sqrt(math.pow(t1.xcor()-t2.xcor(),2)+math.pow(t1.ycor()-t2.ycor(),2))
    if distance < 20:
        return True
    else:
        return False
while True:
    if isCollision(bob, phil):
        bob.setposition(-50, 0)
        phil.setposition(50, 0)



turtle.done()

Ответы [ 3 ]

0 голосов
/ 02 мая 2019

сделайте так, чтобы ваш turtle.done() был внутри цикла while.Это решит проблему замораживания.например:

while True:
    if isCollision(bob, phil):
        bob.setposition(-50, 0)
        phil.setposition(50, 0)
    turtle.done()

Вы также можете удалить цикл while, поскольку он вам действительно не нужен для работы вашего оператора if.как это:

if isCollision(bob, phil):
    bob.setposition(-50, 0)
    phil.setposition(50, 0)
turtle.done()
0 голосов
/ 02 мая 2019

Существуют проблемы с вашим исходным кодом и предлагаемыми ответами, которые я пытался устранить ниже.В частности: вам не нужно вычислять расстояние между черепахами, они уже знают, как это сделать;ваше и другие использование tracer() не имеет смысла, так как у вас нет вызовов update();столкновение между Бобом и Филом должно быть симметричным, но один из ответов предполагает, что Боб сталкивается с Филом, а не Фил - с Бобом;один из ответов, кажется, не понимает природу turtle.done().

from turtle import Screen, Turtle, mainloop

def bob_left():
    bob.left(90)

def bob_forward():
    bob.forward(20)

    if bob.xcor() > 280:
        bob.setx(280)
    elif bob.xcor() < -280:
        bob.setx(-280)

    if bob.ycor() > 280:
        bob.sety(280)
    elif bob.ycor() < -280:
        bob.sety(-280)

    checkCollision()

def bob_right():
    bob.right(90)

def phil_left():
    phil.left(90)

def phil_forward():
    phil.forward(20)

    if phil.xcor() > 280:
        phil.setx(280)
    elif phil.xcor() < -280:
        phil.setx(-280)

    if phil.ycor() > 280:
        phil.sety(280)
    elif phil.ycor() < -280:
        phil.sety(-280)

    checkCollision()

def phil_right():
    phil.right(90)

def isCollision(t1, t2):
    return t1.distance(t2) < 20

def checkCollision():
    if isCollision(bob, phil):
        bob.setposition(-50, 0)
        phil.setposition(50, 0)

screen = Screen()
screen.bgcolor('black')
screen.setup(width=700, height=700)

border_pen = Turtle(visible=False)
border_pen.speed('fastest')
border_pen.color('white')
border_pen.pensize(3)

border_pen.penup()
border_pen.setposition(-300, -300)
border_pen.pendown()

for _ in range(4):
    border_pen.fd(600)
    border_pen.lt(90)

bob = Turtle('triangle')
bob.speed('fastest')
bob.color('blue')
bob.penup()
bob.setpos(-50, 0)

phil = Turtle('triangle')
phil.speed('fastest')
phil.color('red')
phil.penup()
phil.setposition(50, 0)

screen.onkey(bob_left, 'Left')
screen.onkey(bob_forward, 'Up')
screen.onkey(bob_right, 'Right')

screen.onkey(phil_left, 'a')
screen.onkey(phil_forward, 'w')
screen.onkey(phil_right, 'd')
screen.listen()

mainloop()
0 голосов
/ 02 мая 2019

После просмотра это должно работать:

import turtle
import math

bob = turtle.Turtle()

wn = turtle.Screen()
wn.bgcolor("black")
wn.setup(width = 700, height = 700)
wn.tracer()

border_pen = turtle.Turtle()
border_pen.speed(0)
border_pen.color("white")
border_pen.penup()
border_pen.setposition(-300,-300)
border_pen.pendown()
border_pen.pensize(3)

for side in range(4):
    border_pen.fd(600)
    border_pen.lt(90)
border_pen.hideturtle()

bob.shape("triangle")
bob.speed(0)
bob.color("blue")
bob.penup()
bob.setpos(-50, 0)
def draw():
    bob.penup()
def nodraw():
    bob.pendown()

def fd():
    bob.fd(20)
    if bob.xcor() > 280:
        bob.setx(280)
    if bob.ycor() > 280:
        bob.sety(280)

    if bob.xcor() < -280:
        bob.setx(-280)
    if bob.ycor() <- 280:
        bob.sety(-280)
    distance = math.sqrt(math.pow(bob.xcor()-phil.xcor(),2)+math.pow(bob.ycor()-phil.ycor(),2))
    print(distance)
    if distance < 20:
        bob.setposition(-50, 0)
        phil.setposition(50, 0)
def right():
    bob.right(90)

def left():
    bob.left(90)

turtle.listen()
turtle.onkey(left, "Left")
turtle.onkey(fd, "Up")
turtle.onkey(right, "Right")

phil = turtle.Turtle()
phil.speed(0)
phil.penup()
phil.shape("triangle")
phil.color("red")
phil.setpos(50, 0)

def fdp():
    phil.fd(20)
    if phil.xcor() > 280:
        phil.setx(280)
    if phil.ycor() > 280:
        phil.sety(280)

    if phil.xcor() < -280:
        phil.setx(-280)
    if phil.ycor() <- 280:
        phil.sety(-280)
def rightp():
    phil.right(90)

def leftp():
    phil.left(90)

turtle.listen()
turtle.onkey(leftp, "a")
turtle.onkey(fdp, "w")
turtle.onkey(rightp, "d")

turtle.done()
...