mirror of
https://git.muiegratis.online/suikoakari/Campofinale
synced 2025-12-23 15:04:36 +01:00
Compare commits
6 Commits
460bfe527c
...
developmen
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f72b052c41 | ||
|
|
d54bab8906 | ||
|
|
68f93eb80d | ||
|
|
c2ba13b5f7 | ||
|
|
b125394b79 | ||
|
|
69d832d376 |
@@ -171,6 +171,26 @@ namespace Campofinale.Game.Entities
|
|||||||
}else if(eventName == "pick_inst")
|
}else if(eventName == "pick_inst")
|
||||||
{
|
{
|
||||||
//TODO
|
//TODO
|
||||||
|
}else if(eventName == "set_state_true")
|
||||||
|
{
|
||||||
|
ScSceneUpdateInteractiveProperty update = new()
|
||||||
|
{
|
||||||
|
Id = guid,
|
||||||
|
SceneNumId = GetOwner().curSceneNumId,
|
||||||
|
Properties =
|
||||||
|
{
|
||||||
|
{1, new DynamicParameter()
|
||||||
|
{
|
||||||
|
RealType=3,
|
||||||
|
ValueType=3,
|
||||||
|
ValueIntList={1}
|
||||||
|
} }
|
||||||
|
}
|
||||||
|
};
|
||||||
|
GetOwner().sceneManager.KillEntity(guid, true, 1);
|
||||||
|
GetOwner().noSpawnAnymore.Add(guid);
|
||||||
|
GetOwner().sceneManager.GetScene(sceneNumId).AddCollection(templateId, 1);
|
||||||
|
GetOwner().Send(ScMsgId.ScSceneUpdateInteractiveProperty, update);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
34
Campofinale/Packets/Cs/HandleCsItemBagSetItemLock.cs
Normal file
34
Campofinale/Packets/Cs/HandleCsItemBagSetItemLock.cs
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
using Campofinale.Game.Char;
|
||||||
|
using Campofinale.Game.Inventory;
|
||||||
|
using Campofinale.Network;
|
||||||
|
using Campofinale.Protocol;
|
||||||
|
|
||||||
|
namespace Campofinale.Packets.Cs
|
||||||
|
{
|
||||||
|
public class HandleCsItemBagSetItemLock
|
||||||
|
{
|
||||||
|
[Server.Handler(CsMsgId.CsItemBagSetItemLock)]
|
||||||
|
public static void Handle(Player session, CsMsgId cmdId, Packet packet)
|
||||||
|
{
|
||||||
|
CsItemBagSetItemLock req = packet.DecodeBody<CsItemBagSetItemLock>();
|
||||||
|
|
||||||
|
foreach (var info in req.LockInfoList)
|
||||||
|
{
|
||||||
|
Item item = session.inventoryManager.items.items.Find(i=>i.guid==info.InstId);
|
||||||
|
if (item != null)
|
||||||
|
{
|
||||||
|
item.locked = info.IsLock;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ScItemBagSetItemLock rsp = new()
|
||||||
|
{
|
||||||
|
LockInfoList =
|
||||||
|
{
|
||||||
|
req.LockInfoList,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
session.Send(ScMsgId.ScItemBagSetItemLock, rsp);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -3,6 +3,7 @@ using Campofinale.Network;
|
|||||||
using Campofinale.Packets.Sc;
|
using Campofinale.Packets.Sc;
|
||||||
using Campofinale.Protocol;
|
using Campofinale.Protocol;
|
||||||
using Campofinale.Resource;
|
using Campofinale.Resource;
|
||||||
|
using System;
|
||||||
using static Campofinale.Resource.ResourceManager;
|
using static Campofinale.Resource.ResourceManager;
|
||||||
|
|
||||||
namespace Campofinale.Packets.Cs
|
namespace Campofinale.Packets.Cs
|
||||||
@@ -23,6 +24,18 @@ namespace Campofinale.Packets.Cs
|
|||||||
case SpInteractiveOpType.CommonActive:
|
case SpInteractiveOpType.CommonActive:
|
||||||
session.bitsetManager.AddValue(Resource.BitsetType.InteractiveActive, ResourceManager.levelShortIdTable[scene.id].ids[(long)entity.guid]);
|
session.bitsetManager.AddValue(Resource.BitsetType.InteractiveActive, ResourceManager.levelShortIdTable[scene.id].ids[(long)entity.guid]);
|
||||||
break;
|
break;
|
||||||
|
case SpInteractiveOpType.DoodadCommonPick:
|
||||||
|
EntityInteractive interactive = entity as EntityInteractive;
|
||||||
|
if (interactive.templateId== "int_doodad_flower_2")
|
||||||
|
{
|
||||||
|
session.inventoryManager.AddRewards("reward_doodad_moss_3", interactive.Position, 1);
|
||||||
|
}
|
||||||
|
if (interactive.templateId == "int_doodad_flower_1")
|
||||||
|
{
|
||||||
|
session.inventoryManager.AddRewards("reward_doodad_moss_3", interactive.Position, 1);
|
||||||
|
}
|
||||||
|
session.sceneManager.KillEntity(interactive.guid, true, 1);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ class Program
|
|||||||
private static void FakeClientTester()
|
private static void FakeClientTester()
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
string serverIp = "beyond-cn.hypergryph.com";
|
string serverIp = "beyond-ric.gryphline.com";
|
||||||
int serverPort = 30000;
|
int serverPort = 30000;
|
||||||
Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
|
Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
|
||||||
|
|
||||||
@@ -33,6 +33,7 @@ class Program
|
|||||||
socket.Connect(new IPEndPoint(ipAddress, serverPort));
|
socket.Connect(new IPEndPoint(ipAddress, serverPort));
|
||||||
|
|
||||||
socket.Send(Packet.EncodePacket((int)CsMsgId.CsLogin,new CsLogin() { ClientVersion="0.5.5",Uid= "", Token= "", Env=EnvType.Prod,PlatformId=ClientPlatformType.Windows,Area=AreaType.Oversea,ClientResVersion="", LoginToken= "" }.ToByteArray()));
|
socket.Send(Packet.EncodePacket((int)CsMsgId.CsLogin,new CsLogin() { ClientVersion="0.5.5",Uid= "", Token= "", Env=EnvType.Prod,PlatformId=ClientPlatformType.Windows,Area=AreaType.Oversea,ClientResVersion="", LoginToken= "" }.ToByteArray()));
|
||||||
|
//socket.Send(Packet.EncodePacket((int)CsMsgId.CsFriendListSync, new CsFriendListSync() { }.ToByteArray()));
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
byte[] buffer = new byte[3];
|
byte[] buffer = new byte[3];
|
||||||
|
|||||||
@@ -59,7 +59,7 @@ namespace Campofinale
|
|||||||
public delegate void HandlerDelegate(Player sender, string command, string[] args, Player target);
|
public delegate void HandlerDelegate(Player sender, string command, string[] args, Player target);
|
||||||
}
|
}
|
||||||
public static List<Player> clients = new List<Player>();
|
public static List<Player> clients = new List<Player>();
|
||||||
public static string ServerVersion = "1.1.7-dev";
|
public static string ServerVersion = "1.1.8-dev";
|
||||||
public static bool Initialized = false;
|
public static bool Initialized = false;
|
||||||
public static bool showLogs = true;
|
public static bool showLogs = true;
|
||||||
public static bool showWarningLogs = true;
|
public static bool showWarningLogs = true;
|
||||||
|
|||||||
Reference in New Issue
Block a user