mirror of
https://github.com/LorisYounger/VPet.ModMaker.git
synced 2024-08-30 18:22:21 +00:00
保存修改为文件夹对话框
修复载入模组错误时出现的问题
This commit is contained in:
parent
24508f5766
commit
5a29c279e4
@ -61,15 +61,20 @@
|
|||||||
<Reference Include="LinePutScript.Localization.WPF, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="LinePutScript.Localization.WPF, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\LinePutScript.Localization.WPF.1.0.6\lib\net462\LinePutScript.Localization.WPF.dll</HintPath>
|
<HintPath>..\packages\LinePutScript.Localization.WPF.1.0.6\lib\net462\LinePutScript.Localization.WPF.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
<Reference Include="Ookii.Dialogs.Wpf, Version=5.0.0.0, Culture=neutral, PublicKeyToken=66aa232afad40158, processorArchitecture=MSIL">
|
||||||
|
<HintPath>..\packages\Ookii.Dialogs.Wpf.5.0.1\lib\net462\Ookii.Dialogs.Wpf.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="Panuon.WPF, Version=1.0.3.0, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="Panuon.WPF, Version=1.0.3.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\Panuon.WPF.1.0.3\lib\net462\Panuon.WPF.dll</HintPath>
|
<HintPath>..\packages\Panuon.WPF.1.0.3\lib\net462\Panuon.WPF.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="Panuon.WPF.UI, Version=1.1.16.1, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="Panuon.WPF.UI, Version=1.1.16.3, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\Panuon.WPF.UI.1.1.16.2\lib\net462\Panuon.WPF.UI.dll</HintPath>
|
<HintPath>..\packages\Panuon.WPF.UI.1.1.16.3\lib\net462\Panuon.WPF.UI.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="System" />
|
<Reference Include="System" />
|
||||||
<Reference Include="System.Data" />
|
<Reference Include="System.Data" />
|
||||||
|
<Reference Include="System.Design" />
|
||||||
<Reference Include="System.Drawing" />
|
<Reference Include="System.Drawing" />
|
||||||
|
<Reference Include="System.Security" />
|
||||||
<Reference Include="System.Xml" />
|
<Reference Include="System.Xml" />
|
||||||
<Reference Include="Microsoft.CSharp" />
|
<Reference Include="Microsoft.CSharp" />
|
||||||
<Reference Include="System.Core" />
|
<Reference Include="System.Core" />
|
||||||
|
@ -138,14 +138,22 @@ public class I18nEditWindowVM
|
|||||||
AddCulture(culture);
|
AddCulture(culture);
|
||||||
SearchTargets.Add(culture);
|
SearchTargets.Add(culture);
|
||||||
}
|
}
|
||||||
I18nHelper.Current.CultureNames.CollectionChanged -= CultureNames_CollectionChanged;
|
try
|
||||||
I18nHelper.Current.CultureNames.CollectionChanged += CultureNames_CollectionChanged;
|
{
|
||||||
LoadFood(model);
|
LoadFood(model);
|
||||||
LoadClickText(model);
|
LoadClickText(model);
|
||||||
LoadLowText(model);
|
LoadLowText(model);
|
||||||
LoadSelectText(model);
|
LoadSelectText(model);
|
||||||
LoadPets(model);
|
LoadPets(model);
|
||||||
}
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
Close();
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
I18nHelper.Current.CultureNames.CollectionChanged -= CultureNames_CollectionChanged;
|
||||||
|
I18nHelper.Current.CultureNames.CollectionChanged += CultureNames_CollectionChanged;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 载入食物
|
/// 载入食物
|
||||||
|
@ -17,6 +17,7 @@ using LinePutScript.Localization.WPF;
|
|||||||
using Panuon.WPF.UI;
|
using Panuon.WPF.UI;
|
||||||
using VPet.ModMaker.Views.ModEdit.I18nEdit;
|
using VPet.ModMaker.Views.ModEdit.I18nEdit;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
|
using Ookii.Dialogs.Wpf;
|
||||||
|
|
||||||
namespace VPet.ModMaker.ViewModels.ModEdit;
|
namespace VPet.ModMaker.ViewModels.ModEdit;
|
||||||
|
|
||||||
@ -86,8 +87,8 @@ public class ModEditWindowVM
|
|||||||
|
|
||||||
public ModEditWindowVM(ModEditWindow window)
|
public ModEditWindowVM(ModEditWindow window)
|
||||||
{
|
{
|
||||||
ModEditWindow = window;
|
|
||||||
new I18nEditWindow();
|
new I18nEditWindow();
|
||||||
|
ModEditWindow = window;
|
||||||
ChangeImageCommand.ExecuteEvent += ChangeImage;
|
ChangeImageCommand.ExecuteEvent += ChangeImage;
|
||||||
AddCultureCommand.ExecuteEvent += AddCulture;
|
AddCultureCommand.ExecuteEvent += AddCulture;
|
||||||
EditCultureCommand.ExecuteEvent += EditCulture;
|
EditCultureCommand.ExecuteEvent += EditCulture;
|
||||||
@ -254,16 +255,10 @@ public class ModEditWindowVM
|
|||||||
{
|
{
|
||||||
if (ValidationData(ModInfo.Value) is false)
|
if (ValidationData(ModInfo.Value) is false)
|
||||||
return;
|
return;
|
||||||
SaveFileDialog saveFileDialog =
|
var dialog = new VistaFolderBrowserDialog();
|
||||||
new()
|
if (dialog.ShowDialog() is not true)
|
||||||
{
|
|
||||||
Title = "保存模组信息文件,并在文件夹内保存模组数据".Translate(),
|
|
||||||
Filter = $"LPS文件|*.lps;".Translate(),
|
|
||||||
FileName = "info.lps".Translate()
|
|
||||||
};
|
|
||||||
if (saveFileDialog.ShowDialog() is not true)
|
|
||||||
return;
|
return;
|
||||||
SaveTo(Path.GetDirectoryName(saveFileDialog.FileName));
|
SaveTo(dialog.SelectedPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -15,6 +15,7 @@ using System.Windows;
|
|||||||
using VPet.ModMaker.Models;
|
using VPet.ModMaker.Models;
|
||||||
using VPet.ModMaker.Views;
|
using VPet.ModMaker.Views;
|
||||||
using VPet.ModMaker.Views.ModEdit;
|
using VPet.ModMaker.Views.ModEdit;
|
||||||
|
using VPet.ModMaker.Views.ModEdit.I18nEdit;
|
||||||
|
|
||||||
namespace VPet.ModMaker.ViewModels;
|
namespace VPet.ModMaker.ViewModels;
|
||||||
|
|
||||||
@ -189,6 +190,7 @@ public class ModMakerWindowVM
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
private void ShowEditWindow()
|
private void ShowEditWindow()
|
||||||
{
|
{
|
||||||
|
GC.Collect();
|
||||||
ModMakerWindow.Hide();
|
ModMakerWindow.Hide();
|
||||||
// 将当前模组添加到历史
|
// 将当前模组添加到历史
|
||||||
if (string.IsNullOrEmpty(ModInfoModel.Current.SourcePath.Value) is false)
|
if (string.IsNullOrEmpty(ModInfoModel.Current.SourcePath.Value) is false)
|
||||||
@ -196,6 +198,7 @@ public class ModMakerWindowVM
|
|||||||
SaveHistories();
|
SaveHistories();
|
||||||
ModEditWindow = new();
|
ModEditWindow = new();
|
||||||
ModEditWindow.Show();
|
ModEditWindow.Show();
|
||||||
|
ModEditWindow.InitializeData();
|
||||||
ModEditWindow.Closed += (s, e) =>
|
ModEditWindow.Closed += (s, e) =>
|
||||||
{
|
{
|
||||||
var modInfo = ModInfoModel.Current;
|
var modInfo = ModInfoModel.Current;
|
||||||
@ -204,9 +207,11 @@ public class ModMakerWindowVM
|
|||||||
AddHistories(modInfo);
|
AddHistories(modInfo);
|
||||||
SaveHistories();
|
SaveHistories();
|
||||||
}
|
}
|
||||||
ModInfoModel.Current.Close();
|
ModInfoModel.Current?.Close();
|
||||||
I18nHelper.Current = new();
|
I18nHelper.Current = new();
|
||||||
ModMakerWindow.Show();
|
ModMakerWindow.Show();
|
||||||
|
ModMakerWindow.Activate();
|
||||||
|
GC.Collect();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -238,33 +243,32 @@ public class ModMakerWindowVM
|
|||||||
var pendingHandler = PendingBox.Show("载入中".Translate());
|
var pendingHandler = PendingBox.Show("载入中".Translate());
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
loader = new ModLoader(new DirectoryInfo(path));
|
loader = new ModLoader(new(path));
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
MessageBox.Show("模组载入失败:\n{0}".Translate(ex));
|
MessageBox.Show(ModMakerWindow, "模组载入失败:\n{0}".Translate(ex));
|
||||||
pendingHandler.Close();
|
pendingHandler.Close();
|
||||||
}
|
}
|
||||||
if (loader is null)
|
if (loader is null)
|
||||||
return;
|
return;
|
||||||
ModInfoModel? modInfo = null;
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
modInfo = new ModInfoModel(loader);
|
var modInfo = new ModInfoModel(loader);
|
||||||
EditMod(modInfo);
|
EditMod(modInfo);
|
||||||
ModEditWindow.InitializeData();
|
pendingHandler.Close();
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
pendingHandler.Close();
|
pendingHandler.Close();
|
||||||
ModEditWindow?.Close();
|
ModEditWindow?.Close();
|
||||||
|
ModEditWindow = null;
|
||||||
|
ModInfoModel.Current?.Close();
|
||||||
|
I18nHelper.Current = new();
|
||||||
|
I18nEditWindow.Current?.Close(true);
|
||||||
ModMakerWindow.Show();
|
ModMakerWindow.Show();
|
||||||
MessageBox.Show("模组载入失败:\n{0}".Translate(ex));
|
ModMakerWindow.Activate();
|
||||||
ModInfoModel.Current = null;
|
MessageBox.Show(ModMakerWindow, "模组载入失败:\n{0}".Translate(ex));
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
pendingHandler.Close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -26,15 +26,11 @@ public partial class I18nEditWindow : WindowX
|
|||||||
|
|
||||||
public I18nEditWindow()
|
public I18nEditWindow()
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
|
||||||
DataContext = new I18nEditWindowVM();
|
|
||||||
ViewModel.CultureChanged += ViewModel_CultureChanged;
|
|
||||||
ViewModel.InitializeI18nData(ModInfoModel.Current);
|
|
||||||
Current = this;
|
Current = this;
|
||||||
// 只隐藏, 不关闭
|
// 只隐藏, 不关闭
|
||||||
Closing += (s, e) =>
|
Closing += (s, e) =>
|
||||||
{
|
{
|
||||||
Visibility = Visibility.Hidden;
|
Hide();
|
||||||
if (_close is false)
|
if (_close is false)
|
||||||
e.Cancel = true;
|
e.Cancel = true;
|
||||||
};
|
};
|
||||||
@ -48,6 +44,10 @@ public partial class I18nEditWindow : WindowX
|
|||||||
}
|
}
|
||||||
catch { }
|
catch { }
|
||||||
};
|
};
|
||||||
|
InitializeComponent();
|
||||||
|
DataContext = new I18nEditWindowVM();
|
||||||
|
ViewModel.CultureChanged += ViewModel_CultureChanged;
|
||||||
|
ViewModel.InitializeI18nData(ModInfoModel.Current);
|
||||||
}
|
}
|
||||||
private bool _close = false;
|
private bool _close = false;
|
||||||
public void Close(bool close)
|
public void Close(bool close)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<Window
|
<pu:WindowX
|
||||||
x:Class="VPet.ModMaker.Views.ModEdit.ModEditWindow"
|
x:Class="VPet.ModMaker.Views.ModEdit.ModEditWindow"
|
||||||
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
@ -336,4 +336,4 @@
|
|||||||
</StackPanel>
|
</StackPanel>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Window>
|
</pu:WindowX>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
using LinePutScript.Localization.WPF;
|
using LinePutScript.Localization.WPF;
|
||||||
using Microsoft.Win32;
|
using Microsoft.Win32;
|
||||||
using Panuon.WPF;
|
using Panuon.WPF;
|
||||||
|
using Panuon.WPF.UI;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Collections.ObjectModel;
|
using System.Collections.ObjectModel;
|
||||||
@ -36,17 +37,17 @@ namespace VPet.ModMaker.Views.ModEdit;
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// winModInfo.xaml 的交互逻辑
|
/// winModInfo.xaml 的交互逻辑
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public partial class ModEditWindow : Window
|
public partial class ModEditWindow : WindowX
|
||||||
{
|
{
|
||||||
public ModEditWindowVM ViewModel => (ModEditWindowVM)DataContext;
|
public ModEditWindowVM ViewModel => (ModEditWindowVM)DataContext;
|
||||||
public FoodPage FoodPage { get; } = new();
|
public FoodPage FoodPage { get; }
|
||||||
public LowTextPage LowTextPage { get; } = new();
|
public LowTextPage LowTextPage { get; }
|
||||||
public ClickTextPage ClickTextPage { get; } = new();
|
public ClickTextPage ClickTextPage { get; }
|
||||||
public SelectTextPage SelectTextPage { get; } = new();
|
public SelectTextPage SelectTextPage { get; }
|
||||||
public PetPage PetPage { get; } = new();
|
public PetPage PetPage { get; }
|
||||||
public WorkPage WorkPage { get; } = new();
|
public WorkPage WorkPage { get; }
|
||||||
public MovePage MovePage { get; } = new();
|
public MovePage MovePage { get; }
|
||||||
public AnimePage AnimePage { get; } = new();
|
public AnimePage AnimePage { get; }
|
||||||
|
|
||||||
public ModEditWindow()
|
public ModEditWindow()
|
||||||
{
|
{
|
||||||
@ -54,6 +55,14 @@ public partial class ModEditWindow : Window
|
|||||||
DataContext = new ModEditWindowVM(this);
|
DataContext = new ModEditWindowVM(this);
|
||||||
Closing += ModEditWindow_Closing;
|
Closing += ModEditWindow_Closing;
|
||||||
Closed += ModEditWindow_Closed;
|
Closed += ModEditWindow_Closed;
|
||||||
|
FoodPage = new();
|
||||||
|
LowTextPage = new();
|
||||||
|
ClickTextPage = new();
|
||||||
|
SelectTextPage = new();
|
||||||
|
PetPage = new();
|
||||||
|
WorkPage = new();
|
||||||
|
MovePage = new();
|
||||||
|
AnimePage = new();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -93,7 +102,7 @@ public partial class ModEditWindow : Window
|
|||||||
|
|
||||||
private void ModEditWindow_Closed(object sender, EventArgs e)
|
private void ModEditWindow_Closed(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
ViewModel.Close();
|
ViewModel?.Close();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
DataContext = null;
|
DataContext = null;
|
||||||
|
@ -30,16 +30,30 @@ namespace VPet.ModMaker.Views;
|
|||||||
public partial class ModMakerWindow : WindowX
|
public partial class ModMakerWindow : WindowX
|
||||||
{
|
{
|
||||||
public ModMakerWindowVM ViewModel => (ModMakerWindowVM)DataContext;
|
public ModMakerWindowVM ViewModel => (ModMakerWindowVM)DataContext;
|
||||||
public ModEditWindow ModEditWindow { get; set; }
|
|
||||||
public Models.ModMaker ModMaker { get; internal set; }
|
public Models.ModMaker ModMaker { get; internal set; }
|
||||||
|
|
||||||
public ModMakerWindow()
|
public ModMakerWindow()
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
DataContext = new ModMakerWindowVM(this);
|
DataContext = new ModMakerWindowVM(this);
|
||||||
|
Closed += ModMakerWindow_Closed;
|
||||||
//new AnimeEditWindow().Show();
|
//new AnimeEditWindow().Show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void ModMakerWindow_Closed(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
foreach (var item in Application.Current.Windows)
|
||||||
|
{
|
||||||
|
if (item is ModEditWindow window)
|
||||||
|
window.Close();
|
||||||
|
}
|
||||||
|
try
|
||||||
|
{
|
||||||
|
DataContext = null;
|
||||||
|
}
|
||||||
|
catch { }
|
||||||
|
}
|
||||||
|
|
||||||
private void ListBoxItem_MouseDoubleClick(object sender, MouseButtonEventArgs e)
|
private void ListBoxItem_MouseDoubleClick(object sender, MouseButtonEventArgs e)
|
||||||
{
|
{
|
||||||
if (sender is not ListBoxItem item)
|
if (sender is not ListBoxItem item)
|
||||||
|
@ -2,8 +2,9 @@
|
|||||||
<packages>
|
<packages>
|
||||||
<package id="LinePutScript" version="1.9.2" targetFramework="net462" />
|
<package id="LinePutScript" version="1.9.2" targetFramework="net462" />
|
||||||
<package id="LinePutScript.Localization.WPF" version="1.0.6" targetFramework="net462" />
|
<package id="LinePutScript.Localization.WPF" version="1.0.6" targetFramework="net462" />
|
||||||
|
<package id="Ookii.Dialogs.Wpf" version="5.0.1" targetFramework="net462" />
|
||||||
<package id="Panuon.WPF" version="1.0.3" targetFramework="net462" />
|
<package id="Panuon.WPF" version="1.0.3" targetFramework="net462" />
|
||||||
<package id="Panuon.WPF.UI" version="1.1.16.2" targetFramework="net462" />
|
<package id="Panuon.WPF.UI" version="1.1.16.3" targetFramework="net462" />
|
||||||
<package id="VPet-Simulator.Core" version="1.0.9" targetFramework="net462" />
|
<package id="VPet-Simulator.Core" version="1.0.9" targetFramework="net462" />
|
||||||
<package id="VPet-Simulator.Windows.Interface" version="1.0.9" targetFramework="net462" />
|
<package id="VPet-Simulator.Windows.Interface" version="1.0.9" targetFramework="net462" />
|
||||||
</packages>
|
</packages>
|
Loading…
Reference in New Issue
Block a user