• Introduзгo
Obs: Este tуpico й para aqueles que tem algum interesse em criar um plugin como o YSF ou pretendem utilizar RPCs com o plugin Pawn.RakNet de UrShadow.
Estarei explicando o que sгo RPCs e providenciando seus parвmetros e IDs para uso, jб que nem todos estгo documentados e muito menos seus parвmetros.
Alguns RPCs tem os mesmos parвmetros que a funзгo que geralmente estгo relacionados com, jб outros nгo, tornando seu uso complicado.
• O que й RPC?
RPC й um acrфnimo de Remote Procedure Call (Chamada de Procedimento Remoto), um protocolo usado para solicitar um serviзo de um cliente localizado em outro computador em uma rede sem ter que entender os detalhes da rede. Como vocк jб sabe, SA-MP usa o motor (engine) de rede RakNet.
Digamos que vocк explodiu um jogador, o servidor enviarб um RPC (0x47 - RPC_CreateExplosion) ao cliente solicitando que a explosгo seja criada.
O cliente tambйm envia chamadas de procedimento remoto de volta. Digamos que vocк entrou em um veнculo, seu cliente enviarб uma notificaзгo de entrada para o servidor, nesse caso, um RPC informando esse evento (RPC_EnterVehicle) serб enviado.
Tipos de RPCs:
Prioridades:-Outcoming RPCs: RPCs mandados pelo servidor ao cliente.
-Incoming RPCs: RPCs mandados pelo cliente ao servidor.
Confiabilidades:-SYSTEM_PRIORITY: Usada pelo RakNet para enviar chamadas de prioridade acima do normal.
-HIGH_PRIORITY: Chamadas de alta prioridade sгo enviadas antes das chamadas de prioridade mйdia.
-MEDIUM_PRIORITY: As chamadas de prioridade mйdia sгo enviadas antes das chamadas de baixa prioridade.
-LOW_PRIORITY: As chamadas de baixa prioridade sу sгo enviadas quando nenhuma outra chamada estб aguardando.
-UNRELIABLE: Os pacotes UNRELIABLE sгo enviados por UDP direto. Eles podem chegar fora de ordem, ou nгo. Isto й melhor para os dados que nгo sгo importantes ou os dados que vocк envia com muita freqькncia, mesmo que alguns pacotes sejam perdidos, os pacotes mais novos serгo compensados.
Vantagens - Esses pacotes nгo precisam ser reconhecidos pela rede, salvando o tamanho de um cabeзalho UDP em reconhecimento (cerca de 50 bytes ou mais). As economias podem realmente se somar.
Desvantagens - Sem pedidos de pacotes, os pacotes podem nunca chegar, esses pacotes sгo os primeiros a serem descartados se o buffer de envio estiver cheio.
-UNRELIABLE_SEQUENCED: Os pacotes UNRELIABLE_SEQUENCED sгo os mesmos que os pacotes UNRELIABLE, exceto que apenas o pacote mais recente й aceito. Os pacotes mais antigos sгo ignorados. Vantagens - Mesma baixa sobrecarga que pacotes UNRELIABLE, e vocк nгo precisa se preocupar com pacotes mais antigos que mudam seus dados para valores antigos.
Desvantagens - muitos pacotes serгo descartados, uma vez que eles nunca podem chegar por causa do UDP e podem cair mesmo quando eles chegam. Esses pacotes sгo os primeiros a serem descartados se o buffer de envio estiver cheio. O ъltimo pacote enviado pode nunca chegar, o que pode ser um problema se vocк parar de enviar pacotes em algum ponto particular.
-RELIABLE: Os pacotes RELIABLE sгo pacotes UDP monitorados por uma camada de confiabilidade para garantir que eles chegam ao destino.
Vantagens - Vocк sabe que o pacote chegarб lб. Eventualmente ...
Desvantagens - Retransmissхes e reconhecimentos podem adicionar exigкncias significativas de largura de banda. Os pacotes podem chegar muito tarde se a rede estiver ocupada. Nгo hб pedidos de pacotes.
-RELIABLE_ORDERED: Os pacotes RELIABLE_ORDERED sгo pacotes UDP monitorados por uma camada de confiabilidade para garantir que eles chegam ao destino. Vantagens - O pacote chegarб na ordem em que foi enviado. Estes sгo, de longe, os mais fбceis de programar, porque vocк nгo precisa se preocupar com comportamento estranho devido a falta de ordem ou pacotes perdidos.
Desvantagens - Retransmissхes e reconhecimentos podem adicionar exigкncias significativas de largura de banda. Os pacotes podem chegar muito tarde se a rede estiver ocupada. Um pacote tardio pode atrasar muitos pacotes que chegaram mais cedo, resultando em espasmos significativos. No entanto, essa desvantagem pode ser atenuada pelo uso inteligente de fluxos de pedidos.
-RELIABLE_SEQUENCED: Os pacotes RELIABLE_SEQUENCED sгo pacotes UDP monitorados por uma camada de confiabilidade para garantir que eles chegam ao destino e sгo seqьenciados no destino.
Vantagens - Vocк obtйm a confiabilidade dos pacotes UDP, o pedido de pacotes ordenados, mas nгo precisa aguardar pacotes antigos. Mais pacotes chegarгo com esse mйtodo do que com o mйtodo UNRELIABLE_SEQUENCED, e eles serгo distribuнdos de forma mais uniforme. A vantagem mais importante no entanto й que o ъltimo pacote enviado chegarб, onde com UNRELIABLE_SEQUENCED o ъltimo pacote enviado pode nгo chegar.
Desvantagens - Desperdнcio de largura de banda, porque ele usa a sobrecarga de pacotes UDP confiбveis para garantir a chegada de pacotes atrasados que apenas sejam ignorados de qualquer maneira.
• Exemplo de uso
RPC_ShowActor
ID: 171
Parвmetros: WORD wActorID, DWORD dSkinID, float x, float y, float z, float angle, float health
Uso em Plugin
Uso com o Pawn.RakNetPHP Code:
&RPC_ShowActor: Integer com o ID do RPC.
- Código:
RakNet::BitStream bs;
bs.Write((WORD)5); //ID do ator.
bs.Write((DWORD)287); //Skin que serб mostrado para o jogador.
bs.Write((float)0.0); //Coordenada X.
bs.Write((float)0.0); //Coordenada Y.
bs.Write((float)0.0); //Coordenada Z.
bs.Write((float)50.0); //Вngulo.
bs.Write((float)100.0); //Vida do ator.
pRakServer->RPC(&RPC_ShowActor, &bs, LOW_PRIORITY, RELIABLE_ORDERED, 0, pRakServer->GetPlayerIDFromIndex(23), 0, 0);
&bs: BitStream com os parвmetros a serem mandados no RPC.
LOW_PRIORITY: Prioridade do RPC.
RELIABLE_ORDERED: Confiabilidade do RPC.
pRakServer->GetPlayerIDFromIndex(23): O jogador que receberб o RPC.
PHP Code:
bs: BitStream com os parвmetros a serem mandados no RPC.
- Código:
new BitStream:bs = BS_New();
BS_WriteValue(
bs,
PR_UINT16, 5, //ID do Ator.
PR_UINT32, 287, //Skin que serб mostrado para o jogador.
PR_FLOAT, 0.0, //Coordenada X.
PR_FLOAT, 0.0, //Coordenada Y.
PR_FLOAT, 0.0, //Coordenada Z.
PR_FLOAT, 50.0, //Вngulo.
PR_FLOAT, 100.0 //Vida do ator.
);
BS_RPC(bs, 23, 171, PR_LOW_PRIORITY, PR_RELIABLE_ORDERED);
BS_Delete(bs);
23: O jogador que receberб o RPC.
171: ID do RPC ShowActor.
PR_LOW_PRIORITY: Prioridade do RPC.
PR_RELIABLE_ORDERED: Confiabilidade do RPC
• Lista de RPCs com parвmetros
Github
Obs: A lista nгo estб totalmente completa, ainda estou construindo. Se vocк precisa dos parвmetros de um RPC que nгo estб na lista no momento, me deixe saber.
Creditos: Jelly23