怎么P2P接口也是有问题的,到底啥接口能用

This commit is contained in:
ZouJin 2024-03-18 02:22:47 +08:00
parent 03f8da9b4c
commit c6272cdd2a
3 changed files with 66 additions and 41 deletions

View File

@ -11,6 +11,7 @@ namespace VPet_Simulator.Windows.Interface;
/// <summary> /// <summary>
/// 多人模式传输的消息 /// 多人模式传输的消息
/// </summary> /// </summary>
[Serializable]
public struct MPMessage public struct MPMessage
{ {
/// <summary> /// <summary>
@ -53,6 +54,6 @@ public struct MPMessage
/// </summary> /// </summary>
public ulong To; public ulong To;
public static string ConverTo(MPMessage data) => LPSConvert.SerializeObject(data).ToString(); public static byte[] ConverTo(MPMessage data) => Encoding.UTF8.GetBytes(LPSConvert.SerializeObject(data).ToString());
public static MPMessage ConverTo(string data) => LPSConvert.DeserializeObject<MPMessage>(new LPS(data)); public static MPMessage ConverTo(byte[] data) => LPSConvert.DeserializeObject<MPMessage>(new LPS(Encoding.UTF8.GetString(data)));
} }

View File

@ -58,7 +58,6 @@ public partial class MPFriends : WindowX
mw.Windows.Add(this); mw.Windows.Add(this);
try try
{ {
InitializeComponent(); InitializeComponent();
//MGrid.Height = 500 * mw.Set.ZoomLevel; //MGrid.Height = 500 * mw.Set.ZoomLevel;
@ -119,11 +118,10 @@ public partial class MPFriends : WindowX
Close(); Close();
return; return;
} }
Task.Run(async () =>
{
ImageSources.AddRange(mw.ImageSources); ImageSources.AddRange(mw.ImageSources);
//加载所有MOD //加载所有MOD
List<DirectoryInfo> Path = new List<DirectoryInfo>(); List<DirectoryInfo> Path = new List<DirectoryInfo>();
Path.AddRange(new DirectoryInfo(mw.ModPath).EnumerateDirectories()); Path.AddRange(new DirectoryInfo(mw.ModPath).EnumerateDirectories());
@ -134,8 +132,6 @@ public partial class MPFriends : WindowX
Path.Add(new DirectoryInfo(ws.Name)); Path.Add(new DirectoryInfo(ws.Name));
} }
Task.Run(async () =>
{
//加载lobby传过来的数据 //加载lobby传过来的数据
string tmp = lb.GetMemberData(friend, "save"); string tmp = lb.GetMemberData(friend, "save");
while (string.IsNullOrEmpty(tmp)) while (string.IsNullOrEmpty(tmp))
@ -205,7 +201,6 @@ public partial class MPFriends : WindowX
Core.Graph = petloader.Graph(mw.Set.Resolution); Core.Graph = petloader.Graph(mw.Set.Resolution);
Main = new Main(Core); Main = new Main(Core);
Main.DisplayNomal = DisplayMPNomal;
Main.EventTimer.AutoReset = false; Main.EventTimer.AutoReset = false;
Main.EventTimer.Enabled = false; Main.EventTimer.Enabled = false;
@ -245,18 +240,6 @@ public partial class MPFriends : WindowX
})); }));
} }
public new bool Loaded = false; public new bool Loaded = false;
/// <summary>
/// 显示默认动画
/// </summary>
private void DisplayMPNomal()
{
Core.Save = GameSave_VPet.Load(new Line(lb.GetMemberData(friend, "save")));
if (DisplayGraph(LPSConvert.DeserializeObject<GraphInfo>(new LPS(lb.GetMemberData(friend, "display"))))) return;
Main.CountNomal++;
Main.Display(GraphType.Default, AnimatType.Single, DisplayMPNomal);
}
/// <summary> /// <summary>
/// 显示捏脸情况 /// 显示捏脸情况
@ -343,7 +326,7 @@ public partial class MPFriends : WindowX
var img = Core.Graph.FindGraph(gi.Name, gi.Animat, Core.Save.Mode); var img = Core.Graph.FindGraph(gi.Name, gi.Animat, Core.Save.Mode);
if (img != null) if (img != null)
{ {
Main.Display(img, DisplayMPNomal); Main.Display(img);
return true; return true;
} }
return false; return false;

View File

@ -123,6 +123,11 @@ public partial class winMutiPlayer : Window
lbLid.Text = lb.Id.Value.ToString("x"); lbLid.Text = lb.Id.Value.ToString("x");
Steamworks.Data.Image? img = await lb.Owner.GetMediumAvatarAsync(); Steamworks.Data.Image? img = await lb.Owner.GetMediumAvatarAsync();
HostHead.Source = ConvertToImageSource(img.Value); HostHead.Source = ConvertToImageSource(img.Value);
SteamNetworking.AllowP2PPacketRelay(true);
SteamNetworking.OnP2PSessionRequest = (steamid) =>
{
SteamNetworking.AcceptP2PSessionWithUser(steamid);
};
//给自己动画添加绑定 //给自己动画添加绑定
mw.Main.GraphDisplayHandler += Main_GraphDisplayHandler; mw.Main.GraphDisplayHandler += Main_GraphDisplayHandler;
@ -141,7 +146,6 @@ public partial class winMutiPlayer : Window
var mpuc = new MPUserControl(this, mpf); var mpuc = new MPUserControl(this, mpf);
MUUCList.Children.Add(mpuc); MUUCList.Children.Add(mpuc);
MPUserControls.Add(mpuc); MPUserControls.Add(mpuc);
SteamNetworking.AcceptP2PSessionWithUser(v.Id);
if (v.Id == lb.Owner.Id) if (v.Id == lb.Owner.Id)
_ = Task.Run(() => _ = Task.Run(() =>
{ {
@ -157,6 +161,7 @@ public partial class winMutiPlayer : Window
}); });
}); });
} }
_ = Task.Run(LoopP2PPacket);
} }
private void SteamMatchmaking_OnLobbyMemberLeave(Lobby lobby, Friend friend) private void SteamMatchmaking_OnLobbyMemberLeave(Lobby lobby, Friend friend)
@ -175,6 +180,7 @@ public partial class winMutiPlayer : Window
MPUserControls.Remove(mpuc); MPUserControls.Remove(mpuc);
MUUCList.Children.Remove(mpuc); MUUCList.Children.Remove(mpuc);
MPFriends.Remove(mpuc.mpf); MPFriends.Remove(mpuc.mpf);
mpuc.mpf.Quit();
} }
} }
} }
@ -186,14 +192,28 @@ public partial class winMutiPlayer : Window
{ {
return; return;
} }
lb.SetMemberData("display", LPSConvert.SerializeObject(info).ToString()); MPMessage msg = new MPMessage();
msg.Type = MPMessage.MSGType.DispayGraph;
msg.Content = LPSConvert.SerializeObject(info).ToString();
msg.To = SteamClient.SteamId.Value;
byte[] data = MPMessage.ConverTo(msg);
for (int i = 0; i < MPFriends.Count; i++)
{
MPFriends v = MPFriends[i];
SteamNetworking.SendP2PPacket(v.friend.Id, data);
}
} }
private void SteamMatchmaking_OnLobbyMemberJoined(Lobby lobby, Friend friend) private void SteamMatchmaking_OnLobbyMemberJoined(Lobby lobby, Friend friend)
{ {
if (lobby.Id == lb.Id) if (lobby.Id == lb.Id)
{ {
var mpf = new MPFriends(this, mw, lb, friend);
MPFriends.Add(mpf);
mpf.Show();
var mpuc = new MPUserControl(this, mpf);
MUUCList.Children.Add(mpuc);
MPUserControls.Add(mpuc);
} }
} }
@ -205,13 +225,32 @@ public partial class winMutiPlayer : Window
} }
} }
private void LoopP2PPacket()
{
while (SteamNetworking.IsP2PPacketAvailable() && isOPEN)
{
var packet = SteamNetworking.ReadP2PPacket();
if (packet.HasValue)
{
var From = packet.Value.SteamId;
var MSG = MPMessage.ConverTo(packet.Value.Data);
var TO = MPFriends.Find(x => x.friend.Id == MSG.To);
switch (MSG.Type)
{
case MPMessage.MSGType.DispayGraph:
var info = LPSConvert.DeserializeObject<GraphInfo>(new LPS(MSG.Content));
TO.DisplayGraph(info);
break;
}
}
}
Thread.Sleep(100);
LoopP2PPacket();
}
private void Window_Closed(object sender, EventArgs e) private void Window_Closed(object sender, EventArgs e)
{ {
SteamMatchmaking.OnLobbyDataChanged -= SteamMatchmaking_OnLobbyDataChanged; SteamMatchmaking.OnLobbyDataChanged -= SteamMatchmaking_OnLobbyDataChanged;
mw.Main.GraphDisplayHandler -= Main_GraphDisplayHandler; mw.Main.GraphDisplayHandler -= Main_GraphDisplayHandler;
if (lb.Owner.Id == SteamClient.SteamId)
lb.SetData("leave", "true");
lb.Leave(); lb.Leave();
for (int i = 0; i < MPFriends.Count; i++) for (int i = 0; i < MPFriends.Count; i++)
{ {
@ -219,14 +258,16 @@ public partial class winMutiPlayer : Window
} }
mw.winMutiPlayer = null; mw.winMutiPlayer = null;
} }
bool isOPEN = true;
private void Window_Closing(object sender, System.ComponentModel.CancelEventArgs e) private void Window_Closing(object sender, System.ComponentModel.CancelEventArgs e)
{ {
if (!lb.Equals(default(Lobby))) if (!lb.Equals(default(Lobby)))
if (MessageBoxX.Show("确定要关闭访客表吗?".Translate(), "离开游戏", MessageBoxButton.YesNo) != MessageBoxResult.Yes) if (MessageBoxX.Show("确定要关闭访客表吗?".Translate(), "离开游戏", MessageBoxButton.YesNo) != MessageBoxResult.Yes)
{ {
e.Cancel = true; e.Cancel = true;
return;
} }
isOPEN = false;
} }
private void swAllowJoin_Checked(object sender, RoutedEventArgs e) private void swAllowJoin_Checked(object sender, RoutedEventArgs e)