mirror of
https://bitbucket.org/Ioncannon/project-meteor-server.git
synced 2025-04-23 21:27:46 +00:00
142 lines
5.3 KiB
C#
142 lines
5.3 KiB
C#
![]() |
using FFXIVClassic_Lobby_Server.common;
|
|||
|
using FFXIVClassic_Lobby_Server.packets;
|
|||
|
using FFXIVClassic_Map_Server.Actors;
|
|||
|
using FFXIVClassic_Map_Server.packets.send.actor;
|
|||
|
using FFXIVClassic_Map_Server.packets.send.group;
|
|||
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.Linq;
|
|||
|
using System.Text;
|
|||
|
using System.Threading.Tasks;
|
|||
|
|
|||
|
namespace FFXIVClassic_Map_Server.actors.group
|
|||
|
{
|
|||
|
class Group
|
|||
|
{
|
|||
|
public const uint PlayerPartyGroup = 10001;
|
|||
|
public const uint CompanyGroup = 20001;
|
|||
|
|
|||
|
public const uint GroupInvitationRelationGroup = 50001;
|
|||
|
public const uint TradeRelationGroup = 50002;
|
|||
|
public const uint BazaarBuyItemRelationGroup = 50009;
|
|||
|
|
|||
|
public const uint RetainerGroup = 80001;
|
|||
|
|
|||
|
public ulong groupId;
|
|||
|
public uint groupTypeId;
|
|||
|
public int localizedNamed = -1;
|
|||
|
public string groupName = "";
|
|||
|
|
|||
|
public PartyWork partyGroupWork; //For party group types
|
|||
|
public Object work; //For the rest
|
|||
|
|
|||
|
public List<GroupMember> members = new List<GroupMember>();
|
|||
|
|
|||
|
public Group(ulong id, uint typeId, object work)
|
|||
|
{
|
|||
|
groupId = id;
|
|||
|
groupTypeId = typeId;
|
|||
|
|
|||
|
if (work is PartyWork)
|
|||
|
partyGroupWork = (PartyWork)work;
|
|||
|
else
|
|||
|
this.work = work;
|
|||
|
}
|
|||
|
|
|||
|
public Group(ulong id, uint typeId, int nameId, object work)
|
|||
|
{
|
|||
|
groupId = id;
|
|||
|
groupTypeId = typeId;
|
|||
|
localizedNamed = nameId;
|
|||
|
|
|||
|
if (work is PartyWork)
|
|||
|
partyGroupWork = (PartyWork)work;
|
|||
|
else
|
|||
|
this.work = (PartyWork)work;
|
|||
|
}
|
|||
|
|
|||
|
public Group(ulong id, uint typeId, string name, object work)
|
|||
|
{
|
|||
|
groupId = id;
|
|||
|
groupTypeId = typeId;
|
|||
|
groupName = name;
|
|||
|
localizedNamed = -1;
|
|||
|
|
|||
|
if (work is PartyWork)
|
|||
|
partyGroupWork = (PartyWork)work;
|
|||
|
else
|
|||
|
this.work = work;
|
|||
|
}
|
|||
|
|
|||
|
public void add(Actor actor)
|
|||
|
{
|
|||
|
GroupMember member = new GroupMember(actor.actorId, (int)actor.displayNameId, 0, false, true, actor.customDisplayName);
|
|||
|
members.Add(member);
|
|||
|
}
|
|||
|
|
|||
|
public void sendMemberPackets(Player toPlayer)
|
|||
|
{
|
|||
|
ulong time = Utils.MilisUnixTimeStampUTC();
|
|||
|
|
|||
|
toPlayer.queuePacket(GroupHeaderPacket.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, this));
|
|||
|
toPlayer.queuePacket(GroupMembersBeginPacket.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, this));
|
|||
|
|
|||
|
int currentIndex = 0;
|
|||
|
|
|||
|
while (true)
|
|||
|
{
|
|||
|
if (members.Count - currentIndex >= 64)
|
|||
|
toPlayer.queuePacket(GroupMembersX64Packet.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, members, ref currentIndex));
|
|||
|
else if (members.Count - currentIndex >= 32)
|
|||
|
toPlayer.queuePacket(GroupMembersX32Packet.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, members, ref currentIndex));
|
|||
|
else if (members.Count - currentIndex >= 16)
|
|||
|
toPlayer.queuePacket(GroupMembersX16Packet.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, members, ref currentIndex));
|
|||
|
else if (members.Count - currentIndex > 0)
|
|||
|
toPlayer.queuePacket(GroupMembersX08Packet.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, members, ref currentIndex));
|
|||
|
else
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
toPlayer.queuePacket(GroupMembersEndPacket.buildPacket(toPlayer.actorId, toPlayer.zoneId, time, this));
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
public void sendWorkValues(Player player)
|
|||
|
{
|
|||
|
if (groupTypeId == PlayerPartyGroup)
|
|||
|
{
|
|||
|
SetGroupWorkValuesPacket groupWork = new SetGroupWorkValuesPacket(groupId);
|
|||
|
groupWork.addProperty(this, "partyGroupWork._globalTemp.owner");
|
|||
|
groupWork.setTarget("/_init");
|
|||
|
|
|||
|
SubPacket test = groupWork.buildPacket(player.actorId, player.actorId);
|
|||
|
player.queuePacket(test);
|
|||
|
}
|
|||
|
else if (groupTypeId == GroupInvitationRelationGroup)
|
|||
|
{
|
|||
|
SetGroupWorkValuesPacket groupWork = new SetGroupWorkValuesPacket(groupId);
|
|||
|
groupWork.addProperty(this, "work._globalTemp.host");
|
|||
|
groupWork.addProperty(this, "work._globalTemp.variableCommand");
|
|||
|
groupWork.setTarget("/_init");
|
|||
|
|
|||
|
SubPacket test = groupWork.buildPacket(player.actorId, player.actorId);
|
|||
|
test.debugPrintSubPacket();
|
|||
|
player.queuePacket(test);
|
|||
|
}
|
|||
|
else if (groupTypeId == RetainerGroup)
|
|||
|
{
|
|||
|
SetGroupWorkValuesPacket groupWork = new SetGroupWorkValuesPacket(groupId);
|
|||
|
groupWork.addProperty(this, "work._memberSave[0].cdIDOffset");
|
|||
|
groupWork.addProperty(this, "work._memberSave[0].placeName");
|
|||
|
groupWork.addProperty(this, "work._memberSave[0].conditions");
|
|||
|
groupWork.addProperty(this, "work._memberSave[0].level");
|
|||
|
groupWork.setTarget("/_init");
|
|||
|
|
|||
|
SubPacket test = groupWork.buildPacket(player.actorId, player.actorId);
|
|||
|
player.queuePacket(test);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|