因此,在Pygame中,我试图创建一种蝙蝠/球类游戏,其中球以各种速度从屏幕顶部(如流星)发出,并且蝙蝠位于可以移动的屏幕底部附近左右。根据所按的键(球的前进方向)以及是否有击球(即碰撞),球会朝某个方向运动。例如,如果您按“ d”键,则球会移到右侧(假设有击中/碰撞)。
现在一切似乎都运转良好,但是,我真正想要的是当球接近球棒时,玩家安排按键的时间。目前,我可以这样做,但是如果我早些时候一直按住“ d”键,球仍然会击中球棒。这绝对不是我想要的,因为它破坏了计时的目的并且使球具有不同的速度。我了解为什么会发生这种情况,因为pygame.key.get_pressed()似乎并没有区分一键按住,而是将它们视为一个事件。因此,从本质上讲,我只希望在球经过球拍时按下键,而不是从一开始就按住它,才发生碰撞。这是Ball类,其中包含主要代码。
class Ball(pygame.sprite.Sprite):
def __init__(self):
pygame.sprite.Sprite.__init__(self)
self.image = meteor_img
self.image.set_colorkey(WHITE)
self.rect = self.image.get_rect()
self.radius = int(self.rect.width * .85 / 2)
#pygame.draw.circle(self.image, RED, self.rect.center, self.radius)
self.rect.x = WIDTH /2 + 10
self.rect.y = HEIGHT - 770
self.speedy = random.randint(7, 14)
self.speedx = 0.3
self.j = 0
def update(self):
if self.rect.y < HEIGHT - 450 and self.j!= 1:
Ball.old_ball(self)
self.rect.x -= self.speedx
self.rect.y += self.speedy
#print (self.rect.x, self.rect.y)
elif self.j !=1:
Ball.change_ball(self)
self.rect.x += self.speedx
self.rect.y += self.speedy
#print (self.rect.x, self.rect.y)
else:
Ball.old_ball(self)
self.rect.x += self.speedx
self.rect.y += self.speedy
#print (self.rect.y)
shot_played = pygame.key.get_pressed()
hits = pygame.sprite.spritecollide(player, mobs, False, pygame.sprite.collide_circle)
#print (hits)
if hits and shot_played[pygame.K_e]:
#print ("Perfect Timing")
self.speedx = random.uniform(1, 5)
self.speedy = -random.uniform(2, 4)
self.j = 1
elif hits and shot_played[pygame.K_d]:
#print ("Perfect Timing")
self.speedx = random.uniform(6, 10)
self.speedy = -random.uniform(-2, 2)
self.j = 1
elif hits and shot_played[pygame.K_a]: #Leg Side
#print ("Perfect Timing")
self.speedx = -random.uniform(6, 10)
self.speedy = -random.uniform(-2, 2)
self.j = 1
if self.rect.top > HEIGHT + 10 or self.rect.left < -25 or self.rect.right > WIDTH + 20 or self.rect.y < 10:
self.rect.x = WIDTH /2+10
self.rect.y = HEIGHT - 770
self.speedy = random.randint(7, 14)
self.speedx = 0.3
self.j = 0
time.sleep(1)
#self.speedy = random.randrange(1, 8)
def change_ball(self):
self.image = ball_pitched_img
self.image.set_colorkey(WHITE)
def old_ball(self):
self.image = meteor_img
self.image.set_colorkey(WHITE)
答案 0 :(得分:0)
您可以只使用事件循环来代替状态检查。当您按下一个键时,pygame一次向队列添加一个pygame.KEYDOWN
事件,而在释放键时将一个pygame.KEYUP
事件添加到队列。调用pygame.event.get()
会清空队列,并返回事件列表,您可以使用for
循环对其进行迭代以处理另一个事件。
import pygame
pygame.init()
screen = pygame.display.set_mode((640, 480))
clock = pygame.time.Clock()
done = False
while not done:
# for each event in the event queue.
for event in pygame.event.get():
if event.type == pygame.QUIT:
done = True
elif event.type == pygame.KEYDOWN:
if event.key == pygame.K_d:
print('d pressed')
# Check if the bat collides with the ball here.
screen.fill((30, 30, 30))
pygame.display.flip()
clock.tick(60)