支持主动加入 & 退出解散

This commit is contained in:
ZouJin 2024-03-17 01:02:08 +08:00
parent ec31238fba
commit abcd507ec4
4 changed files with 49 additions and 19 deletions

View File

@ -22,6 +22,7 @@ using LinePutScript.Dictionary;
using Steamworks.Data; using Steamworks.Data;
using System.Windows.Controls; using System.Windows.Controls;
using ToolBar = VPet_Simulator.Core.ToolBar; using ToolBar = VPet_Simulator.Core.ToolBar;
using System.Security.Cryptography;
namespace VPet_Simulator.Windows namespace VPet_Simulator.Windows
{ {
@ -286,6 +287,24 @@ namespace VPet_Simulator.Windows
} }
}); });
SteamMatchmaking.OnLobbyInvite += SteamMatchmaking_OnLobbyInvite; SteamMatchmaking.OnLobbyInvite += SteamMatchmaking_OnLobbyInvite;
SteamFriends.OnGameLobbyJoinRequested += SteamFriends_OnGameLobbyJoinRequested;
}
});
}
private void SteamFriends_OnGameLobbyJoinRequested(Lobby lobby, SteamId id)
{
Dispatcher.Invoke(() =>
{
if (winMutiPlayer == null)
{
winMutiPlayer = new winMutiPlayer(this, lobby.Id.Value);
winMutiPlayer.Show();
}
else
{
MessageBoxX.Show("已经有加入了一个访客表,无法再创建更多".Translate());
winMutiPlayer.Focus();
} }
}); });
} }
@ -294,15 +313,18 @@ namespace VPet_Simulator.Windows
{ {
if (winMutiPlayer != null) if (winMutiPlayer != null)
return; return;
Button btn = new Button(); Dispatcher.Invoke(() =>
btn.Content = "加入访客表";
btn.Style = FindResource("ThemedButtonStyle") as Style;
btn.Click += (_, _) =>
{ {
winMutiPlayer = new winMutiPlayer(this, lobby.Id); Button btn = new Button();
winMutiPlayer.Show(); btn.Content = "加入访客表";
}; btn.Style = FindResource("ThemedButtonStyle") as Style;
Main.Say("收到来自{0}的访客邀请,是否加入?".Translate(friend.Name), msgcontent: btn); btn.Click += (_, _) =>
{
winMutiPlayer = new winMutiPlayer(this, lobby.Id);
winMutiPlayer.Show();
};
Main.Say("收到来自{0}的访客邀请,是否加入?".Translate(friend.Name), msgcontent: btn);
});
} }

View File

@ -4,16 +4,16 @@
xmlns:ll="clr-namespace:LinePutScript.Localization.WPF;assembly=LinePutScript.Localization.WPF" xmlns:ll="clr-namespace:LinePutScript.Localization.WPF;assembly=LinePutScript.Localization.WPF"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:VPet_Simulator.Windows" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:VPet_Simulator.Windows"
mc:Ignorable="d" Margin="5" Width="360" Height="100" Background="{DynamicResource SecondaryLight}" mc:Ignorable="d" Margin="5" Width="340" Height="100" Background="{DynamicResource SecondaryLight}"
BorderBrush="{DynamicResource Secondary}"> BorderBrush="{DynamicResource Secondary}">
<Grid> <Grid>
<Image x:Name="uimg" HorizontalAlignment="Left" Source="/Res/TopLogo2019.PNG" Margin="4" /> <Image x:Name="uimg" HorizontalAlignment="Left" Source="/Res/TopLogo2019.PNG" Margin="4" />
<TextBlock HorizontalAlignment="Left" VerticalAlignment="Center" Margin="110,0,0,0" <TextBlock HorizontalAlignment="Left" VerticalAlignment="Center" Margin="110,0,0,0"
Foreground="{DynamicResource DARKPrimaryDarker}" FontSize="16"> Foreground="{DynamicResource DARKPrimaryDarker}" FontSize="16">
<Run Text="{ll:Str 访客}" />: <Run x:Name="rPetName" Text="萝莉斯" FontSize="20" FontWeight="Bold" /> <Run Text="{ll:Str 访客}" />: <Run x:Name="rPetName" Text="{ll:Str 萝莉斯}" FontSize="20" FontWeight="Bold" />
<LineBreak /> <LineBreak />
<Run Text="{ll:Str 来自}" />: <Run x:Name="hostName" Text="XXX" FontWeight="Bold" /><LineBreak /> <Run Text="{ll:Str 来自}" />: <Run x:Name="hostName" Text="XXX" FontWeight="Bold" /><LineBreak />
<Run x:Name="info" Text="Lv 15" /> <Run x:Name="info" Text="Lv ??" />
</TextBlock> </TextBlock>
<Button Style="{DynamicResource ThemedButtonStyle}" HorizontalAlignment="Right" Content="{ll:Str 重置位置}" <Button Style="{DynamicResource ThemedButtonStyle}" HorizontalAlignment="Right" Content="{ll:Str 重置位置}"
VerticalAlignment="Top" Margin="10"/> VerticalAlignment="Top" Margin="10"/>

View File

@ -4,9 +4,9 @@
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:VPet_Simulator.Windows" mc:Ignorable="d" xmlns:local="clr-namespace:VPet_Simulator.Windows" mc:Ignorable="d"
xmlns:pu="https://opensource.panuon.com/wpf-ui" xmlns:pu="https://opensource.panuon.com/wpf-ui"
xmlns:ll="clr-namespace:LinePutScript.Localization.WPF;assembly=LinePutScript.Localization.WPF" Title="{ll:Str 访客表}" xmlns:ll="clr-namespace:LinePutScript.Localization.WPF;assembly=LinePutScript.Localization.WPF"
MinHeight="400" Width="400" Closed="Window_Closed" FontSize="16" SizeToContent="Height" MaxHeight="800" Title="{ll:Str 访客表}" MinHeight="400" Width="400" Closed="Window_Closed" FontSize="16" SizeToContent="Height"
ResizeMode="CanMinimize" Closing="Window_Closing"> MaxHeight="800" ResizeMode="CanMinimize" Closing="Window_Closing">
<Grid> <Grid>
<Image x:Name="HostHead" Margin="20" Width="80" Height="80" HorizontalAlignment="Left" VerticalAlignment="Top" <Image x:Name="HostHead" Margin="20" Width="80" Height="80" HorizontalAlignment="Left" VerticalAlignment="Top"
Source="/Res/TopLogo2019.PNG" /> Source="/Res/TopLogo2019.PNG" />
@ -26,7 +26,8 @@
</TabItem> </TabItem>
<TabItem Header="{ll:Str 消息日志}"> <TabItem Header="{ll:Str 消息日志}">
<TextBox x:Name="tbLog" Margin="0" BorderThickness="0" Background="{DynamicResource DARKPrimaryTrans4}" <TextBox x:Name="tbLog" Margin="0" BorderThickness="0" Background="{DynamicResource DARKPrimaryTrans4}"
Foreground="{DynamicResource DARKPrimaryDarker}" IsReadOnly="True" VerticalScrollBarVisibility="Visible" /> Foreground="{DynamicResource DARKPrimaryDarker}" IsReadOnly="True"
VerticalScrollBarVisibility="Visible" />
</TabItem> </TabItem>
</TabControl> </TabControl>

View File

@ -42,10 +42,11 @@ public partial class winMutiPlayer : Window
if (lobbyid == null) if (lobbyid == null)
CreateLobby(); CreateLobby();
else else
JoinLobby(lobbyid); JoinLobby(lobbyid.Value);
} }
public async void JoinLobby(ulong? lobbyid) public async void JoinLobby(ulong lobbyid)
{ {
MessageBoxX.Show(lobbyid.ToString("x"));
var lbt = (await SteamMatchmaking.JoinLobbyAsync((SteamId)lobbyid)); var lbt = (await SteamMatchmaking.JoinLobbyAsync((SteamId)lobbyid));
if (!lbt.HasValue || lbt.Value.Owner.Id.Value == 0) if (!lbt.HasValue || lbt.Value.Owner.Id.Value == 0)
{ {
@ -151,7 +152,6 @@ public partial class winMutiPlayer : Window
}); });
} }
} }
private void Main_GraphDisplayHandler(GraphInfo info) private void Main_GraphDisplayHandler(GraphInfo info)
{ {
lb.SendChatString(MPMessage.ConverTo(new MPMessage() { Type = MPMessage.MSGType.DispayGraph, Content = LPSConvert.SerializeObject(info).ToString() })); lb.SendChatString(MPMessage.ConverTo(new MPMessage() { Type = MPMessage.MSGType.DispayGraph, Content = LPSConvert.SerializeObject(info).ToString() }));
@ -177,7 +177,12 @@ public partial class winMutiPlayer : Window
{ {
if (lobby.Id == lb.Id) if (lobby.Id == lb.Id)
{ {
if (lb.GetData("leave") == "true")
{
MessageBoxX.Show("访客表已被房主{0}关闭".Translate(lb.Owner.Name));
lb = default(Lobby);
Close();
}
} }
} }
@ -186,6 +191,8 @@ public partial class winMutiPlayer : Window
SteamMatchmaking.OnLobbyDataChanged -= SteamMatchmaking_OnLobbyDataChanged; SteamMatchmaking.OnLobbyDataChanged -= SteamMatchmaking_OnLobbyDataChanged;
SteamMatchmaking.OnLobbyMemberDataChanged -= SteamMatchmaking_OnLobbyMemberDataChanged; SteamMatchmaking.OnLobbyMemberDataChanged -= SteamMatchmaking_OnLobbyMemberDataChanged;
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++)
{ {