首页 > 解决方案 > 如何在pygame中以一定角度射击子弹?

问题描述

我在 pygame 中制作游戏,当你发射子弹时,子弹的行进方向与鼠标移动的方向相同。这是我Player班级的代码:

class Player(pygame.sprite.Sprite):
    def __init__(self, game, x, y):
        self.game = game
        pygame.sprite.Sprite.__init__(self, game.all_sprites)
        self.image = pygame.Surface((50, 50))
        self.image.fill(settings.player_color)

        self.rect = self.image.get_rect()
        self.rect.x, self.rect.y = x, y
        self.pos = Vector2(x, y)

        self.speed = Vector2(0, 0)

        self.is_shooting = False

    def update(self):
        self.pos += self.speed
        self.rect.x, self.rect.y = self.pos.x, self.pos.y

    def shoot(self):
        self.is_shooting = True
        m_x, m_y = pygame.mouse.get_pos()
        b_m_x, b_m_y = m_x - self.pos.x, m_y - self.pos.y
        b = Bullet(self.game, self.rect.x - 50, self.rect.y - 50 / 2, b_m_x, b_m_y)
        _, angle = (pygame.mouse.get_pos() - self.pos).as_polar()
        b.rotate(_)

我制作子弹路径的方式是让子弹有一个像线一样的斜率。是 的变化b_m_x和的变化。b_m_yxy

我今年才刚刚开始学习代数(我 13 岁),去年我学会了如何绘制线性线,所以如果有更简单的方法来制作子弹路径,请告诉我。

这是我的子弹类代码

class Bullet(pygame.sprite.Sprite):
    def __init__(self, game, x, y, run, rise):
        pygame.sprite.Sprite.__init__(self, game.all_sprites)
        self.image = pygame.Surface((15, 50))
        self.image.fill((255, 0, 0))

        self.rect = self.image.get_rect()
        self.rect.x, self.rect.y = x, y
        self.pos = pygame.math.Vector2(self.rect.x, self.rect.y)
        self.speed = pygame.math.Vector2(x=run / settings.bullet_speed_offset, y=rise / settings.bullet_speed_offset)

    def update(self):
        self.pos += self.speed
        self.rect.x, self.rect.y = self.pos.x, self.pos.y

    def rotate(self, angle):
        self.image = pygame.transform.rotozoom(self.image, angle, 1)
        self.rect = self.image.get_rect()

我的问题是我的鼠标离Player精灵越远,子弹移动的越快(因为当我找到直线的斜率时,鼠标和玩家之间的差异越大,子弹的速度就会越快是)。如何制作更好的发射子弹系统?

标签: pythonmathpygamebulletphysicsbullet

解决方案


如果您希望速度不取决于鼠标距离,则应标准化与鼠标的距离。

换句话说,无论鼠标在哪里,都使用同一方向上的点的坐标,但与起始位置有固定距离,例如,当您计算b_m_xand时b_m_y,请执行以下操作:

b_m_x, b_m_y = m_x - self.pos.x, m_y - self.pos.y

distance = (b_m_x ** 2 + b_m_y ** 2) ** .5

if distance != 0:
    # if distance is 0, nothing can be done

    NORMALIZED_DISTANCE = 100
    mutiplier = NORMALIZED_DISTANCE / distance

    b_m_x *= multipler
    b_m_y *= multipler

推荐阅读