05 - Entrega: Lig-4 (em equipe)
No Lig-4, um jogador assume a cor Vermelha e o outro assume a cor Preta. Os jogadores se alternam inserindo suas peças em uma das 7 colunas de uma tabela 7x6. O primeiro jogador que conseguir quatro de suas peças em uma linha (seja horizontal, vertical ou diagonal) vence.
No mundo físico, a tabela é colocada perpendicular à mesa, de forma que as peças caiam para a parte de baixo e se empilhem umas em cima das outras. Sua versão digital do jogo deve manter esta característica (a animação de queda é opcional).
O jogo pode terminar em empate quando todas as células estiverem preenchidas e nenhum jogador conseguir quatro peças em linha.
Implemente o Lig-4 usando HTML, CSS e JavaScript. Em cada partida, os jogadores estarão usando o mesmo teclado & mouse, alternando seus turnos.
Vocês trabalharão em grupos para completar sua implementação do Lig-4. Vocês devem codificar individualmente, mas podem trabalhar juntos para construir o layout e a funcionalidade do jogo.
Como membro de um grupo, você terá que atingir uma certa expectativa de desempenho. Seu desempenho será avaliado pelos outros membros do grupo, então tente contribuir igualmente com o projeto! Você pode ler mais aqui: Guidelines for Individuals on a Team (em inglês)
O líder do projeto fará o envio do mesmo. Este será um projeto que você colocará em seu portfólio, então faça-o bonito e use a função do GitLab Pages para hospedar o jogo concluído para que qualquer um possa jogar.
Se você não estiver se sentindo seguro de como começar, aqui vão algumas etapas para você ir incrementando:
- Exiba um disco preto ou vermelho.
- Empilhe discos vermelhos e pretos em uma coluna usando um layout de caixa flex.
- Exiba um tabuleiro completo consistindo de 7 colunas.
- Configure uma função de handler de clique para cada coluna que adiciona um disco.
- Reveze os turnos! Mude a cor do próximo disco após um disco ser adicionado.
- Registre a cor dos discos em cada posição do tabuleiro. Você deve ser capaz de fazer o debug via console.log() depois de cada movimento mostrando o estado do tabuleiro.
- Após encher uma coluna (6 discos), não permita que mais discos sejam adicionados.
- Verifique se o último disco adicionado completou uma linha de quatro peças na coluna (verticalmente).
- Verifique se o último disco adicionado completou uma linha de quatro peças horizontalmente.
- Verifique se o último disco adicionado completou uma linha de quatro peças em uma diagonal descendente ou ascendente.
Aqui está uma captura de tela de uma implementação concluída, mas sem a estilização chique.
Faça o push e implemente seu código no Gitlab. Adicione grupo ka-br--correcoes como membro do seu projeto com a permissão "Reporter", e envie a url do seu gitlab pages (Ex: https://nomedeusuario.gitlab.io/lig-4). Adicione um comentário ao seu envio informando o nome dos seus colegas.
Iniciar sempre com:
- feat:___
- fix:__
git pull origin develop
Criar branch específica.
git push origin develop