Fix control positions/sizes in the cases where auto scaling doesn't apply (e.g. dynamically created controls).
This commit is contained in:
parent
30d3b02a7f
commit
9a1108e9f7
|
@ -202,6 +202,7 @@
|
|||
<Compile Include="tools\RamSearchEngine.cs" />
|
||||
<Compile Include="tools\Watch.cs" />
|
||||
<Compile Include="tools\WatchList.cs" />
|
||||
<Compile Include="UIHelper.cs" />
|
||||
<Compile Include="XmlGame.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
|
|
|
@ -0,0 +1,41 @@
|
|||
using System;
|
||||
using System.Drawing;
|
||||
using System.Windows.Forms;
|
||||
|
||||
namespace BizHawk.Client.Common
|
||||
{
|
||||
public static class UIHelper
|
||||
{
|
||||
private static SizeF _autoScaleBaseSize = new SizeF(6F, 13F);
|
||||
private static SizeF _autoScaleCurrentSize = GetCurrentAutoScaleSize(AutoScaleMode.Font);
|
||||
|
||||
private static SizeF GetCurrentAutoScaleSize(AutoScaleMode autoScaleMode)
|
||||
{
|
||||
using (Form form = new Form())
|
||||
{
|
||||
form.AutoScaleMode = autoScaleMode;
|
||||
return form.CurrentAutoScaleDimensions;
|
||||
}
|
||||
}
|
||||
|
||||
public static float AutoScaleFactorX
|
||||
{
|
||||
get { return _autoScaleCurrentSize.Width / _autoScaleBaseSize.Width; }
|
||||
}
|
||||
|
||||
public static float AutoScaleFactorY
|
||||
{
|
||||
get { return _autoScaleCurrentSize.Height / _autoScaleBaseSize.Height; }
|
||||
}
|
||||
|
||||
public static int ScaleX(int size)
|
||||
{
|
||||
return (int)Math.Round(size * AutoScaleFactorX);
|
||||
}
|
||||
|
||||
public static int ScaleY(int size)
|
||||
{
|
||||
return (int)Math.Round(size * AutoScaleFactorY);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -4,6 +4,8 @@ using System.Drawing;
|
|||
using System.Linq;
|
||||
using System.Windows.Forms;
|
||||
|
||||
using BizHawk.Client.Common;
|
||||
|
||||
namespace BizHawk.Client.EmuHawk
|
||||
{
|
||||
// this is a little messy right now because of remnants of the old config system
|
||||
|
@ -17,14 +19,14 @@ namespace BizHawk.Client.EmuHawk
|
|||
|
||||
public List<string> buttons = new List<string>();
|
||||
|
||||
public int InputMarginLeft = 0;
|
||||
public int LabelPadding = 5;
|
||||
public int InputMarginLeft = UIHelper.ScaleX(0);
|
||||
public int LabelPadding = UIHelper.ScaleX(5);
|
||||
|
||||
public int MarginTop = 0;
|
||||
public int Spacing = 24;
|
||||
public int InputSize = 170;
|
||||
public int ColumnWidth = 280;
|
||||
public int LabelWidth = 60;
|
||||
public int MarginTop = UIHelper.ScaleY(0);
|
||||
public int Spacing = UIHelper.ScaleY(24);
|
||||
public int InputSize = UIHelper.ScaleX(170);
|
||||
public int ColumnWidth = UIHelper.ScaleX(280);
|
||||
public int LabelWidth = UIHelper.ScaleX(60);
|
||||
|
||||
public ToolTip Tooltip;
|
||||
|
||||
|
@ -105,7 +107,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
for (int i = 0; i < buttons.Count; i++)
|
||||
{
|
||||
y += Spacing;
|
||||
if (y > (_panelSize.Height - 30))
|
||||
if (y > (_panelSize.Height - UIHelper.ScaleY(30)))
|
||||
{
|
||||
y = MarginTop;
|
||||
x += ColumnWidth;
|
||||
|
@ -114,7 +116,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
InputCompositeWidget iw = new InputCompositeWidget
|
||||
{
|
||||
Location = new Point(x, y),
|
||||
Size = new Size(InputSize, 23),
|
||||
Size = new Size(InputSize, UIHelper.ScaleY(23)),
|
||||
TabIndex = i,
|
||||
AutoTab = this.Autotab
|
||||
};
|
||||
|
@ -126,7 +128,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
Inputs.Add(iw);
|
||||
Label label = new Label
|
||||
{
|
||||
Location = new Point(x + InputSize + LabelPadding, y + 3),
|
||||
Location = new Point(x + InputSize + LabelPadding, y + UIHelper.ScaleY(3)),
|
||||
Size = new Size(UIHelper.ScaleX(100), UIHelper.ScaleY(15)),
|
||||
Text = buttons[i].Replace('_', ' ').Trim(),
|
||||
};
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
|
||||
private void FileExtensionPreferences_Load(object sender, EventArgs e)
|
||||
{
|
||||
int spacing = 30;
|
||||
int spacing = UIHelper.ScaleY(30);
|
||||
int count = 0;
|
||||
foreach (var kvp in Global.Config.PreferredPlatformsForExtensions)
|
||||
{
|
||||
|
@ -28,7 +28,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
FileExtension = kvp.Key,
|
||||
OriginalPreference = kvp.Value,
|
||||
Location = new Point(15, 15 + (spacing * count))
|
||||
Location = new Point(UIHelper.ScaleX(15), UIHelper.ScaleY(15) + (spacing * count))
|
||||
};
|
||||
|
||||
count++;
|
||||
|
|
|
@ -110,23 +110,23 @@ namespace BizHawk.Client.EmuHawk
|
|||
|
||||
foreach (var tab in Tabs)
|
||||
{
|
||||
var _y = 14;
|
||||
var _x = 6;
|
||||
var _y = UIHelper.ScaleY(14);
|
||||
var _x = UIHelper.ScaleX(6);
|
||||
|
||||
var tb = new TabPage {Name = tab, Text = tab};
|
||||
|
||||
var bindings = Global.Config.HotkeyBindings.Where(x => x.TabGroup == tab).OrderBy(x => x.Ordinal).ThenBy(x => x.DisplayName).ToList();
|
||||
|
||||
const int iwOffsetX = 110;
|
||||
const int iwOffsetY = -4;
|
||||
const int iwWidth = 120;
|
||||
int iwOffsetX = UIHelper.ScaleX(110);
|
||||
int iwOffsetY = UIHelper.ScaleY(-4);
|
||||
int iwWidth = UIHelper.ScaleX(120);
|
||||
foreach (var b in bindings)
|
||||
{
|
||||
var l = new Label
|
||||
{
|
||||
Text = b.DisplayName,
|
||||
Location = new Point(_x, _y),
|
||||
Width = iwOffsetX - 2,
|
||||
Size = new Size(iwOffsetX - UIHelper.ScaleX(2), UIHelper.ScaleY(15)),
|
||||
};
|
||||
|
||||
var w = new InputCompositeWidget
|
||||
|
@ -145,11 +145,11 @@ namespace BizHawk.Client.EmuHawk
|
|||
tb.Controls.Add(l);
|
||||
tb.Controls.Add(w);
|
||||
|
||||
_y += 24;
|
||||
if (_y > HotkeyTabControl.Height - 35)
|
||||
_y += UIHelper.ScaleY(24);
|
||||
if (_y > HotkeyTabControl.Height - UIHelper.ScaleY(35))
|
||||
{
|
||||
_x += iwOffsetX + iwWidth + 10;
|
||||
_y = 14;
|
||||
_x += iwOffsetX + iwWidth + UIHelper.ScaleX(10);
|
||||
_y = UIHelper.ScaleY(14);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -67,17 +67,9 @@ namespace BizHawk.Client.EmuHawk
|
|||
YNumeric.Maximum = Global.Emulator.VideoProvider.BufferHeight - 12;
|
||||
PositionPanel.Size = new Size(Global.Emulator.VideoProvider.BufferWidth + 2, Global.Emulator.VideoProvider.BufferHeight + 2);
|
||||
|
||||
int width;
|
||||
if (Global.Emulator.VideoProvider.BufferWidth > 128)
|
||||
{
|
||||
width = Global.Emulator.VideoProvider.BufferWidth + 44;
|
||||
}
|
||||
else
|
||||
{
|
||||
width = 128 + 44;
|
||||
}
|
||||
|
||||
PositionGroupBox.Size = new Size(width, Global.Emulator.VideoProvider.BufferHeight + 52);
|
||||
PositionGroupBox.Size = new Size(
|
||||
Math.Max(Global.Emulator.VideoProvider.BufferWidth, UIHelper.ScaleX(128)) + UIHelper.ScaleX(44),
|
||||
Global.Emulator.VideoProvider.BufferHeight + UIHelper.ScaleY(52));
|
||||
}
|
||||
|
||||
private void SetColorBox()
|
||||
|
|
|
@ -95,12 +95,14 @@ namespace BizHawk.Client.EmuHawk
|
|||
|
||||
var tabPages = new List<TabPage>(systems.Count);
|
||||
|
||||
const int _x = 6;
|
||||
const int textboxWidth = 70;
|
||||
const int padding = 5;
|
||||
const int buttonWidth = 26;
|
||||
const int widgetOffset = 85;
|
||||
const int rowHeight = 30;
|
||||
int _x = UIHelper.ScaleX(6);
|
||||
int textboxWidth = UIHelper.ScaleX(70);
|
||||
int padding = UIHelper.ScaleX(5);
|
||||
int buttonWidth = UIHelper.ScaleX(26);
|
||||
int buttonHeight = UIHelper.ScaleY(23);
|
||||
int buttonOffsetY = -1; // To align the top with the textbox I guess? Always 1 pixel regardless of scaling.
|
||||
int widgetOffset = UIHelper.ScaleX(85);
|
||||
int rowHeight = UIHelper.ScaleY(30);
|
||||
|
||||
foreach (var systemDisplayName in systems)
|
||||
{
|
||||
|
@ -109,10 +111,11 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
Text = systemDisplayName,
|
||||
Name = systemId,
|
||||
Width = UIHelper.ScaleX(200) // Initial Left/Width of child controls are based on this size.
|
||||
};
|
||||
var paths = pathCollection.Where(x => x.System == systemId).OrderBy(x => x.Ordinal).ThenBy(x => x.Type).ToList();
|
||||
|
||||
var _y = 14;
|
||||
var _y = UIHelper.ScaleY(14);
|
||||
foreach (var path in paths)
|
||||
{
|
||||
var box = new TextBox
|
||||
|
@ -122,7 +125,7 @@ namespace BizHawk.Client.EmuHawk
|
|||
Width = textboxWidth,
|
||||
Name = path.Type,
|
||||
Anchor = AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Right,
|
||||
MinimumSize = new Size(26, 23),
|
||||
MinimumSize = new Size(UIHelper.ScaleX(26), UIHelper.ScaleY(23)),
|
||||
AutoCompleteMode = AutoCompleteMode.SuggestAppend,
|
||||
AutoCompleteCustomSource = AutoCompleteOptions,
|
||||
AutoCompleteSource = AutoCompleteSource.CustomSource,
|
||||
|
@ -132,8 +135,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
Text = string.Empty,
|
||||
Image = Properties.Resources.OpenFile,
|
||||
Location = new Point(widgetOffset, _y - 1),
|
||||
Width = buttonWidth,
|
||||
Location = new Point(widgetOffset, _y + buttonOffsetY),
|
||||
Size = new Size(buttonWidth, buttonHeight),
|
||||
Name = path.Type,
|
||||
Anchor = AnchorStyles.Top | AnchorStyles.Right,
|
||||
};
|
||||
|
@ -146,18 +149,18 @@ namespace BizHawk.Client.EmuHawk
|
|||
BrowseFolder(tempBox, tempPath, tempSystem);
|
||||
};
|
||||
|
||||
int infoPadding = 0;
|
||||
int infoPadding = UIHelper.ScaleX(0);
|
||||
if (t.Name.Contains("Global") && path.Type == "Firmware")
|
||||
{
|
||||
infoPadding = 26;
|
||||
infoPadding = UIHelper.ScaleX(26);
|
||||
|
||||
var firmwareButton = new Button
|
||||
{
|
||||
Name = "Global",
|
||||
Text = String.Empty,
|
||||
Image = Properties.Resources.Help,
|
||||
Location = new Point(115, _y - 1),
|
||||
Width = 26,
|
||||
Location = new Point(UIHelper.ScaleX(115), _y + buttonOffsetY),
|
||||
Size = new Size(buttonWidth, buttonHeight),
|
||||
Anchor = AnchorStyles.Top | AnchorStyles.Right
|
||||
};
|
||||
|
||||
|
@ -179,8 +182,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
var label = new Label
|
||||
{
|
||||
Text = path.Type,
|
||||
Location = new Point(widgetOffset + buttonWidth + padding + infoPadding, _y + 4),
|
||||
Width = 100,
|
||||
Location = new Point(widgetOffset + buttonWidth + padding + infoPadding, _y + UIHelper.ScaleY(4)),
|
||||
Size = new Size(UIHelper.ScaleX(100), UIHelper.ScaleY(15)),
|
||||
Name = path.Type,
|
||||
Anchor = AnchorStyles.Top | AnchorStyles.Right,
|
||||
};
|
||||
|
|
|
@ -43,7 +43,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
var c = new ComboBox
|
||||
{
|
||||
Location = new Point(35, 17),
|
||||
Location = new Point(UIHelper.ScaleX(35), UIHelper.ScaleY(17)),
|
||||
Width = UIHelper.ScaleX(121),
|
||||
DropDownStyle = ComboBoxStyle.DropDownList
|
||||
};
|
||||
|
||||
|
@ -57,7 +58,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
DisassemblerBox.Controls.Add(new Label
|
||||
{
|
||||
Location = new Point(35, 23),
|
||||
Location = new Point(UIHelper.ScaleX(35), UIHelper.ScaleY(23)),
|
||||
Size = new Size(UIHelper.ScaleX(100), UIHelper.ScaleY(15)),
|
||||
Text = Disassembler.Cpu
|
||||
});
|
||||
}
|
||||
|
@ -66,7 +68,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
DisassemblerBox.Controls.Add(new Label
|
||||
{
|
||||
Location = new Point(35, 23),
|
||||
Location = new Point(UIHelper.ScaleX(35), UIHelper.ScaleY(23)),
|
||||
Size = new Size(UIHelper.ScaleX(100), UIHelper.ScaleY(15)),
|
||||
Text = Disassembler.Cpu
|
||||
});
|
||||
}
|
||||
|
@ -80,7 +83,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
DisassemblerView.ItemCount = 0;
|
||||
DisassemblerBox.Controls.Add(new Label
|
||||
{
|
||||
Location = new Point(35, 23),
|
||||
Location = new Point(UIHelper.ScaleX(35), UIHelper.ScaleY(23)),
|
||||
Size = new Size(UIHelper.ScaleX(100), UIHelper.ScaleY(15)),
|
||||
Text = "Unknown"
|
||||
});
|
||||
|
||||
|
|
|
@ -7,6 +7,7 @@ using System.Linq;
|
|||
using System.Text;
|
||||
using System.Windows.Forms;
|
||||
|
||||
using BizHawk.Client.Common;
|
||||
using BizHawk.Common.NumberExtensions;
|
||||
using BizHawk.Emulation.Common;
|
||||
|
||||
|
@ -142,14 +143,14 @@ namespace BizHawk.Client.EmuHawk
|
|||
|
||||
var registers = Core.GetCpuFlagsAndRegisters();
|
||||
|
||||
int y = 0;
|
||||
int y = UIHelper.ScaleY(0);
|
||||
foreach (var register in registers.Where(r => r.Value.BitSize != 1))
|
||||
{
|
||||
this.Controls.Add(new Label
|
||||
{
|
||||
Text = register.Key.Replace("Flag ", "") + (canset ? ": " : ""),
|
||||
Location = new Point(5, y + 2),
|
||||
Width = 35
|
||||
Location = new Point(UIHelper.ScaleX(5), y + UIHelper.ScaleY(2)),
|
||||
Size = new Size(UIHelper.ScaleX(35), UIHelper.ScaleY(15))
|
||||
});
|
||||
|
||||
if (canset)
|
||||
|
@ -158,8 +159,8 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
Name = register.Key,
|
||||
Text = register.Value.Value.ToHexString(register.Value.BitSize / 16),
|
||||
Width = 6 + ((register.Value.BitSize / 4) * 9),
|
||||
Location = new Point(40, y),
|
||||
Width = UIHelper.ScaleX(6 + ((register.Value.BitSize / 4) * 9)),
|
||||
Location = new Point(UIHelper.ScaleX(40), y),
|
||||
MaxLength = register.Value.BitSize / 4,
|
||||
CharacterCasing = CharacterCasing.Upper
|
||||
};
|
||||
|
@ -187,12 +188,12 @@ namespace BizHawk.Client.EmuHawk
|
|||
{
|
||||
Name = register.Key,
|
||||
Text = register.Value.Value.ToString(),
|
||||
Width = 45,
|
||||
Location = new Point(40, y)
|
||||
Size = new Size(UIHelper.ScaleX(45), UIHelper.ScaleY(15)),
|
||||
Location = new Point(UIHelper.ScaleX(40), y)
|
||||
});
|
||||
}
|
||||
|
||||
y += 25;
|
||||
y += UIHelper.ScaleY(25);
|
||||
}
|
||||
|
||||
var flags = registers.Where(r => r.Value.BitSize == 1);
|
||||
|
@ -202,9 +203,9 @@ namespace BizHawk.Client.EmuHawk
|
|||
var p = new Panel
|
||||
{
|
||||
Name = "FlagPanel",
|
||||
Location = new Point(5, y),
|
||||
Location = new Point(UIHelper.ScaleX(5), y),
|
||||
BorderStyle = BorderStyle.None,
|
||||
Size = new Size(240, 23),
|
||||
Size = new Size(UIHelper.ScaleX(240), UIHelper.ScaleY(23)),
|
||||
AutoScroll = true
|
||||
};
|
||||
|
||||
|
@ -216,9 +217,9 @@ namespace BizHawk.Client.EmuHawk
|
|||
Name = flag.Key,
|
||||
Text = flag.Key.Replace("Flag", "").Trim(), // Hack
|
||||
Checked = flag.Value.Value == 1 ? true : false,
|
||||
Location = new Point(40, y),
|
||||
Location = new Point(UIHelper.ScaleX(40), y),
|
||||
Dock = DockStyle.Left,
|
||||
Size = new Size(23, 23),
|
||||
Size = new Size(UIHelper.ScaleX(23), UIHelper.ScaleY(23)),
|
||||
Enabled = canset
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in New Issue