Entrar
Últimos assuntos
» player não consegue andarpor lovn7 Qui 21 Nov 2024, 13:33
» É possível fazer istó no game maker
por William Lima Qui 21 Nov 2024, 10:56
» Rio Rise - novo launcher do Gta San Andreas SAMP Brasil
por Lua Sáb 16 Nov 2024, 20:22
» (Resolvido) Cenario longo x Texture Pages
por josuedemoraes Sáb 16 Nov 2024, 15:31
» Kids' band
por Adilson Lucindo Santos Sex 15 Nov 2024, 12:23
» (RESOLVIDO) Engasgos-Troca de Sprites/animações
por josuedemoraes Ter 12 Nov 2024, 01:49
» Block Room - DEMO
por Joton Qua 06 Nov 2024, 22:58
» Game Infinito vertical (subindo)
por macmilam Sáb 26 Out 2024, 12:36
» Retorno da GMBR!!!
por Dancity Ter 22 Out 2024, 16:36
» Máquina de estados
por aminaro Qui 10 Out 2024, 13:33
» como faço pra um objeto colidir com o outro e diminuir a vida do player ?
por josuedemoraes Qui 03 Out 2024, 16:51
» RESOLVIDO: Colisão com objetos moveis
por josuedemoraes Qua 02 Out 2024, 20:28
» Crypt of the Blood Moon
por divin sphere Qua 11 Set 2024, 18:18
» como fazer um objeto seguir?
por divin sphere Dom 18 Ago 2024, 18:08
» Procuro de alguém para Modelar/Texturizar/Animar objetos 3D
por un00brn Dom 11 Ago 2024, 11:10
» Destruição de cenário (estilo DD Tank)
por CoronelZeg Sex 09 Ago 2024, 17:16
» RESOLVIDO-Como destruir uma instancia especifica de um objeto
por josuedemoraes Ter 23 Jul 2024, 00:40
» Automatizar a coleta de id
por GabrielXavier Seg 22 Jul 2024, 18:01
» Preciso de ajuda para concluir um pequeno projeto
por lmoura Qui 27 Jun 2024, 15:45
» ANGULO ACOMPANHAR O OBJETO
por Klinton Rodrigues Qui 27 Jun 2024, 08:34
» Musica reinicia quando sala reinicia
por GabrielXavier Ter 18 Jun 2024, 07:28
» como fazer uma copia de gd
por generico_cube Sex 14 Jun 2024, 15:48
» Square Adventure
por guilherme551 Ter 11 Jun 2024, 09:54
» como posso definir limite de uma variavel
por GabrielXavier Sex 07 Jun 2024, 14:14
» [Resolvido] Dúvida, colisão única de objeto
por vdm842 Sex 24 maio 2024, 09:50
Pular automaticamente
5 participantes
Página 1 de 1
Pular automaticamente
Eai.
Eu estou fazendo um de plataforma para android, o player vai andar com os toques na tela (mouse) e ele precisa pular automáticamente em cima de um bloco caso apareça no caminho dele. Eu usei um script mas há algo errado nele, que ainda não entendi oque é.
O problema é que na parte (if place_meeting(x+32,y,obj_block)... se ficar x+32 o jogador vai pular bem adiantado, quando ainda esta longe do bloco, e não vai dar certo. Eu ja tentei diminuir mas abaixo de 32 ele simplesmente não detecta que há um bloco na frente.
Isto é oque era para acontecer
O player tem um sprite 32x32 , mas o desenho é 14 de largura e 22 de altura
O bloco é um quadrado de 32x32.
Obrigado a todos , se alguem souber fazer isso de outra maneira ou concertar meu script me diga pfv.
Eu estou fazendo um de plataforma para android, o player vai andar com os toques na tela (mouse) e ele precisa pular automáticamente em cima de um bloco caso apareça no caminho dele. Eu usei um script mas há algo errado nele, que ainda não entendi oque é.
- Código:
if !place_meeting(x,y+1,obj_block)
{
grav = .5; //gravidade
vspd += grav; //velocidade vertical
}
else
{
grav = 0;
vspd = 0;
if place_meeting(x-32,y,obj_block) && !place_meeting(x-32,y-32,obj_block) && !place_meeting(x,y-32,obj_block)
{
if way="left" && move=true
{
vspd=-5
hspd=-5
}
}
if place_meeting(x+32,y,obj_block) && !place_meeting(x+32,y-32,obj_block) && !place_meeting(x,y-32,obj_block)
{
if way="right" && move=true
{
vspd=-5
hspd=+5
}
}
}
O problema é que na parte (if place_meeting(x+32,y,obj_block)... se ficar x+32 o jogador vai pular bem adiantado, quando ainda esta longe do bloco, e não vai dar certo. Eu ja tentei diminuir mas abaixo de 32 ele simplesmente não detecta que há um bloco na frente.
Isto é oque era para acontecer
- Spoiler:
O player tem um sprite 32x32 , mas o desenho é 14 de largura e 22 de altura
O bloco é um quadrado de 32x32.
Obrigado a todos , se alguem souber fazer isso de outra maneira ou concertar meu script me diga pfv.
Re: Pular automaticamente
tenta 32-(velocidade que o player se move)
desculpa a desatenção, vou deixar o codigo a cima mais ele NÃO É O CORRETO!
tente isso:
place_meeting(x-sprite_xoffset+sprite_width+1,y,(nome do objeto))//checa pra direita
place_meeting(x-sprite_xoffset-sprite_width+1,y,(nome do objeto))//checa pra esquerda
Ps: não tenho certeza que funciona no GMS
desculpa a desatenção, vou deixar o codigo a cima mais ele NÃO É O CORRETO!
tente isso:
place_meeting(x-sprite_xoffset+sprite_width+1,y,(nome do objeto))//checa pra direita
place_meeting(x-sprite_xoffset-sprite_width+1,y,(nome do objeto))//checa pra esquerda
Ps: não tenho certeza que funciona no GMS
Re: Pular automaticamente
Isaque Onix, seria mais fácil usar bbox_left e bbox_right. Mas não é necessário com place_meeting - que te retorna "se haveria colisão caso o objeto fosse colocado na posição (x, y)". O código, como está, DEVERIA funcionar (embora eu também escreveria ele de forma diferente).
Esaucm98, quando você diz "O player tem um sprite 32x32 , mas o desenho é 14 de largura e 22 de altura" você quer dizer que a mask é de 32x32? Você pode estar com problemas de origem de sprite. Só pra teste, tente rodar o jogo com a mask igual à sprite. Se der tudo certo, o problema está em alguma incompatibilidade entre os dois.
Esaucm98, quando você diz "O player tem um sprite 32x32 , mas o desenho é 14 de largura e 22 de altura" você quer dizer que a mask é de 32x32? Você pode estar com problemas de origem de sprite. Só pra teste, tente rodar o jogo com a mask igual à sprite. Se der tudo certo, o problema está em alguma incompatibilidade entre os dois.
saim- Games Ranking :
Notas recebidas : C-D-A-B
Data de inscrição : 14/01/2011
Reputação : 136
Número de Mensagens : 3033
Prêmios :
x 1 x 6 x 0
x 1 x 0 x 3
x 0 x 0 x 0
Re: Pular automaticamente
A mask do player ta igual ao sprite mas o problema ainda continua kk vou tentar fazer oque o Isaac falou. valeu.
Re: Pular automaticamente
saim escreveu:Isaque Onix, seria mais fácil usar bbox_left e bbox_right. Mas não é necessário com place_meeting - que te retorna "se haveria colisão caso o objeto fosse colocado na posição (x, y)". O código, como está, DEVERIA funcionar (embora eu também escreveria ele de forma diferente).
como utiliza esses bbox_left/right? nunca tinha visto eles antes..
Ps, reparei um erro no meu codigo!
Certo:
place_meeting(x-sprite_xoffset+sprite_width+1,y,(nome do objeto))//checa pra direita
place_meeting(x-sprite_xoffset-1,y,(nome do objeto))//checa pra esquerda
errado:
place_meeting(x-sprite_xoffset-sprite_width+1,y,(nome do objeto))//checa pra esquerda
eu coloquei -sprite_width+1 e deveria ser apenas -1, isso checaria muito mais para a esquerda do que para a direita
Re: Pular automaticamente
Uma maneira fácil de resolver seria centralizar o X deste sprite, assim o calculo fica correto de ambos os lados.
Flws!
Flws!
Re: Pular automaticamente
não intendi muito bem, mais o calculo que mandei usado no place_meeting, retorna um ponto exato depois e antes do objeto, independente da marca xoffset e yoffset do sprite
Re: Pular automaticamente
@Isaque Onix: bbox_left/right/top/bottom são variáveis nativas dos objetos que levam em conta a sprite_index mask_index, o image_angle, a image_x/yscale e... acho que é só isso. Representam os extremos da imagem. Se você mandar desenhar um retângulo de bbox_left/top a bbox_right/bottom, esse retângulo sempre vai conter a sprite toda.
"place_meeting" nunca vai te retornar um PONTO, mas true ou false. Como disse, ela te retorna se o objeto, com a mask que está, colidiria com alguma coisa se fosse colocado no ponto tal.
O que você fez com xoffset e yoffset estaria correto se você estivesse verificando por um ponto, mas o que place_meeting verifica é uma região - e, na prática, já leva em conta a origem.
Pra verificar por um ponto isolado, recomendo usar instance_position.
@Esaucm98: assim que possível, dou uma olhada mais a fundo no problema
"place_meeting" nunca vai te retornar um PONTO, mas true ou false. Como disse, ela te retorna se o objeto, com a mask que está, colidiria com alguma coisa se fosse colocado no ponto tal.
O que você fez com xoffset e yoffset estaria correto se você estivesse verificando por um ponto, mas o que place_meeting verifica é uma região - e, na prática, já leva em conta a origem.
Pra verificar por um ponto isolado, recomendo usar instance_position.
@Esaucm98: assim que possível, dou uma olhada mais a fundo no problema
saim- Games Ranking :
Notas recebidas : C-D-A-B
Data de inscrição : 14/01/2011
Reputação : 136
Número de Mensagens : 3033
Prêmios :
x 1 x 6 x 0
x 1 x 0 x 3
x 0 x 0 x 0
Re: Pular automaticamente
Eu concordo com o que o saim disse; além disso, acho que place_meeting não é a função certa. Já que você quer detectar se o bloco está à frente do player, recomendo usar o !place_free. O place_meeting é mais para detectar a possível posição do jogador.
Tenta dar uma alterada no código e depois vê no que vai dar.
Tenta dar uma alterada no código e depois vê no que vai dar.
Mr. Kaleb- Games Ranking :
Notas recebidas : C
Data de inscrição : 07/09/2010
Reputação : 21
Número de Mensagens : 1400
Prêmios :
x 0 x 0 x 0
x 0 x 0 x 0
x 0 x 0 x 0
Re: Pular automaticamente
sain intendi, valeu por explicar! esses bbox vão facilitar minha vida hehe
The Games Never Finish... : bom na verdade da na mesma, pode ser que ele não queira mandar o player pra cima de todos os objetos solidos pela frente (uma hora o jogo acaba hehe)
The Games Never Finish... : bom na verdade da na mesma, pode ser que ele não queira mandar o player pra cima de todos os objetos solidos pela frente (uma hora o jogo acaba hehe)
Re: Pular automaticamente
@Esaucm98: Fiz aqui, cara, deu certo... acho que o erro está em alguma outra parte do código.
No spoiler, a informação completa do objeto, da forma que eu completei. Fiz assim só pra rodar, então tem muita coisa que ficou redundante, muita variável servindo pra mesma coisa, mas você provavelmente vai ter sua utilidade pra elas.
Usei sprites quadradas de 32x32, origem no topo à esquerda. Os pulos não foram suficientes pra subir, então coloquei degraus de 16 pixels na fase.
Ah, coloquei mais um código no step, depois do seu, pro objeto se mover de fato. Mais uma vez, código apenas pra teste, então está meio tosco.
O que aconteceu muitas vezes foi da fase ter condições que impedissem o pulo, mas tudo dentro do previsto. Será que não é o que está acontecendo contigo?
No spoiler, a informação completa do objeto, da forma que eu completei. Fiz assim só pra rodar, então tem muita coisa que ficou redundante, muita variável servindo pra mesma coisa, mas você provavelmente vai ter sua utilidade pra elas.
Usei sprites quadradas de 32x32, origem no topo à esquerda. Os pulos não foram suficientes pra subir, então coloquei degraus de 16 pixels na fase.
Ah, coloquei mais um código no step, depois do seu, pro objeto se mover de fato. Mais uma vez, código apenas pra teste, então está meio tosco.
- Spoiler:
- Information about object: object1
Sprite: sprite0
Solid: false
Visible: true
Depth: 0
Persistent: false
Parent:
Mask:
Create Event:
execute code:
grav := 0;
vspd := 0;
hspd := 0;
way := "";
move := false;
Step Event:
execute code:
if !place_meeting(x,y+1,obj_block)
{
grav = .5; //gravidade
vspd += grav; //velocidade vertical
}
else
{
grav = 0;
vspd = 0;
if place_meeting(x-32,y,obj_block) && !place_meeting(x-32,y-32,obj_block) && !place_meeting(x,y-32,obj_block)
{
if way="left" && move=true
{
vspd=-5
hspd=-5
}
}
if place_meeting(x+32,y,obj_block) && !place_meeting(x+32,y-32,obj_block) && !place_meeting(x,y-32,obj_block)
{
if way="right" && move=true
{
vspd=-5
hspd=+5
}
}
}
execute code:
if (!place_meeting(x + hspd, y, obj_block)){
x += hspd;
}
else {
while(!place_meeting(x + sign(hspd), y, obj_block)){
x += sign(hspd)
}
}
y += vspd;
while(place_meeting(x, y, obj_block)){
y -= 1;
}
Keyboard Event forKey:
execute code:
way := "left";
move := true;
hspd := -5;
Keyboard Event forKey:
execute code:
way := "right";
move := true;
hspd := 5;
Key Release Event forKey:
execute code:
way := "";
move := false;
hspd := 0;
Key Release Event forKey:
execute code:
way := "";
move := false;
hspd := 0;
O que aconteceu muitas vezes foi da fase ter condições que impedissem o pulo, mas tudo dentro do previsto. Será que não é o que está acontecendo contigo?
saim- Games Ranking :
Notas recebidas : C-D-A-B
Data de inscrição : 14/01/2011
Reputação : 136
Número de Mensagens : 3033
Prêmios :
x 1 x 6 x 0
x 1 x 0 x 3
x 0 x 0 x 0
Re: Pular automaticamente
Eu ja tinha centralizado as sprites e mesmo assim ainda não estava dando certo.
Saim eu fiz algumas alterações no sprite e na mask e usei esse codigo e deu certo mesmo, essas variáveis redundantes eu tive que usar porque eu vou precisar delas em outras coisas do jogo. Ainda não sei onde esta o erro no que eu tinha feito, mas como agora ja deu certo vou continuar com meu jogo , muito obrigado pela ajuda a todos.
Eu nem conhecia essa função bbox_left/right dei uma checada e vou ver como ela funciona depois.
Saim eu fiz algumas alterações no sprite e na mask e usei esse codigo e deu certo mesmo, essas variáveis redundantes eu tive que usar porque eu vou precisar delas em outras coisas do jogo. Ainda não sei onde esta o erro no que eu tinha feito, mas como agora ja deu certo vou continuar com meu jogo , muito obrigado pela ajuda a todos.
Eu nem conhecia essa função bbox_left/right dei uma checada e vou ver como ela funciona depois.
Re: Pular automaticamente
É, deve ter sido alguma coisa relacionada às colisões. Você viu que eu usei um "while" pra colisão ficar perfeita, mas fiz de um jeito meio tosco lá, só pra testar mesmo. Mas o importante é saber que se a colisão não for perfeita, algumas vezes pode parecer que as condições estão adequadas pro pulo e elas não estarem. Você olha pra tela, diz "mas não tem NADA acima nem acima-pra-frente do objeto, porque ele não pula?", mas se jogar no debug, vai ver que tem sim. Não parece, mas tem.
Os bboxes são úteis sim, mas não no seu caso. Pra verificar se o caminho está livre pra movimentação, acho melhor usar o place_meeting mesmo.
Eu não cortei as redundâncias porque tinha certeza que elas seriam uteis em outra parte - provavelmente uma movimentação menos tosca que a minha. Só comentei porque, do jeito que eu fiz, elas realmente ficaram inúteis. Claro que eu imaginei que no seu jogo, com mais refino, mais possibilidades, elas teriam utilidade.
Os bboxes são úteis sim, mas não no seu caso. Pra verificar se o caminho está livre pra movimentação, acho melhor usar o place_meeting mesmo.
Eu não cortei as redundâncias porque tinha certeza que elas seriam uteis em outra parte - provavelmente uma movimentação menos tosca que a minha. Só comentei porque, do jeito que eu fiz, elas realmente ficaram inúteis. Claro que eu imaginei que no seu jogo, com mais refino, mais possibilidades, elas teriam utilidade.
saim- Games Ranking :
Notas recebidas : C-D-A-B
Data de inscrição : 14/01/2011
Reputação : 136
Número de Mensagens : 3033
Prêmios :
x 1 x 6 x 0
x 1 x 0 x 3
x 0 x 0 x 0
Tópicos semelhantes
» Salvar e carregar automaticamente
» Ignorar erro automaticamente
» [Duvida]Objetos sobrepostos automaticamente
» Objeto Girar e parar automaticamente
» Como superfisionar tópicos automaticamente?
» Ignorar erro automaticamente
» [Duvida]Objetos sobrepostos automaticamente
» Objeto Girar e parar automaticamente
» Como superfisionar tópicos automaticamente?
Página 1 de 1
Permissões neste sub-fórum
Não podes responder a tópicos