Entrar
Últimos assuntos
» Alguém aqui já ganha dinheiro com seus games?por theguitarmester Ter 30 Abr 2024, 11:43
» Colisões não funcionando
por theguitarmester Ter 30 Abr 2024, 10:16
» Como ajustar velocidade de cada frame da animação no game maker
por pequetux Sex 26 Abr 2024, 16:45
» Preciso de ajuda
por AftonDuGrau Dom 21 Abr 2024, 20:18
» Como faz o evento drawn GUI, não se repetir?
por aminaro Sex 19 Abr 2024, 20:30
» PROBLEMAS COM FÍSICAS DE ÁGUA
por aminaro Ter 16 Abr 2024, 10:07
» Retorno da GMBR!!!
por Ralphed Sex 12 Abr 2024, 22:45
» JOGADOR PARANDO NO AR QUANDO ATACA
por aminaro Qua 10 Abr 2024, 13:51
» Problemas com texto interativo
por Kaaru72 Dom 07 Abr 2024, 11:31
» Erro escondido e indecifrável
por dev_gabize.azv Qui 04 Abr 2024, 10:11
» Mudar cor de apenas uma palavra
por Ralphed Sáb 30 Mar 2024, 00:39
» Procuro Programador de game maker
por Wou Sex 15 Mar 2024, 10:27
» Mod APK
por gamerainha Qua 13 Mar 2024, 06:30
» 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
» 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
Direção Z
3 participantes
Página 1 de 1
Direção Z
Estou precisando de algum script que pegue a direção Z entre dois pontos tridimensionais.
Exemplo:
Exemplo:
- Código:
//Ponto[x,y,z]
Ponto1[0,0,0];
Ponto2[15,23,55];
return (Direção z entre Ponto1 e Ponto2);
Kapoty- Games Ranking :
Notas recebidas : E + D + C + B + D +B + A
Data de inscrição : 05/11/2011
Reputação : 22
Número de Mensagens : 635
Prêmios :
x 0 x 0 x 0
x 1 x 0 x 1
x 0 x 0 x 0
Re: Direção Z
Se eu entendi direito e você quiser o ângulo formado por 2 pontos em relação ao eixo Z (no caso, de Ponto1[0,0,0] a Ponto2[15,23,55]):
-edit: fiz uma correção na ilustração.
- Código:
//x1 e y1 são os x e y do Ponto1, enquanto x2 e y2 os do Ponto2
direcaoZ = point_direction(x1,y1,x2,y2);
-edit: fiz uma correção na ilustração.
Re: Direção Z
Mas, assim eu peguei o angulo XY, quero o angulo Z.
Tipo, pegar o angulo de pontos de Z's diferentes.
(Acho que já da pra entender)
Tipo, pegar o angulo de pontos de Z's diferentes.
(Acho que já da pra entender)
Kapoty- Games Ranking :
Notas recebidas : E + D + C + B + D +B + A
Data de inscrição : 05/11/2011
Reputação : 22
Número de Mensagens : 635
Prêmios :
x 0 x 0 x 0
x 1 x 0 x 1
x 0 x 0 x 0
Re: Direção Z
Sim, sabe como pegar este angulo?
Kapoty- Games Ranking :
Notas recebidas : E + D + C + B + D +B + A
Data de inscrição : 05/11/2011
Reputação : 22
Número de Mensagens : 635
Prêmios :
x 0 x 0 x 0
x 1 x 0 x 1
x 0 x 0 x 0
Re: Direção Z
Então fica assim.
Caso precise de ajuda na hora de converter os angulos de volta pra x,y e z:
- Código:
//x1,y1 e z1 são os x,y e z do Ponto1, enquanto x2,y2 e z2 os do Ponto2
//Primeiro, pegamos a distancia entre os 2 pontos no planoXY
distXY=point_distance(x1,y1,x2,y2);
//E então calculamos o angulo usando os 'Z's
direçãoZ=point_direction(0,-z1,distXY,-z2);
Caso precise de ajuda na hora de converter os angulos de volta pra x,y e z:
- Código:
x=distancia_total*cos(degtorad(direcaoXY))*cos(degtorad(direcaoZ));
y=-distancia_total*sin(degtorad(direcaoXY))*cos(degtorad(direcaoZ));
z=distancia_total*sin(degtorad(direcaoZ));
Re: Direção Z
Era exatamente isto que estava procurando, procurei e procurei mas não achei, obrigado mesmo o/
Kapoty- Games Ranking :
Notas recebidas : E + D + C + B + D +B + A
Data de inscrição : 05/11/2011
Reputação : 22
Número de Mensagens : 635
Prêmios :
x 0 x 0 x 0
x 1 x 0 x 1
x 0 x 0 x 0
Re: Direção Z
Não estou vendo a imagem (internet bloqueada no serviço, aquela história), mas tenho uma idéia do que foi pedido.
Um ângulo em 3D é sempre em um plano e com relação ao outro.
Num eixo de coordenadas, você sempre pode usar dois pontos como vértices opostos de um paralelepípedo (a menos que uma ou mais coordenadas coincidam, o que reduz o paralelepípedo a um retângulo plano, uma reta ou um ponto).
O que parece estar sendo pedido é ângulo entre o plano de base e o plano da diagonal do paralelepípedo.
Usando um terceiro ponto com as mesma coordenada Z de um ponto e com as mesmas coordenadas X e Y do outro, você tem um triângulo retângulo em que um dos ângulos é o que você quer. Com as medidas de um triângulo retângulo, você consegue o seno, cosseno e tangente de qualquer ângulo e, por consequência, o ângulo a que ele se refere.
Dá pra fazer um script mais ou menos assim:
Edit: Droga, o MatheusTeis é muito mais rápido (e melhor) do que eu. Mas quebrei a cabeça com isso, vou postar mesmo ele tendo dado uma solução até mais inteligente.
Um ângulo em 3D é sempre em um plano e com relação ao outro.
Num eixo de coordenadas, você sempre pode usar dois pontos como vértices opostos de um paralelepípedo (a menos que uma ou mais coordenadas coincidam, o que reduz o paralelepípedo a um retângulo plano, uma reta ou um ponto).
O que parece estar sendo pedido é ângulo entre o plano de base e o plano da diagonal do paralelepípedo.
Usando um terceiro ponto com as mesma coordenada Z de um ponto e com as mesmas coordenadas X e Y do outro, você tem um triângulo retângulo em que um dos ângulos é o que você quer. Com as medidas de um triângulo retângulo, você consegue o seno, cosseno e tangente de qualquer ângulo e, por consequência, o ângulo a que ele se refere.
Dá pra fazer um script mais ou menos assim:
- Código:
// uso: variavel := anguloZ(x1, y1, z1, x2, y2, z2);
var xx, yy, zz, catBase, catZ;
xx[0] := argument0;
yy[0] := argument1;
zz[0] := argument2;
xx[1] := argument3;
yy[1] := argument4;
zz[1] := argument5;
// medida do cateto da base (no plano paralelo ao x/y)
catBase := point_distance(xx[0], yy[0], xx[1], yy[1]);
// medida do cateto paralelo ao eixo Z
catZ := abs(zz[0] - zz[1]);
// de posse dos catetos, calcula-se a tangente e o ângulo
return(arctan2(catZ, catBase)); // não tenho certeza se é bem assim que funciona "arctan2"
Edit: Droga, o MatheusTeis é muito mais rápido (e melhor) do que eu. Mas quebrei a cabeça com isso, vou postar mesmo ele tendo dado uma solução até mais inteligente.
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
Página 1 de 1
Permissões neste sub-fórum
Não podes responder a tópicos
|
|