本文整理汇总了C#中Lidgren.Network.NetIncomingMessage.Clone方法的典型用法代码示例。如果您正苦于以下问题:C# NetIncomingMessage.Clone方法的具体用法?C# NetIncomingMessage.Clone怎么用?C# NetIncomingMessage.Clone使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Lidgren.Network.NetIncomingMessage
的用法示例。
在下文中一共展示了NetIncomingMessage.Clone方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: BufferField
internal void BufferField(NetIncomingMessage msg, byte fieldId)
{
var toBuffer = new NetBuffer();
msg.Clone(toBuffer);
fieldBuffer[fieldId] = toBuffer;
}
示例2: Consume
private static void Consume(NetIncomingMessage msg)
{
try
{
//faster than switch, as this is in most to least common order
if (msg.SequenceChannel == Channels.UNRELIABLE_STREAM)
{
var actorId = msg.ReadUInt16();
NetworkView find;
if (NetworkView.Find(actorId, out find))
{
Player player = GetPlayer(msg.SenderConnection);
find.OnDeserializeStream(msg, player);
}
}
else if (msg.SequenceChannel == Channels.RELIABLE_STREAM)
{
var actorId = msg.ReadUInt16();
NetworkView find;
if (NetworkView.Find(actorId, out find))
{
Player player = GetPlayer(msg.SenderConnection);
find.OnDeserializeStream(msg, player);
}
}
else if (msg.SequenceChannel >= Channels.BEGIN_RPCMODES && msg.SequenceChannel <= Channels.OWNER_RPC)
{
//rpc...
var viewID = msg.ReadUInt16();
var rpcId = msg.ReadByte();
Player player = GetPlayer(msg.SenderConnection);
NetworkView find;
var info = new NetMessageInfo((RPCMode)(msg.SequenceChannel - Channels.BEGIN_RPCMODES), player);
if (NetworkView.Find(viewID, out find))
{
find.CallRPC(rpcId, msg, info);
//Do we need to forward this still?
if (info.mode != RPCMode.Server && info.continueForwarding)
{
//need to forward...
if (info.mode == RPCMode.Others || info.mode == RPCMode.All) { }
else
{
find.Buffer(msg);
}
find.Send(msg, info.mode, msg.SenderConnection);
}
}
}
else if (msg.SequenceChannel == Channels.SYNCHED_FIELD)
{
var viewId = msg.ReadUInt16();
var fieldId = msg.ReadByte();
NetworkView find;
if (NetworkView.Find(viewId, out find))
{
find.BufferField(msg, fieldId);
find.SendField(msg, msg.SenderConnection);
}
}
else if (msg.SequenceChannel == Channels.OBJECT_RPC)
{
Player player = GetPlayer(msg.SenderConnection);
if (player.CurrentRoom != null)
player.CurrentRoom.IncomingObjectRPC(msg);
}
else if (msg.SequenceChannel == Channels.STATIC_RPC)
{
var rpcId = msg.ReadByte();
var player = GetPlayer(msg.SenderConnection);
var currentRoom = player.CurrentRoom;
if (currentRoom != null)
{
NetMessageInfo info = new NetMessageInfo(RPCMode.None, player);
currentRoom.CallRPC(rpcId, msg, info);
if (info.continueForwarding)
{
var newMessage = peer.CreateMessage();
msg.Clone(newMessage);
currentRoom.SendMessage(newMessage);
}
}
}
else if (msg.SequenceChannel == Channels.STATIC_UTILS)
{
ProcessUtils(msg);
}
else
{
Debug.LogWarning("data received over unhandled channel " + msg.SequenceChannel);
}
}
catch (Exception ex)
{
Debug.Log("[Consumption] {0} : {1}", ex.Message, ex.StackTrace);
//.........这里部分代码省略.........
示例3: HandleStaticRpc
static void HandleStaticRpc(NetIncomingMessage msg)
{
var rpcId = msg.ReadByte();
var player = GetPlayer(msg.SenderConnection);
var currentRoom = player.CurrentRoom;
if (currentRoom != null)
{
var info = new NetMessageInfo(RPCMode.None, player);
currentRoom.CallRPC(rpcId, msg, info);
if (info.continueForwarding)
{
var newMessage = peer.CreateMessage();
msg.Clone(newMessage);
if (msg.DeliveryMethod == NetDeliveryMethod.ReliableOrdered)
currentRoom.SendMessage(newMessage, true);
else
currentRoom.SendMessage(newMessage, false);
}
}
else
{
Debug.LogWarning("[PNetS.Consume] Player {0} attempted static rpc {1}, but they are not in a room to do so",
player, rpcId);
(player).InternalErrorCount++;
}
}