mirror of
https://github.com/kwsch/PKHeX
synced 2024-11-23 20:43:07 +00:00
Add misc value r/w for trainer8
Closes #2639 casting object to generic T : struct isn't valid, so just cast the get/set appropriately
This commit is contained in:
parent
2a7d475b5b
commit
9b0b0cb1a6
5 changed files with 154 additions and 6 deletions
|
@ -70,8 +70,8 @@ namespace PKHeX.Core
|
||||||
public const int KBattleTowerDoublesVictory = 0x0D477836; // U32 Doubles victories (9,999,999 cap)
|
public const int KBattleTowerDoublesVictory = 0x0D477836; // U32 Doubles victories (9,999,999 cap)
|
||||||
public const int KBattleTowerSinglesStreak = 0x6226F5AD; // U16 Singles Streak (255 cap)
|
public const int KBattleTowerSinglesStreak = 0x6226F5AD; // U16 Singles Streak (255 cap)
|
||||||
public const int KBattleTowerDoublesStreak = 0x5F74FCEE; // U16 Doubles Streak (255 cap)
|
public const int KBattleTowerDoublesStreak = 0x5F74FCEE; // U16 Doubles Streak (255 cap)
|
||||||
public T GetBlockValue<T>(uint key) where T : struct => (T)GetBlock(key).GetValue();
|
public object GetBlockValue(uint key) => GetBlock(key).GetValue();
|
||||||
public void SetBlockValue<T>(uint key, T value) where T : struct => GetBlock(key).SetValue(value);
|
public void SetBlockValue(uint key, object value) => GetBlock(key).SetValue(value);
|
||||||
|
|
||||||
// Rather than storing a dictionary of keys, we can abuse the fact that the SCBlock[] is stored in order of ascending block key.
|
// Rather than storing a dictionary of keys, we can abuse the fact that the SCBlock[] is stored in order of ascending block key.
|
||||||
// Binary Search doesn't require extra memory like a Dictionary would; also, we only need to find a few blocks.
|
// Binary Search doesn't require extra memory like a Dictionary would; also, we only need to find a few blocks.
|
||||||
|
|
|
@ -51,8 +51,8 @@ namespace PKHeX.Core
|
||||||
|
|
||||||
#region Blocks
|
#region Blocks
|
||||||
public SaveBlockAccessorSWSH Blocks { get; }
|
public SaveBlockAccessorSWSH Blocks { get; }
|
||||||
public T GetValue<T>(uint key) where T : struct => Blocks.GetBlockValue<T>(key);
|
public object GetValue(uint key) => Blocks.GetBlockValue(key);
|
||||||
public void SetValue<T>(uint key, T value) where T : struct => Blocks.SetBlockValue<T>(key, value);
|
public void SetValue(uint key, object value) => Blocks.SetBlockValue(key, value);
|
||||||
public override Box8 BoxInfo => Blocks.BoxInfo;
|
public override Box8 BoxInfo => Blocks.BoxInfo;
|
||||||
public override Party8 PartyInfo => Blocks.PartyInfo;
|
public override Party8 PartyInfo => Blocks.PartyInfo;
|
||||||
public override MyItem Items => Blocks.Items;
|
public override MyItem Items => Blocks.Items;
|
||||||
|
|
|
@ -31,7 +31,7 @@ namespace PKHeX.Core
|
||||||
var data = BitConverter.GetBytes(value);
|
var data = BitConverter.GetBytes(value);
|
||||||
SAV.SetData(Data, data, 0x28);
|
SAV.SetData(Data, data, 0x28);
|
||||||
// set to the other block since it doesn't have an accessor
|
// set to the other block since it doesn't have an accessor
|
||||||
((SAV8SWSH)SAV).SetValue(SaveBlockAccessorSWSH.KRotoRally, value);
|
((SAV8SWSH)SAV).SetValue(SaveBlockAccessorSWSH.KRotoRally, (uint)value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -129,6 +129,16 @@
|
||||||
this.L_CurrentMap = new System.Windows.Forms.Label();
|
this.L_CurrentMap = new System.Windows.Forms.Label();
|
||||||
this.L_Z = new System.Windows.Forms.Label();
|
this.L_Z = new System.Windows.Forms.Label();
|
||||||
this.L_X = new System.Windows.Forms.Label();
|
this.L_X = new System.Windows.Forms.Label();
|
||||||
|
this.Tab_MiscValues = new System.Windows.Forms.TabPage();
|
||||||
|
this.GB_BattleTower = new System.Windows.Forms.GroupBox();
|
||||||
|
this.L_Singles = new System.Windows.Forms.Label();
|
||||||
|
this.MT_BattleTowerSinglesWin = new System.Windows.Forms.MaskedTextBox();
|
||||||
|
this.L_BattleTowerWins = new System.Windows.Forms.Label();
|
||||||
|
this.L_BattleTowerStreak = new System.Windows.Forms.Label();
|
||||||
|
this.MT_BattleTowerSinglesStreak = new System.Windows.Forms.MaskedTextBox();
|
||||||
|
this.MT_BattleTowerDoublesStreak = new System.Windows.Forms.MaskedTextBox();
|
||||||
|
this.L_Doubles = new System.Windows.Forms.Label();
|
||||||
|
this.MT_BattleTowerDoublesWin = new System.Windows.Forms.MaskedTextBox();
|
||||||
this.TC_Editor.SuspendLayout();
|
this.TC_Editor.SuspendLayout();
|
||||||
this.Tab_Overview.SuspendLayout();
|
this.Tab_Overview.SuspendLayout();
|
||||||
this.GB_Stats.SuspendLayout();
|
this.GB_Stats.SuspendLayout();
|
||||||
|
@ -141,6 +151,8 @@
|
||||||
((System.ComponentModel.ISupportInitialize)(this.NUD_M)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.NUD_M)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.NUD_Y)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.NUD_Y)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.NUD_X)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.NUD_X)).BeginInit();
|
||||||
|
this.Tab_MiscValues.SuspendLayout();
|
||||||
|
this.GB_BattleTower.SuspendLayout();
|
||||||
this.SuspendLayout();
|
this.SuspendLayout();
|
||||||
//
|
//
|
||||||
// B_Cancel
|
// B_Cancel
|
||||||
|
@ -647,6 +659,7 @@
|
||||||
| System.Windows.Forms.AnchorStyles.Right)));
|
| System.Windows.Forms.AnchorStyles.Right)));
|
||||||
this.TC_Editor.Controls.Add(this.Tab_Overview);
|
this.TC_Editor.Controls.Add(this.Tab_Overview);
|
||||||
this.TC_Editor.Controls.Add(this.Tab_BadgeMap);
|
this.TC_Editor.Controls.Add(this.Tab_BadgeMap);
|
||||||
|
this.TC_Editor.Controls.Add(this.Tab_MiscValues);
|
||||||
this.TC_Editor.Location = new System.Drawing.Point(12, 12);
|
this.TC_Editor.Location = new System.Drawing.Point(12, 12);
|
||||||
this.TC_Editor.Name = "TC_Editor";
|
this.TC_Editor.Name = "TC_Editor";
|
||||||
this.TC_Editor.SelectedIndex = 0;
|
this.TC_Editor.SelectedIndex = 0;
|
||||||
|
@ -698,7 +711,7 @@
|
||||||
// MT_RotoRally
|
// MT_RotoRally
|
||||||
//
|
//
|
||||||
this.MT_RotoRally.Location = new System.Drawing.Point(331, 100);
|
this.MT_RotoRally.Location = new System.Drawing.Point(331, 100);
|
||||||
this.MT_RotoRally.Mask = "000000";
|
this.MT_RotoRally.Mask = "00000";
|
||||||
this.MT_RotoRally.Name = "MT_RotoRally";
|
this.MT_RotoRally.Name = "MT_RotoRally";
|
||||||
this.MT_RotoRally.RightToLeft = System.Windows.Forms.RightToLeft.Yes;
|
this.MT_RotoRally.RightToLeft = System.Windows.Forms.RightToLeft.Yes;
|
||||||
this.MT_RotoRally.Size = new System.Drawing.Size(43, 20);
|
this.MT_RotoRally.Size = new System.Drawing.Size(43, 20);
|
||||||
|
@ -1118,6 +1131,110 @@
|
||||||
this.L_X.Text = "X Coordinate:";
|
this.L_X.Text = "X Coordinate:";
|
||||||
this.L_X.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
|
this.L_X.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
|
||||||
//
|
//
|
||||||
|
// Tab_MiscValues
|
||||||
|
//
|
||||||
|
this.Tab_MiscValues.Controls.Add(this.GB_BattleTower);
|
||||||
|
this.Tab_MiscValues.Location = new System.Drawing.Point(4, 22);
|
||||||
|
this.Tab_MiscValues.Name = "Tab_MiscValues";
|
||||||
|
this.Tab_MiscValues.Padding = new System.Windows.Forms.Padding(3);
|
||||||
|
this.Tab_MiscValues.Size = new System.Drawing.Size(430, 287);
|
||||||
|
this.Tab_MiscValues.TabIndex = 4;
|
||||||
|
this.Tab_MiscValues.Text = "Misc";
|
||||||
|
this.Tab_MiscValues.UseVisualStyleBackColor = true;
|
||||||
|
//
|
||||||
|
// GB_BattleTower
|
||||||
|
//
|
||||||
|
this.GB_BattleTower.Controls.Add(this.MT_BattleTowerDoublesStreak);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.L_Doubles);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.MT_BattleTowerDoublesWin);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.L_BattleTowerStreak);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.MT_BattleTowerSinglesStreak);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.L_BattleTowerWins);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.L_Singles);
|
||||||
|
this.GB_BattleTower.Controls.Add(this.MT_BattleTowerSinglesWin);
|
||||||
|
this.GB_BattleTower.Location = new System.Drawing.Point(6, 6);
|
||||||
|
this.GB_BattleTower.Name = "GB_BattleTower";
|
||||||
|
this.GB_BattleTower.Size = new System.Drawing.Size(195, 94);
|
||||||
|
this.GB_BattleTower.TabIndex = 0;
|
||||||
|
this.GB_BattleTower.TabStop = false;
|
||||||
|
this.GB_BattleTower.Text = "Battle Tower";
|
||||||
|
//
|
||||||
|
// L_Singles
|
||||||
|
//
|
||||||
|
this.L_Singles.Location = new System.Drawing.Point(6, 34);
|
||||||
|
this.L_Singles.Name = "L_Singles";
|
||||||
|
this.L_Singles.Size = new System.Drawing.Size(76, 20);
|
||||||
|
this.L_Singles.TabIndex = 77;
|
||||||
|
this.L_Singles.Text = "Singles:";
|
||||||
|
this.L_Singles.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
|
||||||
|
//
|
||||||
|
// MT_BattleTowerSinglesWin
|
||||||
|
//
|
||||||
|
this.MT_BattleTowerSinglesWin.Location = new System.Drawing.Point(88, 34);
|
||||||
|
this.MT_BattleTowerSinglesWin.Mask = "000000";
|
||||||
|
this.MT_BattleTowerSinglesWin.Name = "MT_BattleTowerSinglesWin";
|
||||||
|
this.MT_BattleTowerSinglesWin.RightToLeft = System.Windows.Forms.RightToLeft.Yes;
|
||||||
|
this.MT_BattleTowerSinglesWin.Size = new System.Drawing.Size(43, 20);
|
||||||
|
this.MT_BattleTowerSinglesWin.TabIndex = 76;
|
||||||
|
this.MT_BattleTowerSinglesWin.TextAlign = System.Windows.Forms.HorizontalAlignment.Center;
|
||||||
|
//
|
||||||
|
// L_BattleTowerWins
|
||||||
|
//
|
||||||
|
this.L_BattleTowerWins.Location = new System.Drawing.Point(85, 11);
|
||||||
|
this.L_BattleTowerWins.Name = "L_BattleTowerWins";
|
||||||
|
this.L_BattleTowerWins.Size = new System.Drawing.Size(46, 20);
|
||||||
|
this.L_BattleTowerWins.TabIndex = 78;
|
||||||
|
this.L_BattleTowerWins.Text = "Wins";
|
||||||
|
this.L_BattleTowerWins.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
|
||||||
|
//
|
||||||
|
// L_BattleTowerStreak
|
||||||
|
//
|
||||||
|
this.L_BattleTowerStreak.Location = new System.Drawing.Point(134, 12);
|
||||||
|
this.L_BattleTowerStreak.Name = "L_BattleTowerStreak";
|
||||||
|
this.L_BattleTowerStreak.Size = new System.Drawing.Size(46, 20);
|
||||||
|
this.L_BattleTowerStreak.TabIndex = 80;
|
||||||
|
this.L_BattleTowerStreak.Text = "Streak";
|
||||||
|
this.L_BattleTowerStreak.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
|
||||||
|
//
|
||||||
|
// MT_BattleTowerSinglesStreak
|
||||||
|
//
|
||||||
|
this.MT_BattleTowerSinglesStreak.Location = new System.Drawing.Point(137, 35);
|
||||||
|
this.MT_BattleTowerSinglesStreak.Mask = "000";
|
||||||
|
this.MT_BattleTowerSinglesStreak.Name = "MT_BattleTowerSinglesStreak";
|
||||||
|
this.MT_BattleTowerSinglesStreak.RightToLeft = System.Windows.Forms.RightToLeft.Yes;
|
||||||
|
this.MT_BattleTowerSinglesStreak.Size = new System.Drawing.Size(43, 20);
|
||||||
|
this.MT_BattleTowerSinglesStreak.TabIndex = 79;
|
||||||
|
this.MT_BattleTowerSinglesStreak.TextAlign = System.Windows.Forms.HorizontalAlignment.Center;
|
||||||
|
//
|
||||||
|
// MT_BattleTowerDoublesStreak
|
||||||
|
//
|
||||||
|
this.MT_BattleTowerDoublesStreak.Location = new System.Drawing.Point(137, 61);
|
||||||
|
this.MT_BattleTowerDoublesStreak.Mask = "000";
|
||||||
|
this.MT_BattleTowerDoublesStreak.Name = "MT_BattleTowerDoublesStreak";
|
||||||
|
this.MT_BattleTowerDoublesStreak.RightToLeft = System.Windows.Forms.RightToLeft.Yes;
|
||||||
|
this.MT_BattleTowerDoublesStreak.Size = new System.Drawing.Size(43, 20);
|
||||||
|
this.MT_BattleTowerDoublesStreak.TabIndex = 83;
|
||||||
|
this.MT_BattleTowerDoublesStreak.TextAlign = System.Windows.Forms.HorizontalAlignment.Center;
|
||||||
|
//
|
||||||
|
// L_Doubles
|
||||||
|
//
|
||||||
|
this.L_Doubles.Location = new System.Drawing.Point(6, 60);
|
||||||
|
this.L_Doubles.Name = "L_Doubles";
|
||||||
|
this.L_Doubles.Size = new System.Drawing.Size(76, 20);
|
||||||
|
this.L_Doubles.TabIndex = 82;
|
||||||
|
this.L_Doubles.Text = "Doubles:";
|
||||||
|
this.L_Doubles.TextAlign = System.Drawing.ContentAlignment.MiddleRight;
|
||||||
|
//
|
||||||
|
// MT_BattleTowerDoublesWin
|
||||||
|
//
|
||||||
|
this.MT_BattleTowerDoublesWin.Location = new System.Drawing.Point(88, 60);
|
||||||
|
this.MT_BattleTowerDoublesWin.Mask = "000000";
|
||||||
|
this.MT_BattleTowerDoublesWin.Name = "MT_BattleTowerDoublesWin";
|
||||||
|
this.MT_BattleTowerDoublesWin.RightToLeft = System.Windows.Forms.RightToLeft.Yes;
|
||||||
|
this.MT_BattleTowerDoublesWin.Size = new System.Drawing.Size(43, 20);
|
||||||
|
this.MT_BattleTowerDoublesWin.TabIndex = 81;
|
||||||
|
this.MT_BattleTowerDoublesWin.TextAlign = System.Windows.Forms.HorizontalAlignment.Center;
|
||||||
|
//
|
||||||
// SAV_Trainer8
|
// SAV_Trainer8
|
||||||
//
|
//
|
||||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
||||||
|
@ -1147,6 +1264,9 @@
|
||||||
((System.ComponentModel.ISupportInitialize)(this.NUD_M)).EndInit();
|
((System.ComponentModel.ISupportInitialize)(this.NUD_M)).EndInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.NUD_Y)).EndInit();
|
((System.ComponentModel.ISupportInitialize)(this.NUD_Y)).EndInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.NUD_X)).EndInit();
|
((System.ComponentModel.ISupportInitialize)(this.NUD_X)).EndInit();
|
||||||
|
this.Tab_MiscValues.ResumeLayout(false);
|
||||||
|
this.GB_BattleTower.ResumeLayout(false);
|
||||||
|
this.GB_BattleTower.PerformLayout();
|
||||||
this.ResumeLayout(false);
|
this.ResumeLayout(false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1254,5 +1374,15 @@
|
||||||
private System.Windows.Forms.Button B_MaxWatt;
|
private System.Windows.Forms.Button B_MaxWatt;
|
||||||
private System.Windows.Forms.Label L_RotoRally;
|
private System.Windows.Forms.Label L_RotoRally;
|
||||||
private System.Windows.Forms.MaskedTextBox MT_RotoRally;
|
private System.Windows.Forms.MaskedTextBox MT_RotoRally;
|
||||||
|
private System.Windows.Forms.TabPage Tab_MiscValues;
|
||||||
|
private System.Windows.Forms.GroupBox GB_BattleTower;
|
||||||
|
private System.Windows.Forms.MaskedTextBox MT_BattleTowerDoublesStreak;
|
||||||
|
private System.Windows.Forms.Label L_Doubles;
|
||||||
|
private System.Windows.Forms.MaskedTextBox MT_BattleTowerDoublesWin;
|
||||||
|
private System.Windows.Forms.Label L_BattleTowerStreak;
|
||||||
|
private System.Windows.Forms.MaskedTextBox MT_BattleTowerSinglesStreak;
|
||||||
|
private System.Windows.Forms.Label L_BattleTowerWins;
|
||||||
|
private System.Windows.Forms.Label L_Singles;
|
||||||
|
private System.Windows.Forms.MaskedTextBox MT_BattleTowerSinglesWin;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -32,6 +32,7 @@ namespace PKHeX.WinForms
|
||||||
NUD_BP.Value = Math.Min(SAV.Misc.BP, 9999);
|
NUD_BP.Value = Math.Min(SAV.Misc.BP, 9999);
|
||||||
GetComboBoxes();
|
GetComboBoxes();
|
||||||
GetTextBoxes();
|
GetTextBoxes();
|
||||||
|
GetMiscValues();
|
||||||
|
|
||||||
TC_Editor.TabPages.Remove(Tab_BadgeMap); // needs more work
|
TC_Editor.TabPages.Remove(Tab_BadgeMap); // needs more work
|
||||||
|
|
||||||
|
@ -101,9 +102,26 @@ namespace PKHeX.WinForms
|
||||||
// CAL_HoFTime.Value = time;
|
// CAL_HoFTime.Value = time;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void GetMiscValues()
|
||||||
|
{
|
||||||
|
MT_BattleTowerSinglesWin.Text = SAV.GetValue(SaveBlockAccessorSWSH.KBattleTowerSinglesVictory).ToString();
|
||||||
|
MT_BattleTowerDoublesWin.Text = SAV.GetValue(SaveBlockAccessorSWSH.KBattleTowerDoublesVictory).ToString();
|
||||||
|
MT_BattleTowerSinglesStreak.Text = SAV.GetValue(SaveBlockAccessorSWSH.KBattleTowerSinglesStreak).ToString();
|
||||||
|
MT_BattleTowerDoublesStreak.Text = SAV.GetValue(SaveBlockAccessorSWSH.KBattleTowerDoublesStreak).ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SaveMiscValues()
|
||||||
|
{
|
||||||
|
SAV.SetValue(SaveBlockAccessorSWSH.KBattleTowerSinglesVictory, Math.Min(999_999u, Util.ToUInt32(MT_BattleTowerSinglesWin.Text)));
|
||||||
|
SAV.SetValue(SaveBlockAccessorSWSH.KBattleTowerDoublesVictory, Math.Min(999_999u, Util.ToUInt32(MT_BattleTowerDoublesWin.Text)));
|
||||||
|
SAV.SetValue(SaveBlockAccessorSWSH.KBattleTowerSinglesStreak, (ushort)Math.Min(255, Util.ToUInt32(MT_BattleTowerSinglesStreak.Text)));
|
||||||
|
SAV.SetValue(SaveBlockAccessorSWSH.KBattleTowerDoublesStreak, (ushort)Math.Min(255, Util.ToUInt32(MT_BattleTowerDoublesStreak.Text)));
|
||||||
|
}
|
||||||
|
|
||||||
private void Save()
|
private void Save()
|
||||||
{
|
{
|
||||||
SaveTrainerInfo();
|
SaveTrainerInfo();
|
||||||
|
SaveMiscValues();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SaveTrainerInfo()
|
private void SaveTrainerInfo()
|
||||||
|
|
Loading…
Reference in a new issue