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
Sprites - Funções e Variáveis
3 participantes
GMBR :: Ensine & Aprenda :: Tutoriais :: Game Maker
Página 1 de 1
Sprites - Funções e Variáveis
Nome: Sprites - Funções e Variáveis
Descrição: Usando funções e variáveis relacionados a sprites
Nível: Intermediário
Requerimentos: Lite/Pro
Olá a todos!
Neste tutorial serão explicadas algumas funções relacionadas a Sprites e Sub-imagens.
Vamos Começar!
Algumas funções podem ser usadas para criar, copiar ou remover sprites. Na maioria das vezes devem estar seguidas de uma variável. As que precisarem estão marcadas com um *.
sprite_duplicate(ind) *
Duplica a sprite ind para a sprite criada pela variável. Se a sprite não existir, a função retornará -1.
sprite_assign(ind,source)
Copia a sprite definida em source e cola na sprite ind, a substituindo.
sprite_merge(ind1,ind2)
Adiciona as sub-imagens de ind2 para ind1, sem substituir as já existentes.
sprite_add(fname,imgnumb,removeback,smooth,xorig,yorig)*
Adiciona uma sprite a partir de um arquivo de imagem externo. O nome do arquivo deve estar entre aspas e com a extensão no final. Em imgnumb você coloca a sub-imagem que deverá ser carregada. removeback define se a cor de fundo deverá ser removida. Smooth arredonda as bordas do desenho, e xorig e yorig definem o ponto de origem da sprite.
sprite_replace(ind,fname,imgnumb,removeback,smooth,xorig,yorig)
Substitui a sprite ind pela imagem fname. Os outros parâmetros são os mesmos que o da função anterior.
sprite_add_sprite(fname) *
Esta função permite adicionar somente arquivos de sprite do Game Maker (.gmspr)
sprite_replace_sprite(ind,fname)
Substitui a sprite ind pela imagem fname, que deve ser .gmspr.
sprite_create_from_screen(x,y,w,h,removeback,smooth,xorig,yorig) *
Cria a sprite copiando o retângulo (x,y,w,h) da tela.
sprite_add_from_screen(ind,x,y,w,h,removeback,smooth)
Adiciona uma sub-imagem a sprite ind copiando o retângulo (x,y,w,h) da tela.
sprite_create_from_surface(id,x,y,w,h,removeback,smooth,xorig,yorig) *
Cria uma sprite copiando o retângulo (x,y,w,h) da surface id.
sprite_add_from_surface(ind,id,x,y,w,h,removeback,smooth)
Adiciona uma sub-imagem a sprite ind copiando o retângulo (x,y,w,h) da surface id.
sprite_delete(ind)
Deleta a sprite ind
sprite_set_alpha_from_sprite(ind,spr)
Esta função faz com que o alpha de cada pixel da sprite ind tenha a mesma intensidade dos respectivos pixels da sprite spr.
sprite_set_offset(ind,xoff,yoff)
Define o ponto de origem da sprite ind
sprite_collision_mask(ind,sepmasks,bboxmode,bbleft,bbright,bbtop,bbbottom,kind,tolerance)
Define a collision mask da sprite ind. sepmasks indica se deve haver um mask para cada sub-imagem. bboxmode define qual o modo da bounding box (0=automatic, 1=full image e 2=user defined). bbleft, bbright, bbtop, bbbottom indicam as posições da bounding box (somente se bboxmode for 2). kind define o tipo da mask (0=precise, 1=rectangle, 2=disk e 3=diamond). tolerance define a tolerância em relação ao alpha da sprite (0-255).
sprite_exists(ind)
Retorna se a sprite ind existe.
sprite_get_name(ind)
Retorna o nome da sprite ind.
sprite_get_number
Retorna o número de sub-imagens da sprite ind
sprite_get_width(ind)
Retorna a largura da sprite ind
sprite_get_height(ind)
Retorna a altura da sprite ind
sprite_get_xoffset
Retorna o x-offset da sprite ind.
sprite_get_bbox_left(ind)
Retorna o valor do lado esquerdo da bounding box da sprite ind.
sprite_get_bbox_right(ind)
Retorna o valor do lado direito da bounding box da sprite ind.
sprite_get_bbox_top(ind)
Retorna o valor do lado de cima da bounding box da sprite ind.
sprite_get_bbox_down(ind)
Retorna o valor do lado de baixo da bounding box da sprite ind
sprite_save(ind,subimg,fname) - PRO
Salva a sub-imagem subimg da sprite ind no arquivo fname. O arquivo será salvo no formato png.
sprite_save_strip(ind,fname) - PRO
Salva a sprite ind no arquivo fname.
sprite_index - Indica a sprite do objeto.
sprite_width - Indica a largura da sprite.
sprite_height - Indica a altura da sprite.
sprite_xoffset - Indica o x-offset da sprite.
sprite_yoffset - Indica o y-offset da sprite.
image_number - Indica o número de sub-imagens da sprite.
image_index - Indica a sub-imagem atual na animação.
image_speed - Indica a velocidade da animação.
image_xscale - Indica a escala horizontal da sprite.
image_yscale - Indica a escala vertical da sprite.
image_angle - Indica o ângulo da sprite. PRO
image_alpha - Indica a transparência da sprite.
image_blend - Indica a cor de mistura da sprite. PRO
bbox_left - Lado esquerdo da bounding box.
bbox_right - Lado direito da bounding box.
bbox_top - Lado de cima da bounding box.
bbox_bottom - Lado de baixo da bounding box.
Pra quem não entendeu quando eu disse sprite ind, ind2 ou source, quis dizer que a ação ocorrerá na sprite definida em ind, ind2, etc.
E pra quem não sabe o quê é a bounding box, ela é a caixa que define qual parte da sprite poderá sofrer a colisão. Tudo o que estiver fora dela será ignorado durante a colisão do objeto.
E o tutorial termina aqui, espero ter ajudado e qualquer coisa é só perguntar!
さようなら!
Descrição: Usando funções e variáveis relacionados a sprites
Nível: Intermediário
Requerimentos: Lite/Pro
Olá a todos!
Neste tutorial serão explicadas algumas funções relacionadas a Sprites e Sub-imagens.
Vamos Começar!
1- Criando novas Sprites
Algumas funções podem ser usadas para criar, copiar ou remover sprites. Na maioria das vezes devem estar seguidas de uma variável. As que precisarem estão marcadas com um *.
sprite_duplicate(ind) *
Duplica a sprite ind para a sprite criada pela variável. Se a sprite não existir, a função retornará -1.
sprite_assign(ind,source)
Copia a sprite definida em source e cola na sprite ind, a substituindo.
sprite_merge(ind1,ind2)
Adiciona as sub-imagens de ind2 para ind1, sem substituir as já existentes.
sprite_add(fname,imgnumb,removeback,smooth,xorig,yorig)*
Adiciona uma sprite a partir de um arquivo de imagem externo. O nome do arquivo deve estar entre aspas e com a extensão no final. Em imgnumb você coloca a sub-imagem que deverá ser carregada. removeback define se a cor de fundo deverá ser removida. Smooth arredonda as bordas do desenho, e xorig e yorig definem o ponto de origem da sprite.
sprite_replace(ind,fname,imgnumb,removeback,smooth,xorig,yorig)
Substitui a sprite ind pela imagem fname. Os outros parâmetros são os mesmos que o da função anterior.
sprite_add_sprite(fname) *
Esta função permite adicionar somente arquivos de sprite do Game Maker (.gmspr)
sprite_replace_sprite(ind,fname)
Substitui a sprite ind pela imagem fname, que deve ser .gmspr.
sprite_create_from_screen(x,y,w,h,removeback,smooth,xorig,yorig) *
Cria a sprite copiando o retângulo (x,y,w,h) da tela.
sprite_add_from_screen(ind,x,y,w,h,removeback,smooth)
Adiciona uma sub-imagem a sprite ind copiando o retângulo (x,y,w,h) da tela.
sprite_create_from_surface(id,x,y,w,h,removeback,smooth,xorig,yorig) *
Cria uma sprite copiando o retângulo (x,y,w,h) da surface id.
sprite_add_from_surface(ind,id,x,y,w,h,removeback,smooth)
Adiciona uma sub-imagem a sprite ind copiando o retângulo (x,y,w,h) da surface id.
sprite_delete(ind)
Deleta a sprite ind
2- Editando Sprites
sprite_set_alpha_from_sprite(ind,spr)
Esta função faz com que o alpha de cada pixel da sprite ind tenha a mesma intensidade dos respectivos pixels da sprite spr.
sprite_set_offset(ind,xoff,yoff)
Define o ponto de origem da sprite ind
sprite_collision_mask(ind,sepmasks,bboxmode,bbleft,bbright,bbtop,bbbottom,kind,tolerance)
Define a collision mask da sprite ind. sepmasks indica se deve haver um mask para cada sub-imagem. bboxmode define qual o modo da bounding box (0=automatic, 1=full image e 2=user defined). bbleft, bbright, bbtop, bbbottom indicam as posições da bounding box (somente se bboxmode for 2). kind define o tipo da mask (0=precise, 1=rectangle, 2=disk e 3=diamond). tolerance define a tolerância em relação ao alpha da sprite (0-255).
3- Retornando valores
sprite_exists(ind)
Retorna se a sprite ind existe.
sprite_get_name(ind)
Retorna o nome da sprite ind.
sprite_get_number
Retorna o número de sub-imagens da sprite ind
sprite_get_width(ind)
Retorna a largura da sprite ind
sprite_get_height(ind)
Retorna a altura da sprite ind
sprite_get_xoffset
Retorna o x-offset da sprite ind.
sprite_get_bbox_left(ind)
Retorna o valor do lado esquerdo da bounding box da sprite ind.
sprite_get_bbox_right(ind)
Retorna o valor do lado direito da bounding box da sprite ind.
sprite_get_bbox_top(ind)
Retorna o valor do lado de cima da bounding box da sprite ind.
sprite_get_bbox_down(ind)
Retorna o valor do lado de baixo da bounding box da sprite ind
4- Salvando Sprites
sprite_save(ind,subimg,fname) - PRO
Salva a sub-imagem subimg da sprite ind no arquivo fname. O arquivo será salvo no formato png.
sprite_save_strip(ind,fname) - PRO
Salva a sprite ind no arquivo fname.
5- Variáveis
sprite_index - Indica a sprite do objeto.
sprite_width - Indica a largura da sprite.
sprite_height - Indica a altura da sprite.
sprite_xoffset - Indica o x-offset da sprite.
sprite_yoffset - Indica o y-offset da sprite.
image_number - Indica o número de sub-imagens da sprite.
image_index - Indica a sub-imagem atual na animação.
image_speed - Indica a velocidade da animação.
image_xscale - Indica a escala horizontal da sprite.
image_yscale - Indica a escala vertical da sprite.
image_angle - Indica o ângulo da sprite. PRO
image_alpha - Indica a transparência da sprite.
image_blend - Indica a cor de mistura da sprite. PRO
bbox_left - Lado esquerdo da bounding box.
bbox_right - Lado direito da bounding box.
bbox_top - Lado de cima da bounding box.
bbox_bottom - Lado de baixo da bounding box.
6- Explicações extras
Pra quem não entendeu quando eu disse sprite ind, ind2 ou source, quis dizer que a ação ocorrerá na sprite definida em ind, ind2, etc.
E pra quem não sabe o quê é a bounding box, ela é a caixa que define qual parte da sprite poderá sofrer a colisão. Tudo o que estiver fora dela será ignorado durante a colisão do objeto.
E o tutorial termina aqui, espero ter ajudado e qualquer coisa é só perguntar!
さようなら!
Última edição por JV Justino em Dom 26 Fev 2012, 15:18, editado 4 vez(es)
JV Justino- Games Ranking :
Notas recebidas : A+A
Data de inscrição : 07/12/2010
Reputação : 20
Número de Mensagens : 619
Prêmios :
x 0 x 13 x 0
x 0 x 0 x 0
x 0 x 0 x 0
Re: Sprites - Funções e Variáveis
muito bom o Tutorial.
bem explicadinho nota: 10 tem umas ai que eu nem conheço
bem explicadinho nota: 10 tem umas ai que eu nem conheço
Re: Sprites - Funções e Variáveis
Muito obrigado!sonic luan escreveu:muito bom o Tutorial.
bem explicadinho nota: 10 tem umas ai que eu nem conheço
Para falar a verdade, eu mesmo não conhecia algumas .
JV Justino- Games Ranking :
Notas recebidas : A+A
Data de inscrição : 07/12/2010
Reputação : 20
Número de Mensagens : 619
Prêmios :
x 0 x 13 x 0
x 0 x 0 x 0
x 0 x 0 x 0
Re: Sprites - Funções e Variáveis
Mais um ótimo tutorial seu cara, como já tinha dito, gostei muito do estilo, bem explicado, bem formatado, direto e objetivo. Continue assim explicando as funções do GM para conhecermos ainda mais os Códigos. E assim podemos diminuir as limitações nos nossos jogos.
Só acho que você devia explicar um pouco mais sobre ind, bouding box e etc...
Só acho que você devia explicar um pouco mais sobre ind, bouding box e etc...
Parabéns, movido para a sessão de Tutoriais Aprovados
Dancity- Games Ranking :
Notas recebidas : A
Data de inscrição : 11/01/2009
Reputação : 8
Número de Mensagens : 1340
Prêmios :
x 0 x 0 x 0
x 1 x 0 x 0
x 0 x 0 x 0
GMBR :: Ensine & Aprenda :: Tutoriais :: Game Maker
Página 1 de 1
Permissões neste sub-fórum
Não podes responder a tópicos