Removed TODOs and moved some logic in algo to it's own method
This commit is contained in:
parent
f3652005af
commit
e850391056
@ -23,7 +23,6 @@ export const App: FC = () => (
|
||||
* @param secured Whether or not the page is secured.
|
||||
* @constructor The Secured component.
|
||||
*/
|
||||
// TODO only works on first render after refresh
|
||||
const Secured: FC<{ secured: boolean } & ChildProps> = ({children, secured}) => {
|
||||
const player = useAtomValue(thisPlayerAtom);
|
||||
const navigate = useNavigate();
|
||||
|
@ -25,7 +25,7 @@ const Board: FC<BoardProps> = (
|
||||
const characters = useAtomValue(allCharactersAtom);
|
||||
const selectedDice = useAtomValue(selectedDiceAtom);
|
||||
const [selectedCharacter, setSelectedCharacter] = useState<Character>();
|
||||
const [possiblePositions, setPossiblePositions] = useState<Path[]>([]); // TODO reset when other client moves a character
|
||||
const [possiblePositions, setPossiblePositions] = useState<Path[]>([]);
|
||||
const [hoveredPosition, setHoveredPosition] = useState<Path>();
|
||||
const setModalOpen = useSetAtom(modalOpenAtom);
|
||||
|
||||
|
@ -83,7 +83,7 @@ export class Ghost extends Character implements CharacterProps {
|
||||
|
||||
export class Dummy extends Character implements CharacterProps {
|
||||
|
||||
public constructor(position: Path) { // TODO see-through
|
||||
public constructor(position: Path) {
|
||||
super({
|
||||
colour: Colour.grey,
|
||||
position: position,
|
||||
|
@ -2,8 +2,6 @@ import {TileType} from "./tileType";
|
||||
import {Character} from "./character";
|
||||
import {Direction, getDirections} from "./direction";
|
||||
|
||||
// TODO if a Pac-Man with a powerpellet hits a ghost, the Pac-Man can't walk further
|
||||
|
||||
/**
|
||||
* Finds all the possible positions for the character to move to
|
||||
* @param board The board the character is on
|
||||
@ -24,7 +22,7 @@ export default function findPossiblePositions(board: GameMap, character: Charact
|
||||
* @param steps The number of steps the character can move
|
||||
* @param character The current character
|
||||
* @param characters All the characters on the map
|
||||
* @returns An array of paths the character can move to
|
||||
* @returns {Path[]} An array of paths the character can move to
|
||||
*/
|
||||
function findPossibleRecursive(map: GameMap, currentPath: Path, steps: number, character: Character, characters: Character[]): Path[] {
|
||||
|
||||
@ -64,7 +62,7 @@ function findPossibleRecursive(map: GameMap, currentPath: Path, steps: number, c
|
||||
* Checks if the current character is on its spawn
|
||||
* @param currentPath The current path the character is on
|
||||
* @param character The current character
|
||||
* @returns True if the character is on its spawn, otherwise false
|
||||
* @returns {boolean} True if the character is on its spawn, otherwise false
|
||||
*/
|
||||
function isCharactersSpawn(currentPath: Path, character: Character): boolean {
|
||||
return character.spawnPosition?.at.x === currentPath.end.x && character.spawnPosition.at.y === currentPath.end.y;
|
||||
@ -75,7 +73,7 @@ function isCharactersSpawn(currentPath: Path, character: Character): boolean {
|
||||
* @param character The current character
|
||||
* @param currentPath The current path the character is on
|
||||
* @param characters All the characters on the board
|
||||
* @returns True if the character is a ghost and hits Pac-Man, otherwise false
|
||||
* @returns {boolean} True if the character is a ghost and hits Pac-Man, otherwise false
|
||||
*/
|
||||
function ghostHitsPacMan(character: Character, currentPath: Path, characters: Character[]): Character | undefined | false {
|
||||
return character.isGhost() && characters.find(c => c.isPacMan() && c.isAt(currentPath.end));
|
||||
@ -86,7 +84,7 @@ function ghostHitsPacMan(character: Character, currentPath: Path, characters: Ch
|
||||
* @param character The current character
|
||||
* @param currentPath The current path the character is on
|
||||
* @param characters All the characters on the board
|
||||
* @returns True if the character hits another character, otherwise false
|
||||
* @returns {boolean} True if the character hits another character, otherwise false
|
||||
*/
|
||||
function characterHitsAnotherCharacter(character: Character, currentPath: Path, characters: Character[]): boolean {
|
||||
return characters.find(c => c !== character && c.isAt(currentPath.end)) !== undefined;
|
||||
@ -143,7 +141,6 @@ function tryMove(board: GameMap, path: Path, direction: Direction, steps: number
|
||||
}
|
||||
|
||||
if (path.direction !== (direction + 2) % 4) {
|
||||
// TODO getNewPosition() and check if a character is on the new position
|
||||
return findPossibleRecursive(board, {
|
||||
end: getNewPosition(), direction: direction, path: path.path
|
||||
}, steps, character, characters);
|
||||
@ -158,13 +155,18 @@ function tryMove(board: GameMap, path: Path, direction: Direction, steps: number
|
||||
* @param steps The number of steps the character can move
|
||||
* @param character The current character
|
||||
* @param characters All the characters on the map
|
||||
* @returns {Path[]} An array of paths the character can move to
|
||||
*/
|
||||
function addTeleportationTiles(board: GameMap, currentPath: Path, steps: number, character: Character, characters: Character[]): Path[] {
|
||||
const possiblePositions = findTeleportationTiles(board);
|
||||
const paths: Path[] = [];
|
||||
for (const pos of possiblePositions) {
|
||||
if (pos.end.x !== interval(0, board.length - 1, currentPath.end.x) ||
|
||||
pos.end.y !== interval(0, board.length - 1, currentPath.end.y)) {
|
||||
|
||||
function inInterval(coordinate: "x" | "y"): boolean {
|
||||
return pos.end[coordinate] !== interval(0, board.length - 1, currentPath.end[coordinate])
|
||||
}
|
||||
|
||||
if (inInterval("x") || inInterval("y")) {
|
||||
|
||||
pos.path = currentPath.path;
|
||||
paths.push(...findPossibleRecursive(board, pos, steps, character, characters));
|
||||
@ -178,7 +180,7 @@ function addTeleportationTiles(board: GameMap, currentPath: Path, steps: number,
|
||||
* @param lower The lower bound
|
||||
* @param upper The upper bound
|
||||
* @param value The value to check
|
||||
* @returns The value if it's between the lower and upper bounds, otherwise it returns the lower or upper bound
|
||||
* @returns {number} The value if it's between the lower and upper bounds, otherwise it returns the lower or upper bound
|
||||
*/
|
||||
function interval(lower: number, upper: number, value: number): number {
|
||||
return Math.max(Math.min(value, upper), lower);
|
||||
|
@ -39,7 +39,7 @@ export const doAction: MessageEventFunction<string> = (event): void => {
|
||||
|
||||
switch (message.action as GameAction) {
|
||||
case GameAction.error:
|
||||
console.error("Error:", message.data); // TODO show error to user
|
||||
console.error("Error:", message.data);
|
||||
break;
|
||||
case GameAction.rollDice:
|
||||
setDice(message.data);
|
||||
|
Loading…
x
Reference in New Issue
Block a user