mirror of
https://github.com/islehorse/HISP.git
synced 2025-04-21 20:25:51 +12:00
Implement 2PLAYER ...
This commit is contained in:
parent
32a288c58a
commit
6256c38414
7 changed files with 145 additions and 24 deletions
|
@ -1893,6 +1893,7 @@ namespace HISP.Server
|
|||
Messages.BallonCutscene = gameData.transport.ballon_cutscene;
|
||||
|
||||
gameData = null;
|
||||
return;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -3326,6 +3326,31 @@ namespace HISP.Server
|
|||
TwoPlayer twoPlayerGame = new TwoPlayer(toInvite, sender.LoggedinUser, false);
|
||||
}
|
||||
break;
|
||||
case PacketBuilder.SWFMODULE_ACCEPT:
|
||||
if (packet.Length < 4)
|
||||
{
|
||||
Logger.ErrorPrint(sender.LoggedinUser.Username + " Sent an invalid 2PLAYER ACCEPT Packet (WRONG SIZE)");
|
||||
break;
|
||||
}
|
||||
packetStr = Encoding.UTF8.GetString(packet);
|
||||
playerIdStr = packetStr.Substring(2, packetStr.Length - 4);
|
||||
playerId = -1;
|
||||
try
|
||||
{
|
||||
playerId = int.Parse(playerIdStr);
|
||||
}
|
||||
catch (Exception) { };
|
||||
|
||||
if (IsUserOnline(playerId))
|
||||
{
|
||||
User toAccept = GetUserById(playerId);
|
||||
if(TwoPlayer.IsPlayerInvitingPlayer(toAccept, sender.LoggedinUser))
|
||||
{
|
||||
TwoPlayer twoPlayerGame = TwoPlayer.GetGameInvitingPlayer(toAccept, sender.LoggedinUser);
|
||||
twoPlayerGame.Accept(sender.LoggedinUser);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case PacketBuilder.SWFMODULE_DRAWINGROOM:
|
||||
if(packet.Length < 3)
|
||||
{
|
||||
|
@ -3724,13 +3749,47 @@ namespace HISP.Server
|
|||
}
|
||||
}
|
||||
break;
|
||||
case PacketBuilder.SWFMODULE_BANDHALL: // Basic
|
||||
case PacketBuilder.SWFMODULE_BANDHALL:
|
||||
byte[] response = PacketBuilder.CreateForwardedSwfRequest(packet);
|
||||
foreach (User user in GetUsersAt(sender.LoggedinUser.X, sender.LoggedinUser.Y))
|
||||
{
|
||||
if (user.Id == sender.LoggedinUser.Id)
|
||||
continue;
|
||||
user.LoggedinClient.SendPacket(response);
|
||||
}
|
||||
break;
|
||||
case PacketBuilder.SWFMODULE_2PLAYER:
|
||||
if(TwoPlayer.IsPlayerInGame(sender.LoggedinUser))
|
||||
{
|
||||
TwoPlayer twoPlayerGame = TwoPlayer.GetTwoPlayerGameInProgress(sender.LoggedinUser);
|
||||
|
||||
User otherUser = null;
|
||||
if (twoPlayerGame.Invitee.Id == sender.LoggedinUser.Id)
|
||||
otherUser = twoPlayerGame.Inviting;
|
||||
else if (twoPlayerGame.Inviting.Id == sender.LoggedinUser.Id)
|
||||
otherUser = twoPlayerGame.Invitee;
|
||||
|
||||
response = PacketBuilder.CreateForwardedSwfRequest(packet);
|
||||
otherUser.LoggedinClient.SendPacket(response);
|
||||
}
|
||||
break;
|
||||
case PacketBuilder.SWFMODULE_CLOSE:
|
||||
if (TwoPlayer.IsPlayerInGame(sender.LoggedinUser))
|
||||
{
|
||||
TwoPlayer twoPlayerGame = TwoPlayer.GetTwoPlayerGameInProgress(sender.LoggedinUser);
|
||||
|
||||
User otherUser = null;
|
||||
if (twoPlayerGame.Invitee.Id == sender.LoggedinUser.Id)
|
||||
otherUser = twoPlayerGame.Inviting;
|
||||
else if (twoPlayerGame.Inviting.Id == sender.LoggedinUser.Id)
|
||||
otherUser = twoPlayerGame.Invitee;
|
||||
|
||||
response = PacketBuilder.Create2PlayerClose();
|
||||
otherUser.LoggedinClient.SendPacket(response);
|
||||
|
||||
twoPlayerGame.CloseGame(sender.LoggedinUser);
|
||||
|
||||
|
||||
}
|
||||
break;
|
||||
case PacketBuilder.SWFMODULE_ARENA:
|
||||
|
@ -6472,6 +6531,7 @@ namespace HISP.Server
|
|||
|
||||
// Leave multirooms
|
||||
Multiroom.LeaveAllMultirooms(sender.LoggedinUser);
|
||||
TwoPlayer.TwoPlayerRemove(sender.LoggedinUser);
|
||||
|
||||
// Remove Trade Reference
|
||||
sender.LoggedinUser.TradingWith = null;
|
||||
|
|
|
@ -113,7 +113,11 @@ namespace HISP.Server
|
|||
public const byte HORSE_CAUGHT = 0x1D;
|
||||
|
||||
public const byte SWFMODULE_INVITE = 0x14;
|
||||
public const byte SWFMODULE_ACCEPT = 0x15;
|
||||
public const byte SWFMODULE_CLOSE = 0x16;
|
||||
|
||||
public const byte SWFMODULE_2PLAYER_CLOSED = 0x58;
|
||||
public const byte SWFMODULE_2PLAYER = 0x50;
|
||||
public const byte SWFMODULE_ARENA = 0x52;
|
||||
public const byte SWFMODULE_BRICKPOET = 0x5A;
|
||||
public const byte SWFMODULE_DRAWINGROOM = 0x5B;
|
||||
|
@ -214,6 +218,18 @@ namespace HISP.Server
|
|||
public const byte DIRECTION_TELEPORT = 4;
|
||||
public const byte DIRECTION_NONE = 10;
|
||||
|
||||
public static byte[] Create2PlayerClose()
|
||||
{
|
||||
MemoryStream ms = new MemoryStream();
|
||||
ms.WriteByte(PACKET_SWFMODULE);
|
||||
ms.WriteByte(SWFMODULE_2PLAYER_CLOSED);
|
||||
ms.WriteByte(PACKET_TERMINATOR);
|
||||
|
||||
ms.Seek(0x00, SeekOrigin.Begin);
|
||||
byte[] response = ms.ToArray();
|
||||
ms.Dispose();
|
||||
return response;
|
||||
}
|
||||
public static byte[] CreateDressupRoomPeiceMove(int peiceId, double x, double y, bool active)
|
||||
{
|
||||
MemoryStream ms = new MemoryStream();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue