2
0
mirror of https://github.com/9ParsonsB/Pulsar.git synced 2025-04-05 17:39:39 -04:00

[ObservatoryCore] UI tweaks

Polishing a few rough edges:
* Enable scrolling on the Plugin List view. It only fit 6 or 7. I have 13.
* I fiddled a bit with column auto-sizing (left it commented out, see comment).
* A whole bunch of tweaks to the settings view:
  * first row of controls was cut off at the top (under the window title bar)
  * fixing that revealed uneven spacing between columns
  * action buttons were teensy tiny and unreadable
  * settings view columns were too narrow (200 px).
  * added some spacing to help with readability
  * settings windows now start in center of current screen rather than some random place.
This commit is contained in:
Fred K 2024-01-22 00:16:00 -05:00
parent 2e3cfc8f6b
commit cfeb716064
4 changed files with 34 additions and 18 deletions

View File

@ -471,7 +471,6 @@
PluginList.MultiSelect = false; PluginList.MultiSelect = false;
PluginList.Name = "PluginList"; PluginList.Name = "PluginList";
PluginList.OwnerDraw = true; PluginList.OwnerDraw = true;
PluginList.Scrollable = false;
PluginList.Size = new Size(659, 137); PluginList.Size = new Size(659, 137);
PluginList.TabIndex = 0; PluginList.TabIndex = 0;
PluginList.UseCompatibleStateImageBehavior = false; PluginList.UseCompatibleStateImageBehavior = false;

View File

@ -212,6 +212,12 @@ namespace Observatory.UI
private void FitColumns() private void FitColumns()
{ {
// This sizes to fit the column width to the text. However, when the listview is resized (by
// expanding setting sections below the list), it causes flashing/jank. Visually, it looks cleaner
// (because the default column sizes are too small) and helps avoid horizontal scrollbar.
//foreach (ColumnHeader col in PluginList.Columns)
// col.Width = -2;
int totalWidth = 0; int totalWidth = 0;
foreach (ColumnHeader col in PluginList.Columns) foreach (ColumnHeader col in PluginList.Columns)
totalWidth += col.Width; totalWidth += col.Width;

View File

@ -1,4 +1,4 @@
namespace Observatory.UI namespace Observatory.UI
{ {
partial class SettingsForm partial class SettingsForm
{ {
@ -50,6 +50,7 @@
Controls.Add(PluginSettingsCloseButton); Controls.Add(PluginSettingsCloseButton);
FormBorderStyle = FormBorderStyle.FixedSingle; FormBorderStyle = FormBorderStyle.FixedSingle;
Name = "SettingsForm"; Name = "SettingsForm";
StartPosition = FormStartPosition.CenterScreen;
Text = "SettingsForm"; Text = "SettingsForm";
ResumeLayout(false); ResumeLayout(false);
} }

View File

@ -18,6 +18,7 @@ namespace Observatory.UI
{ {
private readonly IObservatoryPlugin _plugin; private readonly IObservatoryPlugin _plugin;
private readonly List<int> _colHeight = new List<int>(); private readonly List<int> _colHeight = new List<int>();
private int _colWidth = 400;
public SettingsForm(IObservatoryPlugin plugin) public SettingsForm(IObservatoryPlugin plugin)
{ {
@ -51,16 +52,18 @@ namespace Observatory.UI
foreach (var setting in settings) foreach (var setting in settings)
{ {
// Reset the column tracking for checkboxes if this isn't a checkbox // Reset the column tracking for checkboxes if this isn't a checkbox
int addedHeight = 35;
if (setting.Key.PropertyType.Name != "Boolean") if (setting.Key.PropertyType.Name != "Boolean")
{
if (recentHalfCol) _colHeight.Add(addedHeight);
recentHalfCol = false; recentHalfCol = false;
}
int addedHeight = 29;
switch (setting.Key.GetValue(_plugin.Settings)) switch (setting.Key.GetValue(_plugin.Settings))
{ {
case bool: case bool:
var checkBox = CreateBoolSetting(setting); var checkBox = CreateBoolSetting(setting);
addedHeight = recentHalfCol ? 0 : addedHeight; addedHeight = recentHalfCol ? addedHeight : 0;
checkBox.Location = GetSettingPosition(recentHalfCol); checkBox.Location = GetSettingPosition(recentHalfCol);
recentHalfCol = !recentHalfCol; recentHalfCol = !recentHalfCol;
@ -111,7 +114,7 @@ namespace Observatory.UI
intLabel.Location = GetSettingPosition(); intLabel.Location = GetSettingPosition();
intControl.Location = GetSettingPosition(true); intControl.Location = GetSettingPosition(true);
addedHeight = intControl.Height; addedHeight = intControl.Height + 2;
intLabel.Height = intControl.Height; intLabel.Height = intControl.Height;
intLabel.TextAlign = ContentAlignment.MiddleRight; intLabel.TextAlign = ContentAlignment.MiddleRight;
@ -125,6 +128,7 @@ namespace Observatory.UI
button.Location = GetSettingPosition(); button.Location = GetSettingPosition();
Controls.Add(button); Controls.Add(button);
addedHeight = button.Height;
trackBottomEdge(button); trackBottomEdge(button);
break; break;
case Dictionary<string, object> dictSetting: case Dictionary<string, object> dictSetting:
@ -142,12 +146,14 @@ namespace Observatory.UI
} }
_colHeight.Add(addedHeight); _colHeight.Add(addedHeight);
} }
Height = settingsHeight + 80; Height = settingsHeight + 160;
Width = _colWidth * 2 + 80;
} }
private Point GetSettingPosition(bool secondCol = false) private Point GetSettingPosition(bool secondCol = false)
{ {
return new Point(10 + (secondCol ? 200 : 0), -26 + _colHeight.Sum()); //return new Point(10 + (secondCol ? 200 : 0), -26 + _colHeight.Sum());
return new Point(10 + (secondCol ? _colWidth : 0), 15 + _colHeight.Sum());
} }
@ -157,7 +163,7 @@ namespace Observatory.UI
{ {
Text = settingName + ": ", Text = settingName + ": ",
TextAlign = System.Drawing.ContentAlignment.MiddleRight, TextAlign = System.Drawing.ContentAlignment.MiddleRight,
Width = 200, Width = _colWidth,
ForeColor = Color.LightGray ForeColor = Color.LightGray
}; };
@ -177,7 +183,7 @@ namespace Observatory.UI
ComboBox comboBox = new() ComboBox comboBox = new()
{ {
Width = 200, Width = _colWidth,
DropDownStyle = ComboBoxStyle.DropDownList DropDownStyle = ComboBoxStyle.DropDownList
}; };
@ -203,7 +209,9 @@ namespace Observatory.UI
{ {
Button button = new() Button button = new()
{ {
Text = settingName Text = settingName,
Width = Convert.ToInt32(_colWidth * 0.8),
Height = 35,
}; };
button.Click += (sender, e) => button.Click += (sender, e) =>
@ -229,7 +237,7 @@ namespace Observatory.UI
Orientation = Orientation.Horizontal, Orientation = Orientation.Horizontal,
TickStyle = TickStyle.Both, TickStyle = TickStyle.Both,
TickFrequency = tickFrequency, TickFrequency = tickFrequency,
Width = 200, Width = _colWidth,
Minimum = minBound, Minimum = minBound,
Maximum = maxBound, Maximum = maxBound,
}; };
@ -250,8 +258,7 @@ namespace Observatory.UI
SettingNumericBounds? bounds = (SettingNumericBounds?)System.Attribute.GetCustomAttribute(setting, typeof(SettingNumericBounds)); SettingNumericBounds? bounds = (SettingNumericBounds?)System.Attribute.GetCustomAttribute(setting, typeof(SettingNumericBounds));
NumericUpDown numericUpDown = new() NumericUpDown numericUpDown = new()
{ {
Width = _colWidth,
Width = 200,
Minimum = Convert.ToInt32(bounds?.Minimum ?? Int32.MinValue), Minimum = Convert.ToInt32(bounds?.Minimum ?? Int32.MinValue),
Maximum = Convert.ToInt32(bounds?.Maximum ?? Int32.MaxValue), Maximum = Convert.ToInt32(bounds?.Maximum ?? Int32.MaxValue),
Increment = Convert.ToInt32(bounds?.Increment ?? 1) Increment = Convert.ToInt32(bounds?.Increment ?? 1)
@ -275,7 +282,8 @@ namespace Observatory.UI
Text = setting.Value, Text = setting.Value,
TextAlign = System.Drawing.ContentAlignment.MiddleLeft, TextAlign = System.Drawing.ContentAlignment.MiddleLeft,
Checked = (bool?)setting.Key.GetValue(_plugin.Settings) ?? false, Checked = (bool?)setting.Key.GetValue(_plugin.Settings) ?? false,
Width = 200, Height = 30,
Width = _colWidth,
ForeColor = Color.LightGray ForeColor = Color.LightGray
}; };
@ -293,7 +301,7 @@ namespace Observatory.UI
TextBox textBox = new() TextBox textBox = new()
{ {
Text = (setting.GetValue(_plugin.Settings) ?? String.Empty).ToString(), Text = (setting.GetValue(_plugin.Settings) ?? String.Empty).ToString(),
Width = 200 Width = _colWidth,
}; };
textBox.TextChanged += (object? sender, EventArgs e) => textBox.TextChanged += (object? sender, EventArgs e) =>
@ -312,7 +320,7 @@ namespace Observatory.UI
TextBox textBox = new() TextBox textBox = new()
{ {
Text = fileInfo?.FullName ?? string.Empty, Text = fileInfo?.FullName ?? string.Empty,
Width = 200 Width = _colWidth,
}; };
textBox.TextChanged += (object? sender, EventArgs e) => textBox.TextChanged += (object? sender, EventArgs e) =>
@ -328,7 +336,9 @@ namespace Observatory.UI
{ {
Button button = new() Button button = new()
{ {
Text = "Browse" Text = "Browse",
Height = 35,
Width = _colWidth / 2,
}; };
button.Click += (object? sender, EventArgs e) => button.Click += (object? sender, EventArgs e) =>