Entrar
Últimos assuntos
» Retorno da GMBR!!!por theguitarmester Ter 19 Mar 2024, 22:38
» Procuro Programador de game maker
por Wou Sex 15 Mar 2024, 10:27
» Mod APK
por gamerainha Qua 13 Mar 2024, 06:30
» Mudar cor de apenas uma palavra
por lunalol Sex 01 Mar 2024, 13:42
» Aceito pedidos de sprites (Com exemplos meus)
por Sevilha Qua 28 Fev 2024, 12:17
» Inventário simples
por Isquilo_Roedor Qui 22 Fev 2024, 15:18
» Problemas na programaçnao de inimigo [jogo DOOM LIKE]
por Black Mirror Dom 11 Fev 2024, 13:34
» ANDROID MULTI TOUCH
por DiegoBr Dom 04 Fev 2024, 12:13
» Servidor de Discord do fórum?
por Lighter Sáb 27 Jan 2024, 17:18
» Save e Load Json
por Klinton Rodrigues Qui 25 Jan 2024, 11:12
» Colisão com mais de um objeto
por aminaro Seg 22 Jan 2024, 15:02
» Oi sou novo aqui
por Thiago Silveira Alexandre Sáb 20 Jan 2024, 20:55
» Como acessar conteudo comprado no marketplace
por macmilam Sex 19 Jan 2024, 07:42
» Devlogs em vídeos do Block Room
por Joton Seg 15 Jan 2024, 16:56
» Alguém aqui já ganha dinheiro com seus games?
por Joton Seg 15 Jan 2024, 16:49
» ACERVO GMBR MAGAZINE
por Joton Qui 11 Jan 2024, 19:21
» como aumentar o obj sem aumentar a colisão??
por GabrielXavier Qua 10 Jan 2024, 07:21
» Asteroid Core - Early Acesse Update [0.2.0.0]
por JOZ. Seg 08 Jan 2024, 14:39
» Versionamento de código com GitHub
por GabrielXavier Seg 08 Jan 2024, 07:32
» Rio Rise - novo launcher do Gta San Andreas SAMP Brasil
por kolesovsup Sex 29 Dez 2023, 07:16
» a funçao approach ainda existe?
por PEDRINDEV Ter 26 Dez 2023, 20:05
» Inimigo ataca até por trás! >:(
por saim Sex 22 Dez 2023, 08:55
» [RESOLVIDO]Spawn após morte
por Deception_1999 Dom 17 Dez 2023, 16:39
» Remunerado $$$ - Procuro programador para ajudar a "montar" um jogo
por theguitarmester Sáb 02 Dez 2023, 16:28
» Game maker nao abre
por Cerf Dom 26 Nov 2023, 12:01
[Desafio #001] Crystal Breakers
Página 1 de 1
[Desafio #001] Crystal Breakers
Crystal Breakers
Info:
- Inicio: 01/02/2012
- Ultima release: 02/02/2012
- Plataforma: Game Maker 8.0
- Crétidos: Programação e gráficos totalmente desenvolvidos por mim
Controles:
- Setas do teclado -> move as peças
- Espaça -> mudar sequencia das peças
- Enter -> Menu/Aceitar
- I -> Ativar/Desativar Debug (Mostra o processamento da AI)
- P -> Acelerar
- R -> Reinicia o jogo de estiver no Modo Debug
Download:
- Executável: kabecao_crystal_breakers.gmk - 230 KB
- Source GM 8.0: kabecao_crystal_breakers.zip - 1 MB
Notas do projeto:
Com um nome e gráficos totalmente aleatórios e uma programação corrida devido ao prazo terminei minha entrada para o [Desafio #001] Inteligência Artificial.
Crystal Breakers é um jogo tipo o famoso Columns produzido pela SEGA, jogo este que gostei bastante quanto tinha um Mega Drive.
Já que o tema é inteligência artificial, acho que a melhor forma de demonstra-la é tendo a CPU diretamente como seu adversário então pensei: "um jogo como o Columns seria perfeito para isso!"
Sobre a AI e desenvolvimento:
Como a premissa de um concurso de desafio aqui é desenvolver rápido aprendendo com temas e limitações impostos, acho que é essencial ao menos tentar fazer uma explicação do que foi feito no projeto.
Não sou bom explicando essas coisas mas há quem se interessar leia a seguir:
A AI que desenvolvi para o desafio consiste basicamente na análise das peças de um jogo tipo "Columns".
Usando uma combinação de diversos loops "for" consegui fazer a CPU achar a melhor posição para se colocar uma peça. Você pode observar o resultado do processo entrando no "Modo Debug" dentro do jogo.
As peças não são objetos do GM, é tudo controlado usando ds_grid, que na minha opinião é a melhor forma para se trabalhar com jogos de tabuleiro, sendo assim, as peças são apenas desenhadas de acordo com suas posições na grid.
O método para checar qual peças excluir quando a sequências foi bastante simples:
- Código:
Grade de cheque
------------------------
| -1,-1 | 0,-1 | +1,-1 |
------------------------
| -1,0 | 0,0 | +1,0 |
------------------------
| -1,+1 | 0,+1 | +1,+1 |
------------------------
- Código:
if ( ponto(px-1,py) = ponto(px,py) && ponto(px+1,py) = ponto(px,py) ) // Horizontal
------------------------
| -1,0 | 0,0 | +1,0 |
------------------------
// etc...
if ( ponto(px,py-1) = ponto(px,py) && ponto(px,py+1) = ponto(px,py) ) // Vertical
--------
| 0,-1 |
--------
| 0,0 |
--------
| 0,+1 |
--------
// etc..
if ( ponto(px-1,py-1) = ponto(px,py) && ponto(px+1,py+1) = ponto(px,py) ) // Diagonal
------------------------
| -1,-1 |
------------------------
| 0,0 |
------------------------
| +1,+1 |
------------------------
// etc...
Felizmente a programação correu muito bem e rápida, consegui terminar o necessário em um dias e meio e os gráficos foram feitos no resto do tempo até 1 antes do prazo.
Infelizmente não deu tempo de pensar em modificações para nível de dificuldade, então fazer mais pontos que a CPU pode ser bem difícil.
Screens da fase de teste do meu método:
- Spoiler:
- O quadrado roxo mostra as combinações no momento, o amarelo a melhor posição para a peça com a seleção azul-claro.
Página 1 de 1
Permissões neste sub-fórum
Não podes responder a tópicos
|
|