mirror of
				https://github.com/9ParsonsB/Pulsar.git
				synced 2025-10-26 04:49:50 -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:
		
							
								
								
									
										1
									
								
								ObservatoryCore/UI/CoreForm.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								ObservatoryCore/UI/CoreForm.Designer.cs
									
									
									
										generated
									
									
									
								
							| @@ -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; | ||||||
|   | |||||||
| @@ -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; | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								ObservatoryCore/UI/SettingsForm.Designer.cs
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										3
									
								
								ObservatoryCore/UI/SettingsForm.Designer.cs
									
									
									
										generated
									
									
									
								
							| @@ -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); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -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) => | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user