Skip to content

Commit

Permalink
[SOK-27] fix: +hasCollision ограничение количества проверок коллизий
Browse files Browse the repository at this point in the history
  • Loading branch information
shamemask committed Oct 1, 2024
1 parent 6b32d3a commit 4b02ce2
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 17 deletions.
8 changes: 6 additions & 2 deletions packages/client/src/components/Game/collision.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,18 @@
import { Enemy, Obstacle, Player } from '@/components/Game/gameTypes'

export const hasCollision = (player: Player, obstacle: Obstacle): boolean => {
export const detectCollision = (
player: Player,
obstacle: Obstacle
): boolean => {
return (
player.x < obstacle.x + obstacle.width &&
player.x + player.width > obstacle.x &&
player.y < obstacle.y + obstacle.height &&
player.y + player.height > obstacle.y
)
}
export const hasEnemyCollision = (

export const detectEnemyCollision = (
rect1: Player | Enemy,
rect2: Obstacle | Enemy
): boolean => {
Expand Down
26 changes: 13 additions & 13 deletions packages/client/src/components/Game/controls.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { ControlsProps, KeyMap } from '@/components/Game/gameTypes'

import { hasCollision } from '@/components/Game/collision'
import { detectCollision } from '@/components/Game/collision'

const keyMap: KeyMap = {}

Expand Down Expand Up @@ -37,20 +37,20 @@ export const updatePlayerMovement = (props: ControlsProps) => {
}

// Обработка столкновений с препятствиями
props.obstacles.forEach(obstacle => {
if (hasCollision({ ...prevPlayer, x: newX, y: newY }, obstacle)) {
newX = prevPlayer.x
newY = prevPlayer.y
} else {
// Ограничение движения по краям canvas
newX = Math.max(0, Math.min(newX, props.canvasWidth - prevPlayer.width))
newY = Math.max(
0,
Math.min(newY, props.canvasHeight - prevPlayer.height)
)
}
const hasCollision = props.obstacles.find(obstacle => {
return detectCollision({ ...prevPlayer, x: newX, y: newY }, obstacle)
})

// Если есть столкновение, то вернуть предыдущую позицию
if (hasCollision) {
newX = prevPlayer.x
newY = prevPlayer.y
} else {
// Ограничение движения по краям canvas
newX = Math.max(0, Math.min(newX, props.canvasWidth - prevPlayer.width))
newY = Math.max(0, Math.min(newY, props.canvasHeight - prevPlayer.height))
}

return { ...prevPlayer, x: newX, y: newY }
})
}
4 changes: 2 additions & 2 deletions packages/client/src/components/Game/gameLoop.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { handlePlayerHit, resetPlayerPosition } from './player'
import { updateEnemyPositions, respawnEnemies } from './enemy'
import { clearCanvas, drawPlayer, drawEnemies, drawObstacles } from './utils'
import { Enemy, Obstacle, Player } from '@/components/Game/gameTypes'
import { hasEnemyCollision } from '@/components/Game/collision'
import { detectEnemyCollision } from '@/components/Game/collision'

/**
* Основной игровой цикл, который обновляет состояние игры и перерисовывает экран каждый кадр.
Expand Down Expand Up @@ -42,7 +42,7 @@ export const gameLoop = (

// Проверка на столкновения между игроком и врагами
enemies.forEach(enemy => {
if (hasEnemyCollision(player, enemy)) {
if (detectEnemyCollision(player, enemy)) {
// Обработка столкновения: уменьшаем жизни
handlePlayerHit(
setPlayer,
Expand Down

0 comments on commit 4b02ce2

Please sign in to comment.