Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何让海龟走向另一只乌龟的位置?

如何让海龟走向另一只乌龟的位置?
EN

Stack Overflow用户
提问于 2019-09-20 21:06:20
回答 2查看 1.3K关注 0票数 1

我想创造的SpaceInvaders游戏,但不是敌人击落,它将射击的球员。我使用这样的.goto()方法实现了它:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
bullet2.goto(player.xcor(),player.ycor())

但是这里的问题是,子弹用球员的坐标来修正它的目的地,从而被困在那里。我希望他们继续朝那个方向移动,直到敌人再次射击时,屏幕才会消失(我没有找到一种直接的方法来计算两个海龟位置之间的航向)。

我也很清楚该把bullet2.goto(player.xcor(),player.ycor())命令放在哪里:它应该在while(True)循环中,或者在激发子弹的函数中。

我在下面张贴我的代码。我的目标是:有两种不同类型的敌人,一种是圆圈运动,另一种是方形模式。第一次敌人射击后,作出4次移动棒和第二次敌人射击后,作出2次移动。不管他们发射什么,子弹都向玩家移动,除非子弹从屏幕上弹出来,否则敌人就不能再开火了。

我不是在找碰撞。

我知道在使所有的东西都是面向对象的方面可以改进很多,但是现在我专注于游戏的功能。一旦我清理了基本功能就会这么做。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# python 2.7 and turtle library

import os
import random
import sys
import turtle
turtle.fd(0)
turtle.speed(6)
turtle.bgcolor("black")
turtle.ht()
turtle.setundobuffer(1)
turtle.tracer(1)

class Game():       
    def draw_border(self):
        #Draw border
        self.pen = turtle.Turtle()
        self.pen.speed(0)
        self.pen.color("white")
        self.pen.pensize(3)
        self.pen.penup()
        self.pen.goto(-300, 300)
        self.pen.pendown()
        for side in range(4):
            self.pen.fd(600)
            self.pen.rt(90)
        self.pen.penup()
        self.pen.ht()

game = Game()
game.draw_border()

bulletstate1 = "ready"
bulletstate2 = "ready"

def enemy1_fire():
    #the bullet will travel up from the player's position
    global bulletstate1 # enable modifying global var from inside of function
    if bulletstate1 == "ready":
        bulletstate1 = "fired"
        bullet1.showturtle()
        x = enemy1.xcor() # get the coordinates at the time of firing
        y = enemy1.ycor()
        bullet1.speed = 6
        bullet1.setposition(x,y) # bullet will appear just above the player
        #bullet1.goto(player.xcor(),player.ycor())
        #print(bulletspeed,bullet.xcor(),bullet.ycor(),bulletstate1)

def enemy2_fire():
    #the bullet will travel up from the player's position
    global bulletstate2 # enable modifying global var from inside of function
    if bulletstate2 == "ready":
        bulletstate2 = "fired"
        bullet2.showturtle()
        x = enemy2.xcor()
        y = enemy2.ycor()
        bullet2.speed = 6
        bullet2.setposition(x,y) # bullet will appear just above the player
        #bullet2.goto(player.xcor(),player.ycor())
        #print(bulletspeed,bullet.xcor(),bullet.ycor(),bulletstate2)

class Player(turtle.Turtle):
    def __init__(self, spriteshape, color, startx, starty):
        turtle.Turtle.__init__(self, shape = spriteshape)
        self.speed(3)
        self.penup()
        self.color(color)
        self.fd(0)
        self.goto(startx, starty)
        self.speed = 1
        self.left(90)
        #self.mode("logo")  

    def move(self):
        self.fd(self.speed)
        if (player.xcor()<-280): # boundary checking
            player.setx(-280)
        if (player.xcor()> 280): # boundary checking
            player.setx(280)
        if (player.ycor()<-280): # boundary checking
            player.sety(-280)
        if (player.ycor()> 280): # boundary checking
            player.sety(280)

    def turn_left(self):
        self.move()
        self.lt(30)
        if (player.xcor()<-280): # boundary checking
            player.setx(-280)
        if (player.xcor()> 280): # boundary checking
            player.setx(280)
        if (player.ycor()<-280): # boundary checking
            player.sety(-280)
        if (player.ycor()> 280): # boundary checking
            player.sety(280)

    def turn_right(self):
        self.move()
        self.rt(30)
        if (player.xcor()<-280): # boundary checking
            player.setx(-280)
        if (player.xcor()> 280): # boundary checking
            player.setx(280)
        if (player.ycor()<-280): # boundary checking
            player.sety(-280)
        if (player.ycor()> 280): # boundary checking
            player.sety(280)

    def accelerate(self):
        self.move()
        self.speed = self.speed + 1
        if (player.xcor()<-280): # boundary checking
            player.setx(-280)
        if (player.xcor()> 280): # boundary checking
            player.setx(280)
        if (player.ycor()<-280): # boundary checking
            player.sety(-280)
        if (player.ycor()> 280): # boundary checking
            player.sety(280)

    def brake(self):
        self.speed = self.speed - 1
        if (player.xcor()<-280): # boundary checking
            player.setx(-280)
        if (player.xcor()> 280): # boundary checking
            player.setx(280)
        if (player.ycor()<-280): # boundary checking
            player.sety(-280)
        if (player.ycor()> 280): # boundary checking
            player.sety(280)

class Enemy1(turtle.Turtle):
    def __init__(self, spriteshape, color, startx, starty):
        turtle.Turtle.__init__(self, shape = spriteshape)
        self.speed(3) #animation speed
        self.penup()
        self.color(color)
        self.fd(0)
        self.goto(startx, starty)
        self.speed = 1
        #self.mode("logo")

    shoot = 4 # shoots after 4 interval

    def move(self):
        self.lt(90)
        self.fd(150)
        self.shoot = self.shoot - 1
        if self.shoot==0:
            enemy1_fire() #shoot below, better if can be directed at player
            self.shoot = 4

class Enemy2(turtle.Turtle):
    def __init__(self, spriteshape, color, startx, starty):
        turtle.Turtle.__init__(self, shape = spriteshape)
        self.speed(3)
        self.penup()
        self.color(color)
        self.fd(0)
        self.goto(startx, starty)
        self.speed = 1
        #self.mode("logo")

    shoot = 2 # shoots after 2 interval

    def move(self):
        self.fd(100)
        self.rt(30)
        self.shoot= self.shoot-1
        if self.shoot==0:
            enemy2_fire() #shoot towards player
            self.shoot = 2

enemy1 = Enemy1("circle", "red", 50, -50)
enemy2 = Enemy2("square", "blue", -10, 200)
player = Player("triangle", "white", 0, 0)


#key bindings
turtle.listen()
turtle.onkey(player.turn_left,"Left")
turtle.onkey(player.turn_right,"Right")
turtle.onkey(player.accelerate,"Up")
turtle.onkey(player.brake,"Down")

# create a bullet for the enemy1
bullet1  = turtle.Turtle()
bullet1.color("yellow")
bullet1.shape("triangle")
bullet1.penup()
bullet1.shapesize(0.3,0.3) # length and breadth of bullet
bullet1.hideturtle()
bullet1.speed(3)
bullet1.speed = 2

# create a bullet for the enemy2
bullet2  = turtle.Turtle()
bullet2.color("yellow")
bullet2.shape("square")
bullet2.penup()
bullet2.shapesize(0.4,0.4) # length and breadth of bullet
bullet2.hideturtle()
bullet2.speed(3)
bullet2.speed = 2


while True:
    enemy1.move()
    enemy2.move()

    if bulletstate1=="fired":
        # y = bullet1.ycor()
        # y = y - bullet1.speed
        # bullet1.sety(y)
        bullet1.goto(player.xcor(),player.ycor())

    if bulletstate2=="fired":
        # y = bullet2.ycor()
        # y = y - bullet2.speed
        # bullet2.sety(y)
        bullet2.goto(player.xcor(),player.ycor())

    if (bullet1.ycor()>275 or bullet1.xcor()>275 or bullet1.ycor()<-275 or bullet1.xcor()<-275):
        bullet1.hideturtle()
        # bullet1.sety(enemy1.ycor)
        # bullet1.setx(enemy1.xcor)
        bulletstate1="ready"


    if (bullet2.ycor()>275 or bullet2.xcor()>275 or bullet2.ycor()<-275 or bullet2.xcor()<-275):
        bullet2.hideturtle()
        # bullet2.sety(enemy2.ycor)
        # bullet2.setx(enemy2.xcor)
        bulletstate2="ready"

sys.stdout.close()
delay = raw_input("Press enter to finish. > ")
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-11-07 08:06:30

如果您仍然有兴趣解决这个问题,您应该解决正确的三角形(见图):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        px            
---------|--x--------|
|        |  |        |
|        |  x        |
y--------|-[e]y------y
|        |/ |        |
py-------*py--------py
|       /px |        |
|      / |  |        |
|     /  |  |        |
|    /   |  |        |
|---v----|--x--------|
  y2=-280
  x2=?

[e]是敌人,*是玩家,xy是敌人的坐标,pxpy是玩家的坐标。对于所示的情况,您应该从关系中获得x2坐标:

(x-px)/(y-py) = (x-x2)/(y-(-280)) => (x-x2) = (y-(-280))*(x-px)/(y-py) =>

=> x2 = x-(y-(-280))*(x-px)/(y-py)

xypxpyy2

你必须考虑到玩家和敌人的相对位置,例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
               px
       ---------|------x----|
       |        |      |    |
       |        |      |    |
       |        |      x    |
       y--------|-- . [e]y--y
       py-------*py----|---py
       |    .   px     |    |
       |  .     |      |    |
y2=?   <. ------|------|----|
x2=-280|        |      |    |
       |--------|------x----|

(x-px)/(y-py) = (x-(-280))/(y-y2) => (y-y2) = (x-(-280))*(y-py)/(x-px) =>

=> y2 = y-(x-(-280))*(y-py)/(x-px)

以及坐标差异的迹象。

在您的示例中,这将导致以下代码(我建议您将其设计为一个单独的函数):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
MAX_COOR=330

def bullet_calc(player,x,y):
  diff_x=x-player.xcor()
  diff_y=y-player.ycor()
  if diff_y==0:
    goal_y=y
    if diff_x>0:
      goal_x=-MAX_COOR
    elif diff_x<=0:
      goal_x=MAX_COOR

  elif diff_x==0:
    goal_x=x
    if diff_y>0:
      goal_y=-MAX_COOR
    elif diff_y<=0:
      goal_y=MAX_COOR

  elif diff_x>0 and diff_y>0 and abs(diff_x)<abs(diff_y):  #    |-    - enemy
      goal_x=x-(y-(-MAX_COOR))*diff_x/diff_y               # ---*---  * player
      goal_y=-MAX_COOR                                     #    |

  elif diff_x>0 and diff_y>0 and abs(diff_x)>abs(diff_y):  #    |  _
      goal_x=-MAX_COOR                                     # ---*---
      goal_y=y-(x-(-MAX_COOR))*diff_y/diff_x               #    |

  elif diff_x<0 and diff_y>0 and abs(diff_x)<abs(diff_y):  #   -|    
      goal_x=(y-MAX_COOR)*diff_x/diff_y-x                  # ---*---
      goal_y=-MAX_COOR                                     #    |

  elif diff_x<0 and diff_y>0 and abs(diff_x)>abs(diff_y):  # _  | 
      goal_x=MAX_COOR                                      # ---*---
      goal_y=(x-(-MAX_COOR))*diff_y/diff_x-y               #    |

  elif diff_x>0 and diff_y<0 and abs(diff_x)<abs(diff_y):  #    | 
      goal_x=(y-(-MAX_COOR))*diff_x/diff_y-x               # ---*---
      goal_y=MAX_COOR                                      #    |_

  elif diff_x>0 and diff_y<0 and abs(diff_x)>abs(diff_y):  #    | 
      goal_x=-MAX_COOR                                     # ---*--_
      goal_y=(x-MAX_COOR)*diff_y/diff_x-y                  #    |

  elif diff_x<0 and diff_y<0 and abs(diff_x)<abs(diff_y):  #    | 
      goal_x=x-(y-MAX_COOR)*diff_x/diff_y                  # ---*---
      goal_y=MAX_COOR                                      #   _|

  elif diff_x<0 and diff_y<0 and abs(diff_x)>abs(diff_y):  #    | 
      goal_x=MAX_COOR                                      # _--*---
      goal_y=y-(x-MAX_COOR)*diff_y/diff_x                  #    |

  return (goal_x,goal_y)

在触发项目的函数中调用此代码似乎更容易:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def enemy1_fire():
    #the bullet will travel up from the player's position
    global bulletstate1 # enable modifying global var from inside of function
    if bulletstate1 == "ready":
        bulletstate1 = "fired"
        x = enemy1.xcor() # get the coordinates at the time of firing
        y = enemy1.ycor()
        bullet1.speed = 6
        bullet1.setposition(x,y) # bullet will appear just above the player
        bullet1.showturtle()     # move <showturtle()> here
        bullet1.goto(bullet_calc(player,x,y))
        #bullet1.goto(player.xcor(), player.ycor())  # your old code

所有这一切都更容易,如果球员是在球场的中心。

票数 1
EN

Stack Overflow用户

发布于 2019-11-07 13:57:37

而不是做:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
if bulletstate1=="fired":
    bullet1.goto(player.xcor(),player.ycor())

你想要的是:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
if bulletstate1 == 'fired':
    bullet1.setheading(bullet1.towards(player))
    bullet1.forward(min(10, bullet1.distance(player))

这是在你的运动循环中,在每次迭代中都有子弹转向球员当前的位置,并稍微向前移动。如果玩家站着不动,子弹最终会击中他们。如果玩家在移动,子弹就会追踪他们。

然而,子弹不太可能“从屏幕上消失”。如果向前迈出的一步很大,可能是这样的:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 bullet1.forward(min(100, bullet1.distance(player))
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58037430

复制
相关文章
iOS在线音频流播放
前言 这是一篇关于在线音频播放的文章,参考自苹果OS X的demo。 在移植到iOS后,可以通过iphone播放Mac上面的音频,实现在线播放音频的功能。 本文可以学习到socket编程、AudioFileStream转换音频流、AudioQueue播放音频、信号量的使用。 正文 demo有两个工程,分别是servers和client。 servers是OS X的应用,作为服务端,负责发送音频流数据; client是iOS的应用,作为客户端,负责接收音频流数据; 音频数据通过AudioFil
落影
2018/04/27
2.7K0
iOS在线音频流播放
NoteBurner iTunes DRM Audio Converter for Mac(苹果DRM音频转换器)
NoteBurner iTunes DRM Audio Converter mac版可以一键将DRM保护的音乐文件转换为常见的MP3或者是AAC格式的音频文件,可以在后台以20倍速度记录有声读物。
Mac知识分享
2022/09/02
1K0
Sidify Apple Music Converter mac(Apple音乐转换器)
Sidify Apple Music Converter是一款全功能,功能强大的专业Apple音乐转换器,不仅可以转换Apple音乐文件,还可以转换所有可在iTunes中播放的音乐,包括iTunes M4A / M4B,Audible AA / AAX有声读物和iTunes M4P音乐,转换时可以选择最大20倍的转换速度。
Mac小小
2022/08/26
1.3K0
iOS AVDemo(3):音频封装,采集编码并封装为 M4A丨音视频工程示例
iOS/Android 客户端开发同学如果想要开始学习音视频开发,最丝滑的方式是对音视频基础概念知识有一定了解后,再借助本地平台的音视频能力上手去实践音视频的采集 → 编码 → 封装 → 解封装 → 解码 → 渲染过程,并借助音视频工具来分析和理解对应的音视频数据。
关键帧
2022/06/13
5820
iOS AVDemo(3):音频封装,采集编码并封装为 M4A丨音视频工程示例
iOS/Android 音视频开发专题
记得从 2016 年起我开始从事音视频 SDK 开发,当时音频技术处于零基础阶段。现在 Android 和 iOS SDK 已迭代至 v3.x 版本。在期间得到很多乐于分享的开发者帮助,如果没有他们分享的精神,我无法完成这么复杂的工作。现在,我也愿意把自己在音视频领域积累的开发经验分享出来,让相关开发者能够得到一点启发和帮助。
100001509164
2022/01/20
8540
使用播放器播放视频有黑边
1.推流端推的画面本身有黑边。因为SDK推流只支持16:9(或者9:16)的画面,如果推流端采集的画面不是16:9的,SDK编码时也会编码成16:9的比例,多出来的部分以黑色填充,具体表现就是编码出来的画面有黑边。这样的情况拉流端SDK一般是处理不了的
腾讯云-qichengdeng
2019/09/05
2.9K0
iOS音频播放(一)
转载: http://msching.github.io/blog/2014/07/07/audio-in-ios/
音视频_李超
2020/04/02
1.8K0
AudFree Audio Converter 2.9.0 Mac音频格式文件转换器
AudFree Audio Converter是一款功能强大的音频转换软件,该软件的最大特点是支持多种加密音频格式的转换,如DRM M4P、M4B、AA、AAX等,可以帮助用户轻松转换iTunes购买的音频、亚马逊音乐等流媒体平台下载的音频。
用户1517359
2023/05/20
5890
AudFree Audio Converter 2.9.0 Mac音频格式文件转换器
AudioToolbox_如何录制PCM格式的数据
先来认识一下头文件 AudioConverter.h: 音频转换接口。定义用于创建和使用音频转换器的接口 AudioFile.h: 定义一个用于读取和写入文件中的音频数据的接口。 AudioFileStream.h: 定义了一个用于解析音频文件流的接口。 AudioFormat.h: 定义用于分配和读取音频文件中的音频格式元数据的接口。 AudioQueue.h: 定义播放和录制音频的接口。 AudioServices.h: 定义三个接口。系统健全的服务让你播放简短的声音和警报。音频硬件服务提供了一个轻量级的接口,用于与音频硬件交互。音频会议服务,让iPhone和iPod触摸应用管理音频会议。 AudioToolbox.h: 顶层包括音频工具箱框架的文件。 AuGraph.h:定义用于创建和使用音频处理图形界面。 ExtendedAudioFile.h: 定义用于将音频数据从文件直接转化为线性PCM接口,反之亦然。
酷走天涯
2018/09/14
1.5K0
AudioToolbox_如何录制PCM格式的数据
iOS AVDemo(4):音频解封装,从 MP4 中解封装出 AAC丨音视频工程示例
iOS/Android 客户端开发同学如果想要开始学习音视频开发,最丝滑的方式是对音视频基础概念知识有一定了解后,再借助本地平台的音视频能力上手去实践音视频的采集 → 编码 → 封装 → 解封装 → 解码 → 渲染过程,并借助音视频工具来分析和理解对应的音视频数据。
关键帧
2022/06/13
5170
iOS AVDemo(4):音频解封装,从 MP4 中解封装出 AAC丨音视频工程示例
使用AudioToolbox播放AAC
前言 使用VideoToolbox硬编码H.264 使用VideoToolbox硬解码H.264 使用AudioToolbox编码AAC 在上一篇中,介绍了如何从麦克风采集声音并用AudioToolbox编码成AAC码流,这次是使用AudioToolbox来播放之前录制的AAC码流。 介绍 在iOS设备上播放音频,可以使用AVAudioPlayer(AVFoundation框架内),但是不支持流式播放。 Apple recommends that you use this class for aud
落影
2018/04/27
1.5K0
使用AudioToolbox播放AAC
FFmpeg4.0+SDL2.0笔记07:Seeking
背景:在系统性学习FFmpeg时,发现官方推荐教程还是15年的,不少接口已经弃用,大版本也升了一级,所以在这里记录下FFmpeg4.0+SDL2.0的学习过程。
非一
2021/04/13
6540
FFmpeg推流到Nginx并使用播放器播放
如今直播很火,下面就简单分享下我是如何直播的。必备工具:FFmpeg,Nginx,还有一个播放器。之前在实例解析中分享过如何用FreeSWITCH来做直 播,这次分享下如何用FFmpeg配合Nginx做直播。
杜金房
2020/12/21
1.9K0
使用PWM实现语音播放
链接:https://community.arm.com/cn/b/blog/posts/nucleof429-2-pwm
MCU起航
2021/04/23
2.9K0
delphi 使用windowsmediaplayer播放视频
delphi7中原本自带的一个Tmediaplayer控件,但是发现有不少视频是无法播放的,于是就想到了用windowsmediaplayer来进行播放。
Vaccae
2019/07/25
3.1K0
delphi 使用windowsmediaplayer播放视频
超级播放器点播如何使用Fileid加密播放?
1.播放视频中会有一些视频不想被没获取到或者不想别人看到,这个时候就会用到加密,超级播放是通过视频文件的id来进行加密
腾讯云-qichengdeng
2019/09/12
1.6K0
使用Python,怎么播放视频?
使用Python,怎么播放视频? 昨天分享了用python播放音频,今天来分享一下播放视频。将这一主题补充完整。 import numpy as np import cv2 cap = cv2.VideoCapture('vtest.avi') while(cap.isOpened()): ret, frame = cap.read() gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) cv2.imshow('frame',gray
TalkPython
2020/12/29
1.7K0
点击加载更多

相似问题

AudioQueue内存播放示例

33

播放中的AudioQueue间隙

10

ios音频:使用audioqueue改变播放进度

18

在使用AudioQueue录制的同时使用MPMoviePlayerController播放视频

10

无法同时录制/播放AudioQueue和动画

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文