Multiplayer OnTriggerEnter ServerSide RPC call

I’m working on a game with AI Bots that are controlled from the server. The Bots seems to be working ok in multiplayer, except for an attack script that I have. When ever the trigger collides with the client, it is suppose to reduce the clients health. The problem is that the script seems to only work when the Server’s character is watching the attack, or when the clients character is moving. Please take a look at the script bellow and post your thoughts. Thank you.

function OnTriggerEnter (other : Collider) 
{
	if (other.tag == "Chaos" || other.tag == "Order") // the Two different sides in the game
	{	
		if (Network.isServer  attack)
		{			
			if (other.networkView.isMine)
			{
				if (other.name != "Shield_Collider")
				{
					other.SendMessage("TakeDamage", damage);
				}
				else if (other.name == "Shield_Collider")
				{
					other.SendMessage("ShieldDamage", damage);
				}
			}
			else if (!other.networkView.isMine)
			{
				var otherPlayer = other.networkView.owner;
				
				if (other.name != "Shield_Collider")
				{
					other.networkView.RPC("TakeDamage", otherPlayer, damage);
				}
				else if (other.name == "Shield_Collider")
				{
					other.networkView.RPC("ShieldDamage", otherPlayer, damage);
				}
			}								
			attack = false;
		}				
	}
}

I guess whats causing this, is that you call the RPC function only on the affected client. If you want your server to know that the client has taken damage, then you have to add other.SendMessage("TakeDamage", damage) there as well.

Thanks for the quick reply Der Dude. Unfortunately I’m trying to get the clients computer to show the damage that it’s receiving. I have stored players health individually on their respective characters, locally, that’s why I’ve sent the RPC call, “TakeDamage”, to the client. However it doesn’t update the client’s computer, unless the host watches the Bot attack the client, or the client is moving.

thats because your RPC call is incorrect by default.

You put the ownerid in there, but there is defacto no ownerid within the RPC.
You are meant to put the RPCMode there, like RCPMode.Others for example.

If you want to send the owner id, then you need to send it as function parameter

Thanks for the response Dreamora. Could you explain what you mean? I’m not really following. I read in one of the forums, http://forum.unity3d.com/viewtopic.php?t=14905&highlight=rpc+player , someone posted that we could send RPC calls to specific players. I was trying to re-create that. I thought that the networkView.owner, was the networkPlayer?

Oh, you are right, thats a second possibility.
Always forget about it as it is only of any use for very few things (Client ↔ Server communication with specific information like your character when you login to a server that stores your data between sessions and alike)

I don’t see why you would only want to send it to a specific player only in this case. Especially not granted that we are talking about the server end who is the only one to send things to a single client.

Also, all others must know about it, not only a specific player, otherwise only you and the other player know it and the rest has totally wrong data.
Even worse, the server potentially would have wrong data which is a no go unless you want to invite cheaters (the server should normally always be the one deciding if a desired change is valid and if so promote it to the other connected clients)
So you would send the related object id to all players from the “server player” so they can update it on their end as well.

or are you trying achieving something pretty special out of the normal?

Cool, cool. Yeah thanks for the tip Dreamora. I never thought about it that way.

I finally got it to work. Thanks everyone. What I ended up doing was trimming down the code:

function OnTriggerEnter (other : Collider) 
{
	if (other.tag == "Chaos" || other.tag == "Order") // the Two different sides in the game
	{	
		if (attack)
		{
			if (other.name != "Shield_Collider")
			{
				other.SendMessage("TakeDamage", damage);
			}
			else if (other.name == "Shield_Collider")
			{
				other.SendMessage("ShieldDamage", damage);
			}
								
			attack = false;
		}				
	}
}

So like Der Dude suggested I sent the “TakeDamage” script on the server and clients, locally. Then, like Dreamora suggested, I had a RPC script that sent to ‘All’ the players and returned the new health after taking Damage. Thanks again for all the input.

Glad to hear its working
Good luck and lots of fun with it :slight_smile: