新增3种互动

This commit is contained in:
ZouJin 2023-05-19 18:17:51 +10:00
parent 2fe0b0e089
commit 1c08845294
162 changed files with 538 additions and 337 deletions

View File

@ -1,4 +1,5 @@
using Panuon.WPF.UI; using LinePutScript;
using Panuon.WPF.UI;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
@ -55,6 +56,8 @@ namespace VPet_Simulator.Core
ToolBar = new ToolBar(this); ToolBar = new ToolBar(this);
ToolBar.Visibility = Visibility.Collapsed; ToolBar.Visibility = Visibility.Collapsed;
ToolBar.MenuWork1.Header = core.Graph.GraphConfig.Str[(gstr)"work1"];
ToolBar.MenuWork2.Header = core.Graph.GraphConfig.Str[(gstr)"work2"];
UIGrid.Children.Add(ToolBar); UIGrid.Children.Add(ToolBar);
MsgBar = new MessageBar(this); MsgBar = new MessageBar(this);
MsgBar.Visibility = Visibility.Collapsed; MsgBar.Visibility = Visibility.Collapsed;
@ -120,7 +123,7 @@ namespace VPet_Simulator.Core
if (DisplayType != GraphCore.GraphType.Default) if (DisplayType != GraphCore.GraphType.Default)
{//不是nomal! 可能会卡timer,所有全部timer清空下 {//不是nomal! 可能会卡timer,所有全部timer清空下
CleanState(); CleanState();
if (DisplayStopMove(DisplayNomal)) if (DisplayStopMove(DisplayToNomal))
return; return;
} }
Task.Run(() => Task.Run(() =>
@ -219,7 +222,7 @@ namespace VPet_Simulator.Core
private DateTime wavespan; private DateTime wavespan;
private void MainGrid_MouseWave(object sender, MouseEventArgs e) private void MainGrid_MouseWave(object sender, MouseEventArgs e)
{ {
if (rasetype >= 0) if (rasetype >= 0 || State != WorkingState.Nomal)
return; return;
if ((DateTime.Now - wavespan).TotalSeconds > 2) if ((DateTime.Now - wavespan).TotalSeconds > 2)

View File

@ -24,6 +24,31 @@ namespace VPet_Simulator.Core
/// </summary> /// </summary>
public int CountNomal = 0; public int CountNomal = 0;
/// <summary> /// <summary>
/// 以标准形式显示当前默认状态
/// </summary>
public void DisplayToNomal()
{
switch (State)
{
default:
case WorkingState.Nomal:
DisplayNomal();
return;
case WorkingState.Sleep:
DisplaySleep(true);
return;
case WorkingState.WorkONE:
DisplayWorkONE();
return;
case WorkingState.WorkTWO:
DisplayWorkTWO();
return;
case WorkingState.Study:
DisplayStudy();
return;
}
}
/// <summary>
/// 显示默认情况 /// 显示默认情况
/// </summary> /// </summary>
public void DisplayNomal() public void DisplayNomal()
@ -67,6 +92,7 @@ namespace VPet_Simulator.Core
Display(GraphCore.GraphType.Walk_Right_C_End, EndAction); Display(GraphCore.GraphType.Walk_Right_C_End, EndAction);
return true; return true;
case GraphType.Sleep_B_Loop: case GraphType.Sleep_B_Loop:
State = WorkingState.Nomal;
Display(GraphCore.GraphType.Sleep_C_End, EndAction); Display(GraphCore.GraphType.Sleep_C_End, EndAction);
return true; return true;
case GraphType.Idel_StateONE_B_Loop: case GraphType.Idel_StateONE_B_Loop:
@ -118,7 +144,7 @@ namespace VPet_Simulator.Core
Display(GraphCore.GraphType.Touch_Head_A_Start, () => Display(GraphCore.GraphType.Touch_Head_A_Start, () =>
Display(GraphCore.GraphType.Touch_Head_B_Loop, () => Display(GraphCore.GraphType.Touch_Head_B_Loop, () =>
Display(GraphCore.GraphType.Touch_Head_C_End, DisplayNomal Display(GraphCore.GraphType.Touch_Head_C_End, DisplayToNomal
))); )));
} }
/// <summary> /// <summary>
@ -147,8 +173,8 @@ namespace VPet_Simulator.Core
Core.Graph.RndGraph.Clear(); Core.Graph.RndGraph.Clear();
Display(GraphCore.GraphType.Touch_Body_A_Start, () => Display(GraphCore.GraphType.Touch_Body_A_Start, () =>
Display(GraphCore.GraphType.Touch_Body_B_Loop, () => Display(GraphCore.GraphType.Touch_Body_B_Loop, () =>
Display(GraphCore.GraphType.Touch_Body_C_End, DisplayNomal Display(GraphCore.GraphType.Touch_Body_C_End, DisplayToNomal
, true), true), true); )));
} }
/// <summary> /// <summary>
/// 显示待机(模式1)情况 /// 显示待机(模式1)情况
@ -171,7 +197,7 @@ namespace VPet_Simulator.Core
DisplayIdel_StateTWO(); DisplayIdel_StateTWO();
break; break;
default: default:
Display(GraphCore.GraphType.Idel_StateONE_C_End, DisplayNomal); Display(GraphCore.GraphType.Idel_StateONE_C_End, DisplayToNomal);
break; break;
} }
else else
@ -213,7 +239,7 @@ namespace VPet_Simulator.Core
private void DisplaySquating() private void DisplaySquating()
{ {
if (Function.Rnd.Next(++looptimes) > LoopProMax) if (Function.Rnd.Next(++looptimes) > LoopProMax)
Display(GraphCore.GraphType.Squat_C_End, DisplayNomal); Display(GraphCore.GraphType.Squat_C_End, DisplayToNomal);
else else
Display(GraphCore.GraphType.Squat_B_Loop, DisplaySquating); Display(GraphCore.GraphType.Squat_B_Loop, DisplaySquating);
} }
@ -232,7 +258,7 @@ namespace VPet_Simulator.Core
private void DisplayBoringing() private void DisplayBoringing()
{ {
if (Function.Rnd.Next(++looptimes) > LoopProMax) if (Function.Rnd.Next(++looptimes) > LoopProMax)
Display(GraphCore.GraphType.Boring_C_End, DisplayNomal); Display(GraphCore.GraphType.Boring_C_End, DisplayToNomal);
else else
Display(GraphCore.GraphType.Boring_B_Loop, DisplayBoringing); Display(GraphCore.GraphType.Boring_B_Loop, DisplayBoringing);
} }
@ -246,7 +272,10 @@ namespace VPet_Simulator.Core
looptimes = 0; looptimes = 0;
CountNomal = 0; CountNomal = 0;
if (force) if (force)
{
State = WorkingState.Sleep;
Display(GraphCore.GraphType.Sleep_A_Start, DisplaySleepingForce); Display(GraphCore.GraphType.Sleep_A_Start, DisplaySleepingForce);
}
else else
Display(GraphCore.GraphType.Sleep_A_Start, DisplaySleeping); Display(GraphCore.GraphType.Sleep_A_Start, DisplaySleeping);
} }
@ -256,7 +285,7 @@ namespace VPet_Simulator.Core
private void DisplaySleeping() private void DisplaySleeping()
{ {
if (Function.Rnd.Next(++looptimes) > LoopProMax) if (Function.Rnd.Next(++looptimes) > LoopProMax)
Display(GraphCore.GraphType.Sleep_C_End, DisplayNomal); Display(GraphCore.GraphType.Sleep_C_End, DisplayToNomal);
else else
Display(GraphCore.GraphType.Sleep_B_Loop, DisplaySleeping); Display(GraphCore.GraphType.Sleep_B_Loop, DisplaySleeping);
} }
@ -268,6 +297,51 @@ namespace VPet_Simulator.Core
Display(GraphCore.GraphType.Sleep_B_Loop, DisplaySleepingForce); Display(GraphCore.GraphType.Sleep_B_Loop, DisplaySleepingForce);
} }
/// <summary>
/// 显示工作情况
/// </summary>
public void DisplayWorkONE()
{
State = WorkingState.WorkONE;
Display(GraphCore.GraphType.WorkONE_A_Start, DisplayWorkONEing);
}
/// <summary>
/// 显示工作情况循环
/// </summary>
private void DisplayWorkONEing()
{
Display(GraphCore.GraphType.WorkONE_B_Loop, DisplayWorkONEing);
}
/// <summary>
/// 显示工作情况
/// </summary>
public void DisplayWorkTWO()
{
State = WorkingState.WorkTWO;
Display(GraphCore.GraphType.WorkTWO_A_Start, DisplayWorkTWOing);
}
/// <summary>
/// 显示工作情况循环
/// </summary>
private void DisplayWorkTWOing()
{
Display(GraphCore.GraphType.WorkTWO_B_Loop, DisplayWorkTWOing);
}
/// <summary>
/// 显示学习情况
/// </summary>
public void DisplayStudy()
{
State = WorkingState.Study;
Display(GraphCore.GraphType.Study_A_Start, DisplayStudying);
}
/// <summary>
/// 显示学习情况
/// </summary>
private void DisplayStudying()
{
Display(GraphCore.GraphType.Study_B_Loop, DisplayStudying);
}
/// <summary> /// <summary>
/// 显示拖拽情况 /// 显示拖拽情况
/// </summary> /// </summary>
@ -316,7 +390,7 @@ namespace VPet_Simulator.Core
public void DisplayFalled_Left() public void DisplayFalled_Left()
{ {
Display(GraphCore.GraphType.Fall_Left_C_End, Display(GraphCore.GraphType.Fall_Left_C_End,
() => Display(GraphCore.GraphType.Climb_Up_Left, DisplayNomal)); () => Display(GraphCore.GraphType.Climb_Up_Left, DisplayToNomal));
} }
/// <summary> /// <summary>
/// 显示掉到地上 从左边 /// 显示掉到地上 从左边
@ -324,7 +398,7 @@ namespace VPet_Simulator.Core
public void DisplayFalled_Right() public void DisplayFalled_Right()
{ {
Display(GraphCore.GraphType.Fall_Right_C_End, Display(GraphCore.GraphType.Fall_Right_C_End,
() => Display(GraphCore.GraphType.Climb_Up_Right, DisplayNomal)); () => Display(GraphCore.GraphType.Climb_Up_Right, DisplayToNomal));
} }
/// <summary> /// <summary>
/// 显示向左走 (有判断) /// 显示向左走 (有判断)
@ -358,19 +432,19 @@ namespace VPet_Simulator.Core
DisplayFall_Left(() => DisplayFall_Left(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
}); });
return; return;
case 1: case 1:
DisplayFall_Right(() => DisplayFall_Right(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
}); });
return; return;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
return; return;
} }
} }
@ -388,19 +462,19 @@ namespace VPet_Simulator.Core
DisplayFall_Left(() => DisplayFall_Left(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
}); });
break; break;
case 1: case 1:
DisplayFall_Right(() => DisplayFall_Right(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
}); });
break; break;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
break; break;
} }
@ -438,19 +512,19 @@ namespace VPet_Simulator.Core
DisplayClimb_Right_UP(() => DisplayClimb_Right_UP(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Right_C_End, DisplayToNomal);
}); });
return; return;
case 1: case 1:
DisplayClimb_Right_DOWN(() => DisplayClimb_Right_DOWN(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Right_C_End, DisplayToNomal);
}); });
return; return;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Right_C_End, DisplayToNomal);
return; return;
} }
} }
@ -468,19 +542,19 @@ namespace VPet_Simulator.Core
DisplayFall_Left(() => DisplayFall_Left(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
}); });
break; break;
case 1: case 1:
DisplayFall_Right(() => DisplayFall_Right(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
}); });
break; break;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Walk_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Walk_Left_C_End, DisplayToNomal);
break; break;
} }
@ -517,19 +591,19 @@ namespace VPet_Simulator.Core
DisplayClimb_Left_UP(() => DisplayClimb_Left_UP(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayToNomal);
}); });
return; return;
case 1: case 1:
DisplayClimb_Left_DOWN(() => DisplayClimb_Left_DOWN(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayToNomal);
}); });
return; return;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayToNomal);
return; return;
} }
} }
@ -541,7 +615,7 @@ namespace VPet_Simulator.Core
else else
{//停下来 {//停下来
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Left_C_End, DisplayToNomal);
} }
} }
/// <summary> /// <summary>
@ -575,19 +649,19 @@ namespace VPet_Simulator.Core
DisplayClimb_Right_UP(() => DisplayClimb_Right_UP(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayToNomal);
}); });
return; return;
case 1: case 1:
DisplayClimb_Right_DOWN(() => DisplayClimb_Right_DOWN(() =>
{ {
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayToNomal);
}); });
return; return;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayToNomal);
return; return;
} }
} }
@ -599,7 +673,7 @@ namespace VPet_Simulator.Core
else else
{//停下来 {//停下来
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayNomal); Display(GraphCore.GraphType.Crawl_Right_C_End, DisplayToNomal);
} }
} }
/// <summary> /// <summary>
@ -641,7 +715,7 @@ namespace VPet_Simulator.Core
return; return;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
return; return;
} }
} }
@ -659,7 +733,7 @@ namespace VPet_Simulator.Core
break; break;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
break; break;
} }
} }
@ -695,7 +769,7 @@ namespace VPet_Simulator.Core
if (Core.Controller.GetWindowsDistanceDown() < DistanceMin * Core.Controller.ZoomRatio) if (Core.Controller.GetWindowsDistanceDown() < DistanceMin * Core.Controller.ZoomRatio)
{//是,停下恢复默认 {//是,停下恢复默认
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
} }
//不是:继续or停下 //不是:继续or停下
if (Function.Rnd.Next(walklength++) < LoopMin) if (Function.Rnd.Next(walklength++) < LoopMin)
@ -705,7 +779,7 @@ namespace VPet_Simulator.Core
else else
{//停下来 {//停下来
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
} }
} }
/// <summary> /// <summary>
@ -748,7 +822,7 @@ namespace VPet_Simulator.Core
return; return;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
return; return;
} }
} }
@ -766,7 +840,7 @@ namespace VPet_Simulator.Core
break; break;
default: default:
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
break; break;
} }
} }
@ -802,7 +876,7 @@ namespace VPet_Simulator.Core
if (Core.Controller.GetWindowsDistanceDown() < DistanceMin * Core.Controller.ZoomRatio) if (Core.Controller.GetWindowsDistanceDown() < DistanceMin * Core.Controller.ZoomRatio)
{//是,停下恢复默认 {//是,停下恢复默认
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
} }
//不是:继续or停下 //不是:继续or停下
if (Function.Rnd.Next(walklength++) < LoopMin) if (Function.Rnd.Next(walklength++) < LoopMin)
@ -812,7 +886,7 @@ namespace VPet_Simulator.Core
else else
{//停下来 {//停下来
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayNomal(); DisplayToNomal();
} }
} }
/// <summary> /// <summary>
@ -978,7 +1052,7 @@ namespace VPet_Simulator.Core
//Core.Controller.MoveWindows(0, -Core.Controller.GetWindowsDistanceUp() / Core.Controller.ZoomRatio); //Core.Controller.MoveWindows(0, -Core.Controller.GetWindowsDistanceUp() / Core.Controller.ZoomRatio);
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayFalled_Left(); DisplayFalled_Left();
//DisplayNomal(); //DisplayToNomal();
} }
} }
@ -1041,7 +1115,7 @@ namespace VPet_Simulator.Core
//Core.Controller.MoveWindows(0, -Core.Controller.GetWindowsDistanceUp() / Core.Controller.ZoomRatio); //Core.Controller.MoveWindows(0, -Core.Controller.GetWindowsDistanceUp() / Core.Controller.ZoomRatio);
MoveTimer.Enabled = false; MoveTimer.Enabled = false;
DisplayFalled_Right(); DisplayFalled_Right();
//DisplayNomal(); //DisplayToNomal();
} }
} }
@ -1052,10 +1126,10 @@ namespace VPet_Simulator.Core
/// </summary> /// </summary>
/// <param name="Type">动画类型</param> /// <param name="Type">动画类型</param>
/// <param name="EndAction">动画结束后操作</param> /// <param name="EndAction">动画结束后操作</param>
/// <param name="storernd">是否储存随机数字典</param> ///// <param name="storernd">是否储存随机数字典</param>
public void Display(GraphType Type, Action EndAction = null, bool storernd = false) public void Display(GraphType Type, Action EndAction = null)
{ {
Display(Core.Graph.FindGraph(Type, Core.Save.Mode, storernd), EndAction); Display(Core.Graph.FindGraph(Type, Core.Save.Mode), EndAction);
} }
bool petgridcrlf = true; bool petgridcrlf = true;
/// <summary> /// <summary>

View File

@ -63,6 +63,23 @@ namespace VPet_Simulator.Core
public void FunctionSpend(double TimePass) public void FunctionSpend(double TimePass)
{ {
Core.Save.CleanChange(); Core.Save.CleanChange();
switch (State)
{
case WorkingState.Sleep:
//睡觉消耗
if (Core.Save.StrengthFood >= 25)
{
Core.Save.StrengthChange(TimePass * 2);
if (Core.Save.StrengthFood >= 75)
Core.Save.Health += TimePass / 2;
}
break;
case WorkingState.WorkONE:
case WorkingState.WorkTWO:
case WorkingState.Study:
break;
//工作/娱乐等消耗
default://默认
//饮食等乱七八糟的消耗 //饮食等乱七八糟的消耗
if (Core.Save.StrengthFood >= 50) if (Core.Save.StrengthFood >= 50)
{ {
@ -74,6 +91,10 @@ namespace VPet_Simulator.Core
{ {
Core.Save.Health -= Function.Rnd.Next(0, 1) * TimePass; Core.Save.Health -= Function.Rnd.Next(0, 1) * TimePass;
} }
break;
}
//if (Core.GameSave.Strength <= 40) //if (Core.GameSave.Strength <= 40)
//{ //{
// Core.GameSave.Health -= Function.Rnd.Next(0, 1); // Core.GameSave.Health -= Function.Rnd.Next(0, 1);
@ -243,5 +264,39 @@ namespace VPet_Simulator.Core
MoveTimer.AutoReset = false; MoveTimer.AutoReset = false;
} }
} }
/// <summary>
/// 当前状态
/// </summary>
public WorkingState State = WorkingState.Nomal;
/// <summary>
/// 当前正在的状态
/// </summary>
public enum WorkingState
{
/// <summary>
/// 默认:啥都没干
/// </summary>
Nomal,
/// <summary>
/// 正在干活1
/// </summary>
WorkONE,
/// <summary>
/// 正在干活1
/// </summary>
WorkTWO,
/// <summary>
/// 学习中
/// </summary>
Study,
/// <summary>
/// 睡觉
/// </summary>
Sleep,
///// <summary>
///// 玩耍中
///// </summary>
//Playing,
}
} }
} }

View File

@ -61,7 +61,7 @@ namespace VPet_Simulator.Core
{ {
Thread.Sleep(timeleft * 50); Thread.Sleep(timeleft * 50);
if (sayType != GraphCore.Helper.SayType.None && m.DisplayType.ToString().StartsWith("Say")) if (sayType != GraphCore.Helper.SayType.None && m.DisplayType.ToString().StartsWith("Say"))
m.Display(GraphCore.Helper.Convert(sayType, GraphCore.Helper.AnimatType.C_End), m.DisplayNomal); m.Display(GraphCore.Helper.Convert(sayType, GraphCore.Helper.AnimatType.C_End), m.DisplayToNomal);
}); });
ShowTimer.Stop(); ShowTimer.Stop();
EndTimer.Start(); EndTimer.Start();

View File

@ -94,28 +94,30 @@
Foreground="{DynamicResource DARKPrimary}" /> Foreground="{DynamicResource DARKPrimary}" />
</Grid> </Grid>
</Border> </Border>
<Menu Width="500" VerticalAlignment="Bottom" Style="{DynamicResource ToolBarMenuStyle}"> <Menu VerticalAlignment="Bottom" Style="{DynamicResource ToolBarMenuStyle}" Width="500">
<Menu.ItemsPanel> <Menu.ItemsPanel>
<ItemsPanelTemplate> <ItemsPanelTemplate>
<UniformGrid Columns="5" /> <UniformGrid Columns="5" />
</ItemsPanelTemplate> </ItemsPanelTemplate>
</Menu.ItemsPanel> </Menu.ItemsPanel>
<MenuItem x:Name="MenuFeed" Header="投喂" HorizontalContentAlignment="Center" > <MenuItem x:Name="MenuFeed" Header="投喂" HorizontalContentAlignment="Center" Width="99" Padding="0">
<MenuItem Header="食物" HorizontalContentAlignment="Center" IsEnabled="False" /> <MenuItem Header="食物" HorizontalContentAlignment="Center" IsEnabled="False" />
<MenuItem Header="饮料" HorizontalContentAlignment="Center" IsEnabled="False" /> <MenuItem Header="饮料" HorizontalContentAlignment="Center" IsEnabled="False" />
<MenuItem Header="药品" HorizontalContentAlignment="Center" IsEnabled="False"/> <MenuItem Header="药品" HorizontalContentAlignment="Center" IsEnabled="False"/>
</MenuItem> </MenuItem>
<MenuItem x:Name="MenuPanel" Header="面板" MouseEnter="MenuPanel_MouseEnter" MouseLeave="MenuPanel_MouseLeave" <MenuItem x:Name="MenuPanel" Header="面板" MouseEnter="MenuPanel_MouseEnter" MouseLeave="MenuPanel_MouseLeave"
HorizontalContentAlignment="Center" /> HorizontalContentAlignment="Center" Width="99" Padding="0" />
<MenuItem x:Name="MenuInteract" Header="互动" HorizontalContentAlignment="Center"> <MenuItem x:Name="MenuInteract" Header="互动" HorizontalContentAlignment="Center" Width="99" Padding="0">
<MenuItem Header="睡觉" HorizontalContentAlignment="Center" Click="Sleep_Click" /> <MenuItem Header="睡觉" HorizontalContentAlignment="Center" Click="Sleep_Click" />
<MenuItem Header="玩耍" HorizontalContentAlignment="Center" IsEnabled="False"/> <MenuItem Header="学习" HorizontalContentAlignment="Center" Click="Study_Click" />
<MenuItem x:Name="MenuWork1" Header="工作1" HorizontalContentAlignment="Center" Click="Work1_Click" />
<MenuItem x:Name="MenuWork2" Header="工作2" HorizontalContentAlignment="Center" Click="Work2_Click" />
<MenuItem Header="说话" HorizontalContentAlignment="Center" IsEnabled="False" /> <MenuItem Header="说话" HorizontalContentAlignment="Center" IsEnabled="False" />
<MenuItem Header="学习" HorizontalContentAlignment="Center" IsEnabled="False" />
</MenuItem> </MenuItem>
<MenuItem x:Name="MenuDIY" Header="自定" HorizontalContentAlignment="Center" Click="MenuDIY_Click" <MenuItem x:Name="MenuDIY" Header="自定" HorizontalContentAlignment="Center" Click="MenuDIY_Click"
x:FieldModifier="public" /> x:FieldModifier="public" Width="99" Padding="0" />
<MenuItem x:Name="MenuSetting" Header="系统" HorizontalContentAlignment="Center" x:FieldModifier="public"/> <MenuItem x:Name="MenuSetting" Header="系统" HorizontalContentAlignment="Center" x:FieldModifier="public"
Width="99" Padding="0" />
</Menu> </Menu>
</Grid> </Grid>
</UserControl> </UserControl>

View File

@ -260,7 +260,39 @@ namespace VPet_Simulator.Core
private void Sleep_Click(object sender, RoutedEventArgs e) private void Sleep_Click(object sender, RoutedEventArgs e)
{ {
if (m.Core.Save.Mode != GameSave.ModeType.Ill)
if (m.State == Main.WorkingState.Sleep)
m.Display(GraphCore.GraphType.Sleep_C_End, m.DisplayNomal);
else
m.DisplaySleep(true); m.DisplaySleep(true);
this.Visibility = Visibility.Collapsed;
}
private void Study_Click(object sender, RoutedEventArgs e)
{
if (m.Core.Save.Mode != GameSave.ModeType.Ill)
if (m.State == Main.WorkingState.Study)
m.Display(GraphCore.GraphType.Study_C_End, m.DisplayNomal);
else m.DisplayStudy();
this.Visibility = Visibility.Collapsed;
}
private void Work1_Click(object sender, RoutedEventArgs e)
{
if (m.Core.Save.Mode != GameSave.ModeType.Ill)
if (m.State == Main.WorkingState.WorkONE)
m.Display(GraphCore.GraphType.WorkONE_C_End, m.DisplayNomal);
else m.DisplayWorkONE();
this.Visibility = Visibility.Collapsed;
}
private void Work2_Click(object sender, RoutedEventArgs e)
{
if (m.Core.Save.Mode != GameSave.ModeType.Ill)
if (m.State == Main.WorkingState.WorkTWO)
m.Display(GraphCore.GraphType.WorkTWO_C_End, m.DisplayNomal);
else m.DisplayWorkTWO();
this.Visibility = Visibility.Collapsed;
} }
} }
} }

View File

@ -275,6 +275,42 @@ namespace VPet_Simulator.Core
/// 关机 /// 关机
/// </summary> /// </summary>
Shutdown, Shutdown,
/// <summary>
/// 学习 (开始)
/// </summary>
Study_A_Start,
/// <summary>
/// 学习 (循环)
/// </summary>
Study_B_Loop,
/// <summary>
/// 学习 (结束)
/// </summary>
Study_C_End,
/// <summary>
/// 工作 (开始)
/// </summary>
WorkONE_A_Start,
/// <summary>
/// 工作 (循环)
/// </summary>
WorkONE_B_Loop,
/// <summary>
/// 工作 (结束)
/// </summary>
WorkONE_C_End,
/// <summary>
/// 直播 (开始)
/// </summary>
WorkTWO_A_Start,
/// <summary>
/// 直播 (循环)
/// </summary>
WorkTWO_B_Loop,
/// <summary>
/// 直播 (结束)
/// </summary>
WorkTWO_C_End,
} }
/// <summary> /// <summary>
@ -337,9 +373,9 @@ namespace VPet_Simulator.Core
/// </summary> /// </summary>
/// <param name="type">动画类型</param> /// <param name="type">动画类型</param>
/// <param name="mode">状态类型,找不到就找相同动画类型</param> /// <param name="mode">状态类型,找不到就找相同动画类型</param>
/// <param name="storernd">是否储存随机数字典</param> ///// <param name="storernd">是否储存随机数字典</param>
/// <returns></returns> /// <returns></returns>
public IGraph FindGraph(GraphType type, GameSave.ModeType mode, bool storernd = false) public IGraph FindGraph(GraphType type, GameSave.ModeType mode)
{ {
if (Graphs.ContainsKey(type)) if (Graphs.ContainsKey(type))
{ {
@ -348,7 +384,7 @@ namespace VPet_Simulator.Core
{ {
if (list.Count == 1) if (list.Count == 1)
return list[0]; return list[0];
if (storernd) if (GraphConfig.StoreRnd.Contains(type.ToString()))
if (RndGraph.TryGetValue(list.Count, out int index)) if (RndGraph.TryGetValue(list.Count, out int index))
{ {
return list[index]; return list[index];
@ -453,8 +489,8 @@ namespace VPet_Simulator.Core
/// 定位爬行上边距离 /// 定位爬行上边距离
/// </summary> /// </summary>
public double LocateClimbTop; public double LocateClimbTop;
public List<string> StoreRnd = new List<string>();
public ILine Str;
/// <summary> /// <summary>
/// 初始化设置 /// 初始化设置
/// </summary> /// </summary>
@ -484,6 +520,12 @@ namespace VPet_Simulator.Core
LocateClimbLeft = s[(gdbe)"climbleft"]; LocateClimbLeft = s[(gdbe)"climbleft"];
LocateClimbRight = s[(gdbe)"climbright"]; LocateClimbRight = s[(gdbe)"climbright"];
LocateClimbTop = s[(gdbe)"climbtop"]; LocateClimbTop = s[(gdbe)"climbtop"];
foreach (Sub sub in lps["storernd"])
{
StoreRnd.Add(sub.Name);
}
Str = lps["str"];
} }
/// <summary> /// <summary>
/// 加载更多设置,新的替换后来的,允许空内容 /// 加载更多设置,新的替换后来的,允许空内容
@ -526,6 +568,16 @@ namespace VPet_Simulator.Core
LocateClimbRight = s.GetDouble("climbright", LocateClimbRight); LocateClimbRight = s.GetDouble("climbright", LocateClimbRight);
LocateClimbTop = s.GetDouble("climbtop", LocateClimbTop); LocateClimbTop = s.GetDouble("climbtop", LocateClimbTop);
} }
foreach (Sub sub in lps["storernd"])
{
if (!StoreRnd.Contains(sub.Name))
StoreRnd.Add(sub.Name);
}
foreach(Sub sub in lps["str"])
{
if (!Str.Contains(sub.Name))
Str.Add(sub);
}
} }
} }

View File

@ -32,9 +32,9 @@ namespace VPet_Simulator.Core
if (!GraphCore.CommConfig.ContainsKey("PIC_Setup")) if (!GraphCore.CommConfig.ContainsKey("PIC_Setup"))
{ {
GraphCore.CommConfig["PIC_Setup"] = true; GraphCore.CommConfig["PIC_Setup"] = true;
GraphCore.CommUIElements["Image1.Picture"] = new System.Windows.Controls.Image() { Width = 500, Height = 500 }; GraphCore.CommUIElements["Image1.Picture"] = new Image() { Width = 500, Height = 500 };
GraphCore.CommUIElements["Image2.Picture"] = new System.Windows.Controls.Image() { Width = 500, Height = 500 }; GraphCore.CommUIElements["Image2.Picture"] = new Image() { Width = 500, Height = 500 };
GraphCore.CommUIElements["Image3.Picture"] = new System.Windows.Controls.Image() { Width = 500, Height = 500 }; GraphCore.CommUIElements["Image3.Picture"] = new Image() { Width = 500, Height = 500 };
} }
} }
/// <summary> /// <summary>
@ -59,14 +59,14 @@ namespace VPet_Simulator.Core
{ {
if (parant.Tag != this) if (parant.Tag != this)
{ {
System.Windows.Controls.Image img; Image img;
if (parant.Child == GraphCore.CommUIElements["Image1.Picture"]) if (parant.Child == GraphCore.CommUIElements["Image1.Picture"])
{ {
img = (System.Windows.Controls.Image)GraphCore.CommUIElements["Image1.Picture"]; img = (Image)GraphCore.CommUIElements["Image1.Picture"];
} }
else else
{ {
img = (System.Windows.Controls.Image)GraphCore.CommUIElements["Image2.Picture"]; img = (Image)GraphCore.CommUIElements["Image2.Picture"];
if (parant.Child != GraphCore.CommUIElements["Image2.Picture"]) if (parant.Child != GraphCore.CommUIElements["Image2.Picture"])
{ {
if (img.Parent == null) if (img.Parent == null)
@ -75,7 +75,7 @@ namespace VPet_Simulator.Core
} }
else else
{ {
img = (System.Windows.Controls.Image)GraphCore.CommUIElements["Image3.Picture"]; img = (Image)GraphCore.CommUIElements["Image3.Picture"];
parant.Child = img; parant.Child = img;
} }
} }

View File

@ -239,27 +239,6 @@ namespace VPet_Simulator.Core
//save.SetFloat("Likability", Likability); //save.SetFloat("Likability", Likability);
return LPSConvert.SerializeObject(this, "vpet"); return LPSConvert.SerializeObject(this, "vpet");
} }
/// <summary>
/// 当前正在的状态
/// </summary>
public enum WorkingState
{
/// <summary>
/// 默认:啥都没干
/// </summary>
Nomal,
/// <summary>
/// 正在干活, workingobj指示正在干啥活
/// </summary>
Working,
/// <summary>
/// 学习中
/// </summary>
Studying,
/// <summary>
/// 玩耍中
/// </summary>
Playing,
}
} }
} }

View File

@ -63,7 +63,7 @@ namespace VPet_Simulator.Windows
public int PressLength => mw.Set.PressLength; public int PressLength => mw.Set.PressLength;
public bool EnableFunction => mw.Set.EnableFunction; public bool EnableFunction => false;// mw.Set.EnableFunction;
public int InteractionCycle => mw.Set.InteractionCycle; public int InteractionCycle => mw.Set.InteractionCycle;

View File

@ -68,7 +68,11 @@ namespace VPet_Simulator.Windows
{ {
Main.ToolBar.MenuDIY.Items.Clear(); Main.ToolBar.MenuDIY.Items.Clear();
foreach (Sub sub in Set["diy"]) foreach (Sub sub in Set["diy"])
Main.ToolBar.AddMenuButton(ToolBar.MenuType.DIY, sub.Name, () => RunDIY(sub.Info)); Main.ToolBar.AddMenuButton(ToolBar.MenuType.DIY, sub.Name, () =>
{
Main.ToolBar.Visibility = Visibility.Collapsed;
RunDIY(sub.Info);
});
try try
{ {
//加载游戏创意工坊插件 //加载游戏创意工坊插件

View File

@ -254,11 +254,13 @@ namespace VPet_Simulator.Windows
} }
Dispatcher.Invoke(() => LoadingText.Visibility = Visibility.Collapsed); Dispatcher.Invoke(() => LoadingText.Visibility = Visibility.Collapsed);
}); });
Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "退出桌宠", () => { Close(); });
Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "开发控制台", () => { new winConsole(this).Show(); }); Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "退出桌宠", () => { Main.ToolBar.Visibility = Visibility.Collapsed; Close(); });
Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "反馈中心", () => { new winReport(this).Show(); }); Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "开发控制台", () => { Main.ToolBar.Visibility = Visibility.Collapsed; new winConsole(this).Show(); });
Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "反馈中心", () => { Main.ToolBar.Visibility = Visibility.Collapsed; new winReport(this).Show(); });
Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "设置面板", () => Main.ToolBar.AddMenuButton(VPet_Simulator.Core.ToolBar.MenuType.Setting, "设置面板", () =>
{ {
Main.ToolBar.Visibility = Visibility.Collapsed;
Topmost = false; Topmost = false;
winSetting.Show(); winSetting.Show();
}); });
@ -275,7 +277,7 @@ namespace VPet_Simulator.Windows
m_menu.MenuItems.Add(new MenuItem("重置状态", (x, y) => m_menu.MenuItems.Add(new MenuItem("重置状态", (x, y) =>
{ {
Main.CleanState(); Main.CleanState();
Main.DisplayNomal(); Main.DisplayToNomal();
Left = (SystemParameters.PrimaryScreenWidth - Width) / 2; Left = (SystemParameters.PrimaryScreenWidth - Width) / 2;
Top = (SystemParameters.PrimaryScreenHeight - Height) / 2; Top = (SystemParameters.PrimaryScreenHeight - Height) / 2;
})); }));

View File

@ -13,8 +13,7 @@
</DataTemplate> </DataTemplate>
</pu:WindowX.Resources>--> </pu:WindowX.Resources>-->
<Grid> <Grid>
<TabControl Margin="5" BorderThickness="0" pu:TabControlHelper.ItemsHeight="NaN" <TabControl Margin="5" BorderThickness="0" pu:TabControlHelper.ItemsHeight="NaN" Background="Transparent"
Background="Transparent"
pu:TabControlHelper.ItemsPadding="10,7" pu:TabControlHelper.ItemsCornerRadius="4" pu:TabControlHelper.ItemsPadding="10,7" pu:TabControlHelper.ItemsCornerRadius="4"
pu:TabControlHelper.ItemsHoverBackground="{DynamicResource PrimaryLight}" pu:TabControlHelper.ItemsHoverBackground="{DynamicResource PrimaryLight}"
pu:TabControlHelper.ItemsSelectedBackground="{DynamicResource PrimaryDark}" pu:TabControlHelper.ItemsSelectedBackground="{DynamicResource PrimaryDark}"
@ -50,16 +49,14 @@
</Grid.RowDefinitions> </Grid.RowDefinitions>
<TextBlock Text="置于顶层" VerticalAlignment="Center" /> <TextBlock Text="置于顶层" VerticalAlignment="Center" />
<pu:Switch x:Name="TopMostBox" Grid.Column="2" BorderBrush="{DynamicResource PrimaryDark}" <pu:Switch x:Name="TopMostBox" Grid.Column="2" BorderBrush="{DynamicResource PrimaryDark}"
CheckedBackground="{DynamicResource Primary}" CheckedBackground="{DynamicResource Primary}" CheckedBorderBrush="{DynamicResource Primary}"
CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35" Background="Transparent" BoxWidth="35" BoxHeight="18" ToggleSize="14"
BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}" ToggleShadowColor="{x:Null}" ToggleBrush="{DynamicResource PrimaryDark}"
ToggleBrush="{DynamicResource PrimaryDark}"
CheckedToggleBrush="{DynamicResource DARKPrimaryText}" Checked="TopMostBox_Checked" CheckedToggleBrush="{DynamicResource DARKPrimaryText}" Checked="TopMostBox_Checked"
Unchecked="TopMostBox_Unchecked" ToolTip="将桌宠置于顶层" /> Unchecked="TopMostBox_Unchecked" ToolTip="将桌宠置于顶层" />
<TextBlock Grid.Row="1" Text="更高缩放" VerticalAlignment="Center" /> <TextBlock Grid.Row="1" Text="更高缩放" VerticalAlignment="Center" />
<pu:Switch x:Name="FullScreenBox" Grid.Row="1" Grid.Column="2" <pu:Switch x:Name="FullScreenBox" Grid.Row="1" Grid.Column="2"
BorderBrush="{DynamicResource PrimaryDark}" BorderBrush="{DynamicResource PrimaryDark}" CheckedBackground="{DynamicResource Primary}"
CheckedBackground="{DynamicResource Primary}"
CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35" CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35"
BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}"
ToggleBrush="{DynamicResource PrimaryDark}" ToggleBrush="{DynamicResource PrimaryDark}"
@ -78,8 +75,7 @@
PreviewMouseUp="ZoomSlider_MouseUp" /> PreviewMouseUp="ZoomSlider_MouseUp" />
<TextBlock Grid.Column="1" Margin="15,0,0,0" VerticalAlignment="Center" <TextBlock Grid.Column="1" Margin="15,0,0,0" VerticalAlignment="Center"
Text="{Binding ElementName=ZoomSlider,Path=Value,StringFormat=f2}" FontSize="18" Text="{Binding ElementName=ZoomSlider,Path=Value,StringFormat=f2}" FontSize="18"
Foreground="{DynamicResource DARKPrimaryDarker}" FontWeight="Bold" Foreground="{DynamicResource DARKPrimaryDarker}" FontWeight="Bold" Background="{x:Null}" />
Background="{x:Null}" />
</Grid> </Grid>
<TextBlock Grid.Row="3" Text="主题" VerticalAlignment="Center" /> <TextBlock Grid.Row="3" Text="主题" VerticalAlignment="Center" />
<ComboBox x:Name="ThemeBox" Grid.Row="3" Grid.Column="2" <ComboBox x:Name="ThemeBox" Grid.Row="3" Grid.Column="2"
@ -87,9 +83,9 @@
Style="{DynamicResource StandardComboBoxStyle}" Margin="0,3,0,2" FontSize="16" /> Style="{DynamicResource StandardComboBoxStyle}" Margin="0,3,0,2" FontSize="16" />
<TextBlock Grid.Row="4" Text="字体" VerticalAlignment="Center" /> <TextBlock Grid.Row="4" Text="字体" VerticalAlignment="Center" />
<ComboBox x:Name="FontBox" Grid.Row="4" Grid.Column="2" <ComboBox x:Name="FontBox" Grid.Row="4" Grid.Column="2" SelectionChanged="FontBox_SelectionChanged"
SelectionChanged="FontBox_SelectionChanged" IsEnabled="False" IsEnabled="False" Style="{DynamicResource StandardComboBoxStyle}" FontSize="16"
Style="{DynamicResource StandardComboBoxStyle}" FontSize="16" Margin="0,2,0,3" /> Margin="0,2,0,3" />
<TextBlock Grid.Row="5" Text="启动位置" VerticalAlignment="Center" /> <TextBlock Grid.Row="5" Text="启动位置" VerticalAlignment="Center" />
<Grid Grid.Row="5" Grid.Column="2"> <Grid Grid.Row="5" Grid.Column="2">
<Grid.ColumnDefinitions> <Grid.ColumnDefinitions>
@ -100,20 +96,23 @@
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<pu:Switch x:Name="StartPlace" BorderBrush="{DynamicResource PrimaryDark}" <pu:Switch x:Name="StartPlace" BorderBrush="{DynamicResource PrimaryDark}"
CheckedBackground="{DynamicResource Primary}" IsChecked="True" CheckedBackground="{DynamicResource Primary}" IsChecked="True"
CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35"
BoxWidth="35" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}"
ToggleBrush="{DynamicResource PrimaryDark}" Content="退出位置" ToggleBrush="{DynamicResource PrimaryDark}" Content="退出位置"
CheckedToggleBrush="{DynamicResource DARKPrimaryText}" ToolTip="该游戏随着开机启动该程序" CheckedToggleBrush="{DynamicResource DARKPrimaryText}" ToolTip="该游戏随着开机启动该程序"
Unchecked="StartPlace_Checked" VerticalAlignment="Center" Checked="StartPlace_Checked" /> Unchecked="StartPlace_Checked" VerticalAlignment="Center" Checked="StartPlace_Checked" />
<TextBox x:Name="TextBoxStartUpX" Grid.Column="1" Style="{DynamicResource StandardTextBoxStyle}" ToolTip="X轴" pu:TextBoxHelper.Icon="X" <TextBox x:Name="TextBoxStartUpX" Grid.Column="1" Style="{DynamicResource StandardTextBoxStyle}"
FontSize="16" Margin="0,0,5,0" pu:TextBoxHelper.InputLimit="Digit" pu:TextBoxHelper.Watermark="X轴" ToolTip="X轴" pu:TextBoxHelper.Icon="X" FontSize="16" Margin="0,0,5,0"
pu:TextBoxHelper.InputLimit="Digit" pu:TextBoxHelper.Watermark="X轴"
TextChanged="TextBoxStartUp_TextChanged" pu:IconHelper.Margin="5,0,0,0" /> TextChanged="TextBoxStartUp_TextChanged" pu:IconHelper.Margin="5,0,0,0" />
<TextBox x:Name="TextBoxStartUpY" Grid.Column="2" Style="{DynamicResource StandardTextBoxStyle}" ToolTip="Y轴" pu:TextBoxHelper.Icon="Y" <TextBox x:Name="TextBoxStartUpY" Grid.Column="2" Style="{DynamicResource StandardTextBoxStyle}"
FontSize="16" pu:TextBoxHelper.InputLimit="Digit" pu:TextBoxHelper.Watermark="Y轴" Margin="0,0,5,0" ToolTip="Y轴" pu:TextBoxHelper.Icon="Y" FontSize="16" pu:TextBoxHelper.InputLimit="Digit"
pu:TextBoxHelper.Watermark="Y轴" Margin="0,0,5,0"
TextChanged="TextBoxStartUp_TextChanged" pu:IconHelper.Margin="5,0,0,0" /> TextChanged="TextBoxStartUp_TextChanged" pu:IconHelper.Margin="5,0,0,0" />
<Button x:Name="BtnStartUpGet" pu:ButtonHelper.CornerRadius="4" Content="当前位置" Grid.Column="3" <Button x:Name="BtnStartUpGet" pu:ButtonHelper.CornerRadius="4" Content="当前位置" Grid.Column="3"
Background="{DynamicResource SecondaryLight}" HorizontalAlignment="Center" Background="{DynamicResource SecondaryLight}" HorizontalAlignment="Center"
VerticalAlignment="Center" Height="30" BorderBrush="{DynamicResource SecondaryDark}" BorderThickness="2" Click="BtnStartUpGet_Click"/> VerticalAlignment="Center" Height="30" BorderBrush="{DynamicResource SecondaryDark}"
BorderThickness="2" Click="BtnStartUpGet_Click" />
</Grid> </Grid>
<TextBlock Grid.Row="7" Text="开机启动" VerticalAlignment="Center" /> <TextBlock Grid.Row="7" Text="开机启动" VerticalAlignment="Center" />
@ -124,29 +123,30 @@
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<pu:Switch x:Name="StartUpBox" BorderBrush="{DynamicResource PrimaryDark}" <pu:Switch x:Name="StartUpBox" BorderBrush="{DynamicResource PrimaryDark}"
CheckedBackground="{DynamicResource Primary}" CheckedBackground="{DynamicResource Primary}"
CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35"
BoxWidth="35" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}"
ToggleBrush="{DynamicResource PrimaryDark}" Content="开机启动" ToggleBrush="{DynamicResource PrimaryDark}" Content="开机启动"
CheckedToggleBrush="{DynamicResource DARKPrimaryText}" ToolTip="该游戏随着开机启动该程序" CheckedToggleBrush="{DynamicResource DARKPrimaryText}" ToolTip="该游戏随着开机启动该程序"
Checked="StartUpBox_Checked" Unchecked="StartUpBox_Checked" /> Checked="StartUpBox_Checked" Unchecked="StartUpBox_Checked" />
<pu:Switch x:Name="StartUpSteamBox" BorderBrush="{DynamicResource PrimaryDark}" <pu:Switch x:Name="StartUpSteamBox" BorderBrush="{DynamicResource PrimaryDark}"
CheckedBackground="{DynamicResource Primary}" CheckedBackground="{DynamicResource Primary}"
IsEnabled="{Binding ElementName=StartUpBox,Path=IsChecked}" IsEnabled="{Binding ElementName=StartUpBox,Path=IsChecked}"
CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35"
BoxWidth="35" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}"
ToggleBrush="{DynamicResource PrimaryDark}" Content="从Steam启动" ToggleBrush="{DynamicResource PrimaryDark}" Content="从Steam启动"
CheckedToggleBrush="{DynamicResource DARKPrimaryText}" CheckedToggleBrush="{DynamicResource DARKPrimaryText}" ToolTip="从Steam启动该游戏, 统计时长不能停"
ToolTip="从Steam启动该游戏, 统计时长不能停" Grid.Column="1" Checked="StartUpSteamBox_Checked" Grid.Column="1" Checked="StartUpSteamBox_Checked" Unchecked="StartUpSteamBox_Checked" />
Unchecked="StartUpSteamBox_Checked" />
</Grid> </Grid>
<TextBlock Grid.Row="8" Text="宠物动画" VerticalAlignment="Center" /> <TextBlock Grid.Row="8" Text="宠物动画" VerticalAlignment="Center" />
<TextBlock x:Name="PetIntor" Grid.Row="9" Text="动画描述动画描述动画描述动画描述动画描述" VerticalAlignment="Center" Grid.Column="2" TextWrapping="WrapWithOverflow" FontSize="14" /> <TextBlock x:Name="PetIntor" Grid.Row="9" Text="动画描述动画描述动画描述动画描述动画描述" VerticalAlignment="Center"
Grid.Column="2" TextWrapping="WrapWithOverflow" FontSize="14" />
<ComboBox x:Name="PetBox" Grid.Row="8" Grid.Column="2" ToolTip="加载的宠物动画,重启后生效" <ComboBox x:Name="PetBox" Grid.Row="8" Grid.Column="2" ToolTip="加载的宠物动画,重启后生效"
Style="{DynamicResource StandardComboBoxStyle}" Margin="0,3,0,2" SelectionChanged="PetBox_SelectionChanged" FontSize="16" /> Style="{DynamicResource StandardComboBoxStyle}" Margin="0,3,0,2"
SelectionChanged="PetBox_SelectionChanged" FontSize="16" />
<Button x:Name="ButtonRestartGraph" Content="重启软件以应用更改" Visibility="Collapsed" <Button x:Name="ButtonRestartGraph" Content="重启软件以应用更改" Visibility="Collapsed"
VerticalAlignment="Bottom" Background="{DynamicResource DARKPrimary}" VerticalAlignment="Bottom" Background="{DynamicResource DARKPrimary}"
Foreground="{DynamicResource DARKPrimaryText}" Foreground="{DynamicResource DARKPrimaryText}" Click="ButtonRestart_Click"
Click="ButtonRestart_Click" Grid.ColumnSpan="3" Grid.Row="10" /> Grid.ColumnSpan="3" Grid.Row="10" />
</Grid> </Grid>
</TabItem> </TabItem>
<TabItem Header="系统" BorderBrush="{DynamicResource PrimaryDarker}"> <TabItem Header="系统" BorderBrush="{DynamicResource PrimaryDarker}">
@ -207,16 +207,17 @@
</Grid.RowDefinitions> </Grid.RowDefinitions>
<TextBlock Grid.Row="0" Text="长按间隔" VerticalAlignment="Center" /> <TextBlock Grid.Row="0" Text="长按间隔" VerticalAlignment="Center" />
<TextBlock Grid.Row="1" Text="桌宠名字" VerticalAlignment="Center" /> <TextBlock Grid.Row="1" Text="桌宠名字" VerticalAlignment="Center" />
<TextBox x:Name="TextBoxPetName" Grid.Row="1" Grid.Column="2" Style="{DynamicResource StandardTextBoxStyle}" TextChanged="TextBoxPetName_TextChanged" FontSize="16"/> <TextBox x:Name="TextBoxPetName" Grid.Row="1" Grid.Column="2"
<Grid Grid.Column="2" Grid.Row="0" Style="{DynamicResource StandardTextBoxStyle}" TextChanged="TextBoxPetName_TextChanged"
ToolTip="数据计算和互动计算时间间隔,间隔越短需要互动的频率可能会增加.&#13;间隔越大越不容易打扰到当前工作"> FontSize="16" />
<Grid Grid.Column="2" Grid.Row="0" ToolTip="数据计算和互动计算时间间隔,间隔越短需要互动的频率可能会增加.&#13;间隔越大越不容易打扰到当前工作">
<Grid.ColumnDefinitions> <Grid.ColumnDefinitions>
<ColumnDefinition /> <ColumnDefinition />
<ColumnDefinition Width="Auto" /> <ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<Slider x:Name="PressLengthSlider" TickFrequency="0.01" IsSnapToTickEnabled="True" <Slider x:Name="PressLengthSlider" TickFrequency="0.01" IsSnapToTickEnabled="True"
Style="{DynamicResource StandardSliderStyle}" VerticalAlignment="Center" Style="{DynamicResource StandardSliderStyle}" VerticalAlignment="Center" Maximum="5"
Maximum="5" SmallChange=".05" Minimum="0.05" LargeChange="0.1" Value="0.5" SmallChange=".05" Minimum="0.05" LargeChange="0.1" Value="0.5"
ValueChanged="PressLengthSlider_ValueChanged" /> ValueChanged="PressLengthSlider_ValueChanged" />
<TextBlock Grid.Column="1" Margin="10,0,0,0" VerticalAlignment="Center" Width="60" <TextBlock Grid.Column="1" Margin="10,0,0,0" VerticalAlignment="Center" Width="60"
Text="{Binding ElementName=PressLengthSlider,Path=Value,StringFormat={}{0:f2} 秒}" Text="{Binding ElementName=PressLengthSlider,Path=Value,StringFormat={}{0:f2} 秒}"
@ -247,14 +248,15 @@
<ColumnDefinition Width="*" /> <ColumnDefinition Width="*" />
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<RadioButton x:Name="RBCGPTUseAPI" Style="{DynamicResource StandardRadioButtonStyle}" <RadioButton x:Name="RBCGPTUseAPI" Style="{DynamicResource StandardRadioButtonStyle}"
Content="使用从ChatGPT&#13;申请的的API" ToolTip="需要去OpenAI官网申请" Content="使用从ChatGPT&#13;申请的的API" ToolTip="需要去OpenAI官网申请" GroupName="cgpttype"
GroupName="cgpttype" Grid.Column="1" Checked="CGPType_Checked" /> Grid.Column="1" Checked="CGPType_Checked" />
<RadioButton x:Name="RBCGPTUseLB" Style="{DynamicResource StandardRadioButtonStyle}" <RadioButton x:Name="RBCGPTUseLB" Style="{DynamicResource StandardRadioButtonStyle}"
Content="使用桌宠开发者&#13;提供的免费API" ToolTip="需遵循相关协议法律法规并有聊天字数限制" Content="使用桌宠开发者&#13;提供的免费API" ToolTip="需遵循相关协议法律法规并有聊天字数限制" GroupName="cgpttype"
GroupName="cgpttype" IsChecked="True" Checked="CGPType_Checked" /> IsChecked="True" Checked="CGPType_Checked" />
</Grid> </Grid>
<Button x:Name="BtnCGPTReSet" pu:ButtonHelper.CornerRadius="4" Content="初始化桌宠聊天程序" Margin="4" Grid.Column="2" <Button x:Name="BtnCGPTReSet" pu:ButtonHelper.CornerRadius="4" Content="初始化桌宠聊天程序" Margin="4"
Background="{DynamicResource SecondaryLight}" Padding="1" Grid.Row="1" Click="ChatGPT_Reset_Click" /> Grid.Column="2" Background="{DynamicResource SecondaryLight}" Padding="1" Grid.Row="1"
Click="ChatGPT_Reset_Click" />
</Grid> </Grid>
</StackPanel> </StackPanel>
</TabItem> </TabItem>
@ -280,10 +282,10 @@
<RowDefinition Height="35" /> <RowDefinition Height="35" />
<RowDefinition Height="35" /> <RowDefinition Height="35" />
</Grid.RowDefinitions> </Grid.RowDefinitions>
<pu:Switch x:Name="CalFunctionBox" BorderBrush="{DynamicResource PrimaryDark}" <pu:Switch x:Name="CalFunctionBox" BorderBrush="{DynamicResource PrimaryDark}" Grid.Column="2"
Grid.Column="2" CheckedBackground="{DynamicResource Primary}" CheckedBackground="{DynamicResource Primary}"
CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" CheckedBorderBrush="{DynamicResource Primary}" Background="Transparent" BoxWidth="35"
BoxWidth="35" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}" BoxHeight="18" ToggleSize="14" ToggleShadowColor="{x:Null}"
ToggleBrush="{DynamicResource PrimaryDark}" ToggleBrush="{DynamicResource PrimaryDark}"
CheckedToggleBrush="{DynamicResource DARKPrimaryText}" Margin="10,0,0,0" CheckedToggleBrush="{DynamicResource DARKPrimaryText}" Margin="10,0,0,0"
ToolTip="启用数据计算,桌宠会有状态变化,需要按时投喂等.&#13;如果嫌麻烦可以关掉" Checked="CalFunctionBox_Checked" /> ToolTip="启用数据计算,桌宠会有状态变化,需要按时投喂等.&#13;如果嫌麻烦可以关掉" Checked="CalFunctionBox_Checked" />
@ -314,8 +316,7 @@
<TextBlock Grid.Row="0" Text="数据计算" VerticalAlignment="Center" /> <TextBlock Grid.Row="0" Text="数据计算" VerticalAlignment="Center" />
<TextBlock Grid.Row="3" Text="桌宠移动" VerticalAlignment="Center" /> <TextBlock Grid.Row="3" Text="桌宠移动" VerticalAlignment="Center" />
<TextBlock Grid.Row="1" Text="计算间隔" VerticalAlignment="Center" /> <TextBlock Grid.Row="1" Text="计算间隔" VerticalAlignment="Center" />
<Grid Grid.Column="2" Grid.Row="1" <Grid Grid.Column="2" Grid.Row="1" ToolTip="数据计算和互动计算时间间隔,间隔越短需要互动的频率可能会增加.&#13;间隔越大越不容易打扰到当前工作">
ToolTip="数据计算和互动计算时间间隔,间隔越短需要互动的频率可能会增加.&#13;间隔越大越不容易打扰到当前工作">
<Grid.ColumnDefinitions> <Grid.ColumnDefinitions>
<ColumnDefinition /> <ColumnDefinition />
<ColumnDefinition Width="Auto" /> <ColumnDefinition Width="Auto" />
@ -352,8 +353,7 @@
<TextBlock Text="智能移动判断时间间隔" /> <TextBlock Text="智能移动判断时间间隔" />
<ComboBox x:Name="CBSmartMove" Style="{DynamicResource StandardComboBoxStyle}" <ComboBox x:Name="CBSmartMove" Style="{DynamicResource StandardComboBoxStyle}"
IsEnabled="{Binding ElementName=SmartMoveEventBox,Path=IsChecked}" IsEnabled="{Binding ElementName=SmartMoveEventBox,Path=IsChecked}"
SelectionChanged="CBSmartMove_SelectionChanged" SelectedIndex="5" SelectionChanged="CBSmartMove_SelectionChanged" SelectedIndex="5" Grid.Column="1">
Grid.Column="1">
<ComboBoxItem> <ComboBoxItem>
<ComboBoxItem.Tag> <ComboBoxItem.Tag>
<system:Int32>30</system:Int32> <system:Int32>30</system:Int32>
@ -412,8 +412,7 @@
</TabItem> </TabItem>
<TabItem Header="自定" BorderBrush="{DynamicResource PrimaryDarker}"> <TabItem Header="自定" BorderBrush="{DynamicResource PrimaryDarker}">
<StackPanel> <StackPanel>
<TextBlock Background="{x:Null}" <TextBlock Background="{x:Null}" TextWrapping="Wrap">
TextWrapping="Wrap">
<Run FontWeight="Bold" FontSize="18">自定义链接</Run><LineBreak /> <Run FontWeight="Bold" FontSize="18">自定义链接</Run><LineBreak />
<Run>在自定栏添加快捷方式/网页/快捷键, 可以便携启动想要的功能</Run><LineBreak /> <Run>在自定栏添加快捷方式/网页/快捷键, 可以便携启动想要的功能</Run><LineBreak />
<Run>键盘快捷键编写方法请参考</Run> <Hyperlink Click="sendkey_click">键盘快捷键 通用注解</Hyperlink><LineBreak /> <Run>键盘快捷键编写方法请参考</Run> <Hyperlink Click="sendkey_click">键盘快捷键 通用注解</Hyperlink><LineBreak />
@ -432,24 +431,23 @@
<StackPanel x:Name="StackDIY" /> <StackPanel x:Name="StackDIY" />
</StackPanel> </StackPanel>
</TabItem> </TabItem>
<TabItem Header="诊断" BorderBrush="{DynamicResource PrimaryDarker}"> <TabItem Header="诊断" BorderBrush="{DynamicResource PrimaryDarker}">
<StackPanel> <StackPanel>
<TextBlock HorizontalAlignment="Left" FontSize="11" VerticalAlignment="Top" <TextBlock HorizontalAlignment="Left" FontSize="11" VerticalAlignment="Top" Background="{x:Null}"
Background="{x:Null}" TextWrapping="Wrap"> TextWrapping="Wrap">
<Run FontWeight="Bold" FontSize="18">诊断与反馈</Run><LineBreak /> <Run FontWeight="Bold" FontSize="18">诊断与反馈</Run><LineBreak />
<Run>选择要发送给 LBGame 的诊断数据,诊断数据用于保护和及时更新 虚拟桌宠模拟器, 解决问题并改进产品.</Run><LineBreak /> <Run>选择要发送给 LBGame 的诊断数据,诊断数据用于保护和及时更新 虚拟桌宠模拟器, 解决问题并改进产品.</Run><LineBreak />
<Run>无论选择哪个选项,游戏都可以安全正常地运行.</Run> <Hyperlink Click="hyper_moreInfo">获取有关这些设置的更多信息</Hyperlink> <Run>无论选择哪个选项,游戏都可以安全正常地运行.</Run> <Hyperlink Click="hyper_moreInfo">获取有关这些设置的更多信息</Hyperlink>
</TextBlock> </TextBlock>
<RadioButton x:Name="RBDiagnosisYES" Style="{DynamicResource StandardRadioButtonStyle}" <RadioButton x:Name="RBDiagnosisYES" Style="{DynamicResource StandardRadioButtonStyle}"
Content="发送诊断数据: 发送游戏存档, 包括饱腹,状态等各种游戏内&#13;数据. 可能会包括该游戏内存和CPU使用情况" Content="发送诊断数据: 发送游戏存档, 包括饱腹,状态等各种游戏内&#13;数据. 可能会包括该游戏内存和CPU使用情况"
HorizontalAlignment="Left" Margin="10,10,10,0" VerticalAlignment="Top" HorizontalAlignment="Left" Margin="10,10,10,0" VerticalAlignment="Top" GroupName="diagnosis"
GroupName="diagnosis" Checked="RBDiagnosisYES_Checked" IsEnabled="False" /> Checked="RBDiagnosisYES_Checked" IsEnabled="False" />
<RadioButton x:Name="RBDiagnosisNO" Style="{DynamicResource StandardRadioButtonStyle}" <RadioButton x:Name="RBDiagnosisNO" Style="{DynamicResource StandardRadioButtonStyle}"
Content="不发送诊断数据: 适用于启用修改器,修改过游戏数据等不&#13;符合分析数据条件. 或不希望提供游戏数据的玩家" Content="不发送诊断数据: 适用于启用修改器,修改过游戏数据等不&#13;符合分析数据条件. 或不希望提供游戏数据的玩家" HorizontalAlignment="Left"
HorizontalAlignment="Left" Margin="10,10,10,0" VerticalAlignment="Top" Margin="10,10,10,0" VerticalAlignment="Top" GroupName="diagnosis"
GroupName="diagnosis" Checked="RBDiagnosisNO_Checked" IsChecked="True" /> Checked="RBDiagnosisNO_Checked" IsChecked="True" />
<TextBlock HorizontalAlignment="Left" VerticalAlignment="Top" Margin="0,15,0,0" <TextBlock HorizontalAlignment="Left" VerticalAlignment="Top" Margin="0,15,0,0"
Background="{x:Null}" TextWrapping="Wrap"> Background="{x:Null}" TextWrapping="Wrap">
<Run FontWeight="Bold">反馈频率</Run><LineBreak /> <Run FontWeight="Bold">反馈频率</Run><LineBreak />
@ -487,9 +485,9 @@
<Image x:Name="ImageMOD" HorizontalAlignment="Right" Height="120" Margin="0,5,0,0" <Image x:Name="ImageMOD" HorizontalAlignment="Right" Height="120" Margin="0,5,0,0"
VerticalAlignment="Top" Width="120" Stretch="Fill" /> VerticalAlignment="Top" Width="120" Stretch="Fill" />
<StackPanel Grid.Column="2"> <StackPanel Grid.Column="2">
<Label x:Name="LabelModName" Content="Core" HorizontalAlignment="Left" <Label x:Name="LabelModName" Content="Core" HorizontalAlignment="Left" Margin="-5,2,0,0"
Margin="-5,2,0,0" VerticalAlignment="Top" FontWeight="Bold" FontSize="20" VerticalAlignment="Top" FontWeight="Bold" FontSize="20" Background="{x:Null}"
Background="{x:Null}" Foreground="{DynamicResource PrimaryText}" /> Foreground="{DynamicResource PrimaryText}" />
<TextBlock Margin="0,0,0,0" TextWrapping="Wrap"> <TextBlock Margin="0,0,0,0" TextWrapping="Wrap">
<Run Text="模组作者: " /><LineBreak /> <Run Text="模组作者: " /><LineBreak />
<Run x:Name="runMODAuthor" Text="LorisYounger" /> <Run x:Name="runMODAuthor" Text="LorisYounger" />
@ -511,8 +509,7 @@
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<StackPanel> <StackPanel>
<Label Content="MOD介绍" HorizontalAlignment="Left" Margin="-5,0,0,0" <Label Content="MOD介绍" HorizontalAlignment="Left" Margin="-5,0,0,0"
VerticalAlignment="Center" FontSize="18" FontWeight="Bold" VerticalAlignment="Center" FontSize="18" FontWeight="Bold" Background="{x:Null}" />
Background="{x:Null}" />
<ScrollViewer VerticalScrollBarVisibility="Auto" Height="140" Margin="0,0,0,0" <ScrollViewer VerticalScrollBarVisibility="Auto" Height="140" Margin="0,0,0,0"
pu:ScrollViewerHelper.ScrollBarThickness="10" HorizontalAlignment="Left" pu:ScrollViewerHelper.ScrollBarThickness="10" HorizontalAlignment="Left"
VerticalAlignment="Top"> VerticalAlignment="Top">
@ -522,22 +519,20 @@
</ScrollViewer> </ScrollViewer>
</StackPanel> </StackPanel>
<StackPanel Grid.Column="1"> <StackPanel Grid.Column="1">
<Label Content="内容" HorizontalAlignment="Left" Margin="-5,0,0,0" <Label Content="内容" HorizontalAlignment="Left" Margin="-5,0,0,0" VerticalAlignment="Top"
VerticalAlignment="Top" FontSize="18" FontWeight="Bold" FontSize="18" FontWeight="Bold" Background="{x:Null}" />
Background="{x:Null}" />
<TextBlock x:Name="ButtonOpenModFolder" Cursor="Hand" HorizontalAlignment="Left" <TextBlock x:Name="ButtonOpenModFolder" Cursor="Hand" HorizontalAlignment="Left"
Margin="0,0,0,0" TextWrapping="Wrap" Text="所在文件夹" VerticalAlignment="Top" Margin="0,0,0,0" TextWrapping="Wrap" Text="所在文件夹" VerticalAlignment="Top"
FontSize="14" Foreground="{DynamicResource DARKPrimaryDarker}" FontSize="14" Foreground="{DynamicResource DARKPrimaryDarker}"
TextDecorations="Underline" MouseDown="ButtonOpenModFolder_MouseDown" /> TextDecorations="Underline" MouseDown="ButtonOpenModFolder_MouseDown" />
<TextBlock x:Name="ButtonEnable" HorizontalAlignment="Left" Margin="0,2,0,0" <TextBlock x:Name="ButtonEnable" HorizontalAlignment="Left" Margin="0,2,0,0"
TextWrapping="Wrap" Text="启用该模组" VerticalAlignment="Top" FontSize="14" TextWrapping="Wrap" Text="启用该模组" VerticalAlignment="Top" FontSize="14"
Foreground="{DynamicResource DARKPrimaryDarker}" Foreground="{DynamicResource DARKPrimaryDarker}" TextDecorations="Underline"
TextDecorations="Underline" Cursor="Hand" MouseDown="ButtonEnable_MouseDown" /> Cursor="Hand" MouseDown="ButtonEnable_MouseDown" />
<TextBlock x:Name="ButtonDisEnable" HorizontalAlignment="Left" Margin="0,2,0,0" <TextBlock x:Name="ButtonDisEnable" HorizontalAlignment="Left" Margin="0,2,0,0"
TextWrapping="Wrap" Text="停用该模组" VerticalAlignment="Top" FontSize="14" TextWrapping="Wrap" Text="停用该模组" VerticalAlignment="Top" FontSize="14"
Foreground="{DynamicResource DARKPrimaryDarker}" Foreground="{DynamicResource DARKPrimaryDarker}" TextDecorations="Underline"
TextDecorations="Underline" Cursor="Hand" Cursor="Hand" MouseDown="ButtonDisEnable_MouseDown" />
MouseDown="ButtonDisEnable_MouseDown" />
<TextBlock x:Name="ButtonPublish" HorizontalAlignment="Left" Margin="0,2,0,0" <TextBlock x:Name="ButtonPublish" HorizontalAlignment="Left" Margin="0,2,0,0"
TextWrapping="Wrap" Text="更新至Steam" VerticalAlignment="Top" FontSize="14" TextWrapping="Wrap" Text="更新至Steam" VerticalAlignment="Top" FontSize="14"
Foreground="DimGray" TextDecorations="Underline" Cursor="Hand" Foreground="DimGray" TextDecorations="Underline" Cursor="Hand"
@ -554,11 +549,11 @@
Foreground="{DynamicResource DARKPrimary}" BorderThickness="2" /> Foreground="{DynamicResource DARKPrimary}" BorderThickness="2" />
<TextBlock x:Name="ButtonSetting" HorizontalAlignment="Left" Margin="0,2,0,0" <TextBlock x:Name="ButtonSetting" HorizontalAlignment="Left" Margin="0,2,0,0"
TextWrapping="Wrap" Text="MOD设置" VerticalAlignment="Top" FontSize="14" TextWrapping="Wrap" Text="MOD设置" VerticalAlignment="Top" FontSize="14"
Foreground="{DynamicResource DARKPrimaryDarker}" TextDecorations="Underline" Cursor="Hand" MouseDown="ButtonSetting_MouseDown" Foreground="{DynamicResource DARKPrimaryDarker}" TextDecorations="Underline"
/> Cursor="Hand" MouseDown="ButtonSetting_MouseDown" />
<Button x:Name="ButtonAllow" Content="启用代码插件" HorizontalAlignment="Left" <Button x:Name="ButtonAllow" Content="启用代码插件" HorizontalAlignment="Left"
VerticalAlignment="Top" Background="#FFFF2C2C" Foreground="White" VerticalAlignment="Top" Background="#FFFF2C2C" Foreground="White" FontSize="12"
FontSize="12" ToolTip="启用该模组的代码内容,不能保证系统安全性" Click="ButtonAllow_Click" /> ToolTip="启用该模组的代码内容,不能保证系统安全性" Click="ButtonAllow_Click" />
</StackPanel> </StackPanel>
<Button x:Name="ButtonRestart" Content="重启软件以应用更改" Margin="0,2,0,0" <Button x:Name="ButtonRestart" Content="重启软件以应用更改" Margin="0,2,0,0"
VerticalAlignment="Bottom" Background="{DynamicResource DARKPrimary}" VerticalAlignment="Bottom" Background="{DynamicResource DARKPrimary}"
@ -571,8 +566,8 @@
<TabItem Header="关于" BorderBrush="{DynamicResource PrimaryDarker}" <TabItem Header="关于" BorderBrush="{DynamicResource PrimaryDarker}"
Foreground="{DynamicResource PrimaryText}"> Foreground="{DynamicResource PrimaryText}">
<Grid> <Grid>
<Image x:Name="ImageWHY" Width="64" HorizontalAlignment="Right" <Image x:Name="ImageWHY" Width="64" HorizontalAlignment="Right" VerticalAlignment="Center"
VerticalAlignment="Center" Height="64" Source="/Res/TopLogo2019.PNG" Margin="0,210,55,0" /> Height="64" Source="/Res/TopLogo2019.PNG" Margin="0,210,55,0" />
<TextBlock Margin="0,0,0,0" Text="虚拟主播模拟器 规格" FontSize="20" FontWeight="Bold" /> <TextBlock Margin="0,0,0,0" Text="虚拟主播模拟器 规格" FontSize="20" FontWeight="Bold" />
<TextBlock Margin="0,130,0,0" FontWeight="Bold"> <TextBlock Margin="0,130,0,0" FontWeight="Bold">
<Run>游戏策划</Run><LineBreak /> <Run>游戏策划</Run><LineBreak />
@ -587,8 +582,7 @@
<Hyperlink TextDecorations="Underline" Foreground="Black" Click="LB_Click">LBGame</Hyperlink> <Hyperlink TextDecorations="Underline" Foreground="Black" Click="LB_Click">LBGame</Hyperlink>
<LineBreak /><LineBreak /> <LineBreak /><LineBreak />
<Run xml:space="preserve">相关链接 </Run> <Run xml:space="preserve">相关链接 </Run>
<Hyperlink TextDecorations="Underline" <Hyperlink TextDecorations="Underline" Foreground="{DynamicResource DARKPrimaryDarker}"
Foreground="{DynamicResource DARKPrimaryDarker}"
Click="VUP_Click" FontWeight="Normal">虚拟主播模拟器</Hyperlink> Click="VUP_Click" FontWeight="Normal">虚拟主播模拟器</Hyperlink>
<Hyperlink TextDecorations="Underline" Foreground="{DynamicResource DARKPrimaryDarker}" <Hyperlink TextDecorations="Underline" Foreground="{DynamicResource DARKPrimaryDarker}"
Click="Group_Click" FontWeight="Normal">相关群</Hyperlink> Click="Group_Click" FontWeight="Normal">相关群</Hyperlink>
@ -622,7 +616,7 @@
</Grid> </Grid>
</TabItem> </TabItem>
</TabControl> </TabControl>
<Label x:Name="GameVerison" Content="版本v1.0 (655366666)" HorizontalAlignment="Left" <Label x:Name="GameVerison" Content="版本v1.0 (655366666)" HorizontalAlignment="Left" VerticalAlignment="Bottom"
VerticalAlignment="Bottom" FontSize="10" Foreground="Green" Background="{x:Null}" /> FontSize="10" Foreground="Green" Background="{x:Null}" />
</Grid> </Grid>
</pu:WindowX> </pu:WindowX>

View File

@ -154,6 +154,7 @@ namespace VPet_Simulator.Windows
foreach (CoreMOD mod in mw.CoreMODs) foreach (CoreMOD mod in mw.CoreMODs)
{ {
ListBoxItem moditem = (ListBoxItem)ListMod.Items[ListMod.Items.Add(new ListBoxItem())]; ListBoxItem moditem = (ListBoxItem)ListMod.Items[ListMod.Items.Add(new ListBoxItem())];
moditem.Padding = new Thickness(5, 0, 5, 0);
moditem.Content = mod.Name; moditem.Content = mod.Name;
if (mod.IsBanMOD(mw)) if (mod.IsBanMOD(mw))
{ {
@ -793,6 +794,7 @@ namespace VPet_Simulator.Windows
{ {
if (!AllowChange) if (!AllowChange)
return; return;
MessageBoxX.Show("由于没做完,暂不支持数据计算\n敬请期待后续更新", "没做完!", MessageBoxButton.OK, MessageBoxIcon.Warning);
mw.Set.EnableFunction = CalFunctionBox.IsChecked.Value; mw.Set.EnableFunction = CalFunctionBox.IsChecked.Value;
} }
} }

View File

@ -4,3 +4,5 @@ touchraised:|px#0:|py#50:|sw#500:|sh#200:|
raisepoint:|happy_x#290:|happy_y#128:|nomal_x#290:|nomal_y#128:|poorcondition_x#290:|poorcondition_y#128:|ill_x#290:|ill_y#128:| raisepoint:|happy_x#290:|happy_y#128:|nomal_x#290:|nomal_y#128:|poorcondition_x#290:|poorcondition_y#128:|ill_x#290:|ill_y#128:|
speed:|walk#20:|climb#10:|climbtop#8:|crawl#8:|fallx#14:|fally#10:|crawl#10:| speed:|walk#20:|climb#10:|climbtop#8:|crawl#8:|fallx#14:|fally#10:|crawl#10:|
locate:|climbleft#145:|climbright#185:|climbtop#150:| locate:|climbleft#145:|climbright#185:|climbtop#150:|
storernd:|Touch_Body_A_Start:|Touch_Body_B_Loop:|Touch_Body_C_End:|
str:|work1#工作:|work2#直播:|

Binary file not shown.

After

Width:  |  Height:  |  Size: 159 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 154 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 184 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 190 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 171 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 100 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 105 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 117 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 128 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 117 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 128 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 109 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 177 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 173 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 231 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 273 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 300 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 292 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 159 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 154 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 184 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 190 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 171 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 151 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 140 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 134 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 136 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 140 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 140 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 141 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 140 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 134 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 136 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 109 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 177 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 173 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 231 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 273 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 300 KiB

Some files were not shown because too many files have changed in this diff Show More