修复自动备份相关错误

This commit is contained in:
ZouJin 2023-08-13 17:28:08 +10:00
parent 8629c59091
commit 1e1e9f1b35
4 changed files with 28 additions and 23 deletions

View File

@ -184,7 +184,7 @@ namespace VPet_Simulator.Core
imgs.Add(System.Drawing.Image.FromFile(file.FullName)); imgs.Add(System.Drawing.Image.FromFile(file.FullName));
int w = imgs[0].Width; int w = imgs[0].Width;
int h = imgs[0].Height; int h = imgs[0].Height;
if(w > GraphCore.Resolution) if (w > GraphCore.Resolution)
{ {
w = GraphCore.Resolution; w = GraphCore.Resolution;
h = (int)(h * (GraphCore.Resolution / (double)imgs[0].Width)); h = (int)(h * (GraphCore.Resolution / (double)imgs[0].Width));
@ -340,6 +340,8 @@ namespace VPet_Simulator.Core
else else
{ {
img = (System.Windows.Controls.Image)GraphCore.CommUIElements["Image1.PNGAnimation"]; img = (System.Windows.Controls.Image)GraphCore.CommUIElements["Image1.PNGAnimation"];
if (img.Parent != null)
((Decorator)img.Parent).Child = null;
parant.Child = img; parant.Child = img;
} }
} }

View File

@ -101,7 +101,8 @@ namespace VPet_Simulator.Core
else else
{ {
img = (Image)GraphCore.CommUIElements["Image1.Picture"]; img = (Image)GraphCore.CommUIElements["Image1.Picture"];
parant.Child = null; if (img.Parent != null)
((Decorator)img.Parent).Child = null;
parant.Child = img; parant.Child = img;
} }
} }

View File

@ -165,20 +165,20 @@ namespace VPet_Simulator.Windows
.GetFiles("*.lps").OrderByDescending(x => x.LastWriteTime).FirstOrDefault(); .GetFiles("*.lps").OrderByDescending(x => x.LastWriteTime).FirstOrDefault();
if (latestsave != null) if (latestsave != null)
{ {
GameLoad(new Line(File.ReadAllText(latestsave.FullName))); if (GameLoad(new Line(File.ReadAllText(latestsave.FullName))))
return; return;
} }
} }
Core.Save = new GameSave(petname.Translate()); Core.Save = new GameSave(petname.Translate());
} }
public void GameLoad() public async void GameLoad()
{ {
//加载所有MOD //加载所有MOD
List<DirectoryInfo> Path = new List<DirectoryInfo>(); List<DirectoryInfo> Path = new List<DirectoryInfo>();
Path.AddRange(new DirectoryInfo(ModPath).EnumerateDirectories()); Path.AddRange(new DirectoryInfo(ModPath).EnumerateDirectories());
if (IsSteamUser)//如果是steam用户,尝试加载workshop if (IsSteamUser)//如果是steam用户,尝试加载workshop
{ {
Dispatcher.Invoke(new Action(() => LoadingText.Content = "Loading Steam Workshop")); await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "Loading Steam Workshop"));
int i = 1; int i = 1;
while (true) while (true)
{ {
@ -197,13 +197,13 @@ namespace VPet_Simulator.Windows
} }
} }
} }
Dispatcher.Invoke(new Action(() => LoadingText.Content = "Loading MOD")); await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "Loading MOD"));
//加载mod //加载mod
foreach (DirectoryInfo di in Path) foreach (DirectoryInfo di in Path)
{ {
if (!File.Exists(di.FullName + @"\info.lps")) if (!File.Exists(di.FullName + @"\info.lps"))
continue; continue;
Dispatcher.Invoke(new Action(() => LoadingText.Content = $"Loading MOD: {di.Name}")); await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = $"Loading MOD: {di.Name}"));
CoreMODs.Add(new CoreMOD(di, this)); CoreMODs.Add(new CoreMOD(di, this));
} }
@ -218,7 +218,8 @@ namespace VPet_Simulator.Windows
Directory.CreateDirectory(CachePath); Directory.CreateDirectory(CachePath);
} }
} }
Dispatcher.BeginInvoke(new Action(() => LoadingText.Content = "Loading Translate"));
await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "Loading Translate"));
//加载语言 //加载语言
LocalizeCore.StoreTranslation = true; LocalizeCore.StoreTranslation = true;
if (Set.Language == "null") if (Set.Language == "null")
@ -249,16 +250,17 @@ namespace VPet_Simulator.Windows
} }
Dispatcher.BeginInvoke(new Action(() => LoadingText.Content = "尝试加载游戏MOD".Translate())); await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "尝试加载游戏MOD".Translate()));
//当前桌宠动画 //当前桌宠动画
var petloader = Pets.Find(x => x.Name == Set.PetGraph); var petloader = Pets.Find(x => x.Name == Set.PetGraph);
petloader ??= Pets[0]; petloader ??= Pets[0];
await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "尝试加载游戏存档".Translate()));
//加载存档 //加载存档
Core.Controller = new MWController(this); Core.Controller = new MWController(this);
if (File.Exists(AppDomain.CurrentDomain.BaseDirectory + @"\Save.lps") && if (!(File.Exists(AppDomain.CurrentDomain.BaseDirectory + @"\Save.lps") &&
!GameLoad(new LpsDocument(File.ReadAllText(AppDomain.CurrentDomain.BaseDirectory + @"\Save.lps")).First())) GameLoad(new LpsDocument(File.ReadAllText(AppDomain.CurrentDomain.BaseDirectory + @"\Save.lps")).First())))
//如果加载存档失败了,试试加载备份,如果没备份,就新建一个 //如果加载存档失败了,试试加载备份,如果没备份,就新建一个
LoadLatestSave(petloader.PetName); LoadLatestSave(petloader.PetName);
@ -283,6 +285,7 @@ namespace VPet_Simulator.Windows
"长按脑袋拖动桌宠到你喜欢的任意位置".Translate(), "长按脑袋拖动桌宠到你喜欢的任意位置".Translate(),
"欢迎加入 虚拟主播模拟器群 430081239".Translate() "欢迎加入 虚拟主播模拟器群 430081239".Translate()
}; };
await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "尝试加载Steam内容".Translate()));
//给正在玩这个游戏的主播/游戏up主做个小功能 //给正在玩这个游戏的主播/游戏up主做个小功能
if (IsSteamUser) if (IsSteamUser)
{ {
@ -306,19 +309,15 @@ namespace VPet_Simulator.Windows
}; };
MusicTimer.Elapsed += MusicTimer_Elapsed; MusicTimer.Elapsed += MusicTimer_Elapsed;
await Dispatcher.InvokeAsync(new Action(() => LoadingText.Content = "尝试加载游戏动画".Translate()));
Dispatcher.Invoke(new Action(() => await Dispatcher.InvokeAsync(new Action(() =>
{ {
LoadingText.Content = "尝试加载动画和生成缓存".Translate(); LoadingText.Content = "尝试加载动画和生成缓存".Translate();
Core.Graph = petloader.Graph(Set.Resolution); Core.Graph = petloader.Graph(Set.Resolution);
LoadingText.Content = "正在加载CGPT".Translate();
winSetting = new winGameSetting(this);
winBetterBuy = new winBetterBuy(this);
Main = new Main(Core); Main = new Main(Core);
Main.NoFunctionMOD = Set.CalFunState; Main.NoFunctionMOD = Set.CalFunState;
LoadingText.Content = "正在加载CGPT".Translate();
switch (Set["CGPT"][(gstr)"type"]) switch (Set["CGPT"][(gstr)"type"])
{ {
case "API": case "API":
@ -334,7 +333,6 @@ namespace VPet_Simulator.Windows
break; break;
} }
LoadingText.Content = "正在加载游戏".Translate(); LoadingText.Content = "正在加载游戏".Translate();
var m = new System.Windows.Controls.MenuItem() var m = new System.Windows.Controls.MenuItem()
{ {
@ -366,6 +364,10 @@ namespace VPet_Simulator.Windows
Main.TimeHandle += Handle_Steam; Main.TimeHandle += Handle_Steam;
Main.TimeHandle += (x) => DiagnosisUPLoad(); Main.TimeHandle += (x) => DiagnosisUPLoad();
//窗口部件
winSetting = new winGameSetting(this);
winBetterBuy = new winBetterBuy(this);
Main.DefaultClickAction = () => Main.DefaultClickAction = () =>
{ {
if (new TimeSpan(DateTime.Now.Ticks - lastclicktime).TotalSeconds > 20) if (new TimeSpan(DateTime.Now.Ticks - lastclicktime).TotalSeconds > 20)
@ -377,13 +379,13 @@ namespace VPet_Simulator.Windows
Main.PlayVoiceVolume = Set.VoiceVolume; Main.PlayVoiceVolume = Set.VoiceVolume;
Main.FunctionSpendHandle += StatisticsCalHandle; Main.FunctionSpendHandle += StatisticsCalHandle;
DisplayGrid.Child = Main; DisplayGrid.Child = Main;
Task.Run(() => Task.Run(async () =>
{ {
while (Main.IsWorking) while (Main.IsWorking)
{ {
Thread.Sleep(100); Thread.Sleep(100);
} }
Dispatcher.Invoke(() => LoadingText.Visibility = Visibility.Collapsed); await Dispatcher.InvokeAsync(() => LoadingText.Visibility = Visibility.Collapsed);
}); });
Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "退出桌宠".Translate(), () => { Main.ToolBar.Visibility = Visibility.Collapsed; Close(); }); Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "退出桌宠".Translate(), () => { Main.ToolBar.Visibility = Visibility.Collapsed; Close(); });

View File

@ -144,7 +144,7 @@ namespace VPet_Simulator.Windows
/// </summary> /// </summary>
public void TalkChatInfoDisplay() public void TalkChatInfoDisplay()
{ {
Dispatcher.Invoke(() => this.IsEnabled = false); //Dispatcher.Invoke(() => this.IsEnabled = false);
var l = ConnectAIOpen("VPet/Data", "GET"); var l = ConnectAIOpen("VPet/Data", "GET");
if (l.Name == "Info") if (l.Name == "Info")
{ {