如何列出海龟运动的坐标?

时间:2020-08-22 14:02:37

标签: python python-3.x coordinates python-turtle

我是python的初学者,我正在与乌龟一起做一个小型迷宫游戏。该游戏使用相对像素(可能不是官方术语)-在此,它不使用像素值来移动,而是使用屏幕分辨率来确定所需移动量(在代码中-第33-44行)。

我的屏幕分辨率为1366 x 768-像素测量由此进行。我想跟踪乌龟经过的所有坐标,并将它们全部添加到另一只乌龟的阻止坐标列表中。

我如何测量乌龟mak1通过的所有坐标? (最好每个动作都没有for循环)谢谢!

PS。我的代码可能效率不高-我不是很擅长

for i in range (1):
    import turtle
    import random
    import math
    import pyautogui
    import keyboard
    import ctypes
    import time


#turtle def
for i in range(1):
    turtle.getscreen().bgcolor('black')
    mak1 = turtle.Turtle()
    mak2 = turtle.Turtle()
    wn = turtle.Screen()
    pacman = turtle.Turtle()
    mak1.color('white')
    mak2.color('white')
    pacman.color('yellow')
    mak1.hideturtle()
    mak1.speed(0)
    mak2.hideturtle()
    mak2.speed(0)
    mak1.width(10)
    mak2.width(10)
    pacman.shape('circle')
    pacman.shapesize(stretch_wid = 1.5, stretch_len = 1.5)


#GetAndSetScreenRes - line 33
for i in range(1):
    user32 = ctypes.windll.user32
    width = user32.GetSystemMetrics(0)
    height = user32.GetSystemMetrics(1)
    wn.setup(width, height)

#values
for i in range(1):
    pix50 = (width/26)
    pix100 = (width/13)
    pix200 = (width/(13/2))
    blocked_coords = [] # line 44


#make the maze - mak1
for i in range (1):
    mak1.penup()
    mak1.fd(pix100)
    mak1.pendown()
    mak1.lt(90)
    mak1.bk(pix100)
    #innersquare
    for i in range(4):
        if (i == 1) or (i == 3):
            mak1.fd(pix50)
            mak1.penup()
            mak1.fd(pix100)
            mak1.pendown()
            mak1.fd(pix50)
        else:
            mak1.fd(pix200)
        mak1.lt(90)
    mak1.fd(pix100)
    mak1.rt(90)
    #right mid
    for i in range(1):
        mak1.penup()
        mak1.rt(90)
        mak1.fd(pix100)
        mak1.lt(90)
        mak1.fd(pix100)
        mak1.pendown()
        mak1.fd(pix100)
        mak1.rt(90)
        for i in range(2):
            mak1.fd(pix200)
            mak1.lt(90)
        mak1.fd(pix100)
        mak1.penup()
        mak1.lt(90)
        mak1.fd(pix100)
        mak1.rt(90)
        mak1.pendown()
        mak1.fd(pix100)
    #toppie
    for i in range(1):
        mak1.penup()
        mak1.goto(0, 0)
        mak1.seth(90)
        mak1.fd(pix200)
        mak1.pendown()
        mak1.fd(pix50)
        mak1.lt(90)
        mak1.fd(pix50)
        mak1.bk(pix100)
        mak1.penup()
        mak1.fd(pix200)
        mak1.pendown()
        mak1.fd(pix50)
        mak1.lt(90)
        mak1.fd(pix50)
        mak1.rt(90)
        mak1.fd(50)
        mak1.penup()
        mak1.fd(pix200)
        mak1.pendown()
        mak1.fd(pix100)
        mak1.penup()
        mak1.bk(pix200)
        mak1.lt(90)
        mak1.pendown()
        mak1.fd(pix100)
        mak1.penup()
        mak1.goto(0, 0)
        mak1.seth(0)
    #cubey
    for i in range (1):
        mak1.fd (pix100)
        mak1.pendown()
        mak1.fd(pix200)
        mak1.lt(90)
        mak1.fd(pix100)
        mak1.penup()
        mak1.lt(90)
        mak1.fd(pix100)
        mak1.rt(90)
        mak1.pendown()
        mak1.fd(pix100)
        mak1.penup()
        mak1.bk(pix100)
        mak1.rt(90)
        mak1.fd(pix200)
        mak1.pendown()
        mak1.fd(pix200)
        mak1.lt(90)
        mak1.fd(pix100)
        mak1.penup()
        mak1.lt(90)
        mak1.fd(pix100)
        mak1.pendown()
        mak1.fd(200)
        mak1.penup()
        mak1.fd(pix100)
        mak1.rt(90)
        mak1.fd(pix100)
        mak1.rt(90)
        mak1.pendown()
        mak1.fd(pix200 + pix200)
        mak1.penup()
        mak1.bk(pix200 * 4 + pix100)
        mak1.pendown()
        mak1.bk(pix200 + pix100)
        mak1.penup()
        mak1.goto(0, 0)
        mak1.seth(90)

    
#blocked coords
#??


#end program
turtle.done()```

1 个答案:

答案 0 :(得分:0)

乌龟免费提供给您的最好的东西是乌龟在使用begin_poly()end_poly()get_poly()时开始/停止的所有点的坐标,例如:< / p>

mak1.begin_poly()

#make the maze - mak1
for i in range (1):
    mak1.penup()
    mak1.fd(pix100)

# ...
        mak1.penup()
        mak1.goto(0, 0)
        mak1.seth(90)

mak1.end_poly()

#blocked coords

blocked_coords = mak1.get_poly()

这将为您提供类似的帮助:

((0.00,0.00), (129.23,0.00), (129.23,-129.23), (129.23,129.23), (64.62,129.23),
 (-64.62,129.23), (-129.23,129.23), (-129.23,-129.23), (-64.62,-129.23), (64.62,-129.23),
 (129.23,-129.23), (129.23,-0.00), (129.23,-129.23), (258.46,-129.23), (387.69,-129.23),
 (387.69,-387.69), (646.15,-387.69), (646.15,-258.46), (516.92,-258.46), (516.92,-129.23),
 (0.00,0.00), (0.00,258.46), (0.00,323.08), (-64.62,323.08), (64.62,323.08),
 (-193.85,323.08), (-258.46,323.08), (-258.46,258.46), (-308.46,258.46), (-566.92,258.46),
 (-696.15,258.46), (-437.69,258.46), (-437.69,129.23), (0.00,0.00), (129.23,-0.00),
 (387.69,-0.00), (387.69,129.23), (258.46,129.23), (258.46,258.46), (258.46,129.23),
 (516.92,129.23), (775.38,129.23), (775.38,258.46), (646.15,258.46), (446.15,258.46),
 (316.92,258.46), (316.92,387.69), (833.85,387.69), (-329.23,387.69), (-716.92,387.69),
 (0.00,0.00))

但是,除非您受过有关pen缩和pen落训练的纪律,否则可能无法实现您的目的。

另一种方法是先用ASCII定义迷宫(空格用于空白空间,句号用于墙段等),然后将空间分成网格。由于您的墙壁已经是10像素厚,因此尽管我会更厚一些,例如pacman的厚度为30px。然后在ASCII迷宫定义中的每个期间,在该点放一个新的方形乌龟。

绘制似乎比较困难,但是在运行时,您可以简单地使用turtle distance()方法来确定是否与墙段发生了碰撞。在SO中搜索此类示例,它们就在那里。

最后,您应该可以删除Windows依赖项:

user32 = ctypes.windll.user32
width = user32.GetSystemMetrics(0)
height = user32.GetSystemMetrics(1)
wn.setup(width, height)

改为在乌龟本身内做些事情:

wn = turtle.Screen()
wn.setup(1.0, 1.0)  # as much screen as I can get
width = wn.window_width()
height = wn.window_height()