Changeset 16692 for branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views
- Timestamp:
- 03/18/19 17:24:30 (6 years ago)
- Location:
- branches/2521_ProblemRefactoring
- Files:
-
- 9 edited
- 2 copied
Legend:
- Unmodified
- Added
- Removed
-
branches/2521_ProblemRefactoring
- Property svn:ignore
-
old new 24 24 protoc.exe 25 25 obj 26 .vs
-
- Property svn:mergeinfo changed
- Property svn:ignore
-
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBAlgorithmView.Designer.cs
r12012 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBAlgorithmView.cs
r12012 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. … … 324 324 if (Content != null) Content.StoreAlgorithmInEachRun = storeAlgorithmInEachRunCheckBox.Checked; 325 325 } 326 private void startButton_Click(object sender, EventArgs e) {327 Content.Start();326 private async void startButton_Click(object sender, EventArgs e) { 327 await Content.StartAsync(); 328 328 } 329 329 private void pauseButton_Click(object sender, EventArgs e) { -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBExperimentUploadView.Designer.cs
r12971 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBExperimentUploadView.cs
r12971 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBProblemView.Designer.cs
r12012 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. … … 49 49 this.refreshButton = new System.Windows.Forms.Button(); 50 50 this.cloneProblemButton = new System.Windows.Forms.Button(); 51 this.tabControl = new System.Windows.Forms.TabControl(); 52 this.parametersTabPage = new System.Windows.Forms.TabPage(); 51 53 this.parameterCollectionView = new HeuristicLab.Core.Views.ParameterCollectionView(); 54 this.solutionsTabPage = new System.Windows.Forms.TabPage(); 55 this.flaAnalysisTabPage = new System.Windows.Forms.TabPage(); 56 this.flaSplitContainer = new System.Windows.Forms.SplitContainer(); 57 this.calculateButton = new System.Windows.Forms.Button(); 58 this.characteristicsMatrixView = new HeuristicLab.Data.Views.StringConvertibleMatrixView(); 59 this.uploadCharacteristicsButton = new System.Windows.Forms.Button(); 60 this.downloadCharacteristicsButton = new System.Windows.Forms.Button(); 61 this.solutionsViewHost = new HeuristicLab.MainForm.WindowsForms.ViewHost(); 62 this.refreshSolutionsButton = new System.Windows.Forms.Button(); 63 this.uploadSolutionsButton = new System.Windows.Forms.Button(); 52 64 ((System.ComponentModel.ISupportInitialize)(this.errorProvider)).BeginInit(); 65 this.tabControl.SuspendLayout(); 66 this.parametersTabPage.SuspendLayout(); 67 this.solutionsTabPage.SuspendLayout(); 68 this.flaAnalysisTabPage.SuspendLayout(); 69 ((System.ComponentModel.ISupportInitialize)(this.flaSplitContainer)).BeginInit(); 70 this.flaSplitContainer.Panel1.SuspendLayout(); 71 this.flaSplitContainer.Panel2.SuspendLayout(); 72 this.flaSplitContainer.SuspendLayout(); 53 73 this.SuspendLayout(); 54 74 // … … 58 78 this.errorProvider.SetIconPadding(this.nameTextBox, 2); 59 79 this.nameTextBox.Location = new System.Drawing.Point(72, 27); 60 this.nameTextBox.Size = new System.Drawing.Size(6 04, 20);80 this.nameTextBox.Size = new System.Drawing.Size(640, 20); 61 81 this.nameTextBox.TabIndex = 5; 62 82 // … … 68 88 // infoLabel 69 89 // 70 this.infoLabel.Location = new System.Drawing.Point( 687, 30);90 this.infoLabel.Location = new System.Drawing.Point(723, 30); 71 91 this.infoLabel.TabIndex = 6; 72 92 // 73 93 // problemComboBox 74 94 // 75 this.problemComboBox.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) 76 95 this.problemComboBox.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) 96 | System.Windows.Forms.AnchorStyles.Right))); 77 97 this.problemComboBox.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; 78 98 this.problemComboBox.FormattingEnabled = true; 79 99 this.problemComboBox.Location = new System.Drawing.Point(72, 0); 80 100 this.problemComboBox.Name = "problemComboBox"; 81 this.problemComboBox.Size = new System.Drawing.Size( 574, 21);101 this.problemComboBox.Size = new System.Drawing.Size(610, 21); 82 102 this.problemComboBox.TabIndex = 1; 83 103 this.problemComboBox.SelectedValueChanged += new System.EventHandler(this.problemComboBox_SelectedValueChanged); … … 95 115 // 96 116 this.refreshButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); 97 this.refreshButton.Image = HeuristicLab.Common.Resources.VSImageLibrary.Refresh; 98 this.refreshButton.Location = new System.Drawing.Point(682, -1); 117 this.refreshButton.Location = new System.Drawing.Point(718, -1); 99 118 this.refreshButton.Name = "refreshButton"; 100 119 this.refreshButton.Size = new System.Drawing.Size(24, 24); … … 107 126 // 108 127 this.cloneProblemButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); 109 this.cloneProblemButton.Image = HeuristicLab.Common.Resources.VSImageLibrary.Clone; 110 this.cloneProblemButton.Location = new System.Drawing.Point(652, -1); 128 this.cloneProblemButton.Location = new System.Drawing.Point(688, -1); 111 129 this.cloneProblemButton.Name = "cloneProblemButton"; 112 130 this.cloneProblemButton.Size = new System.Drawing.Size(24, 24); … … 116 134 this.cloneProblemButton.Click += new System.EventHandler(this.cloneProblemButton_Click); 117 135 // 136 // tabControl 137 // 138 this.tabControl.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) 139 | System.Windows.Forms.AnchorStyles.Left) 140 | System.Windows.Forms.AnchorStyles.Right))); 141 this.tabControl.Controls.Add(this.parametersTabPage); 142 this.tabControl.Controls.Add(this.solutionsTabPage); 143 this.tabControl.Controls.Add(this.flaAnalysisTabPage); 144 this.tabControl.Location = new System.Drawing.Point(6, 53); 145 this.tabControl.Name = "tabControl"; 146 this.tabControl.SelectedIndex = 0; 147 this.tabControl.Size = new System.Drawing.Size(736, 473); 148 this.tabControl.TabIndex = 8; 149 // 150 // parametersTabPage 151 // 152 this.parametersTabPage.Controls.Add(this.parameterCollectionView); 153 this.parametersTabPage.Location = new System.Drawing.Point(4, 22); 154 this.parametersTabPage.Name = "parametersTabPage"; 155 this.parametersTabPage.Padding = new System.Windows.Forms.Padding(3); 156 this.parametersTabPage.Size = new System.Drawing.Size(728, 447); 157 this.parametersTabPage.TabIndex = 0; 158 this.parametersTabPage.Text = "Parameters"; 159 this.parametersTabPage.UseVisualStyleBackColor = true; 160 // 118 161 // parameterCollectionView 119 162 // 120 163 this.parameterCollectionView.AllowEditingOfHiddenParameters = false; 121 this.parameterCollectionView.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)122 | System.Windows.Forms.AnchorStyles.Left)123 | System.Windows.Forms.AnchorStyles.Right)));124 164 this.parameterCollectionView.Caption = "ParameterCollection View"; 125 165 this.parameterCollectionView.Content = null; 126 this.parameterCollectionView.Location = new System.Drawing.Point(0, 53); 166 this.parameterCollectionView.Dock = System.Windows.Forms.DockStyle.Fill; 167 this.parameterCollectionView.Location = new System.Drawing.Point(3, 3); 127 168 this.parameterCollectionView.Name = "parameterCollectionView"; 128 this.parameterCollectionView.ReadOnly = false; 129 this.parameterCollectionView.Size = new System.Drawing.Size(706, 340); 130 this.parameterCollectionView.TabIndex = 7; 169 this.parameterCollectionView.ReadOnly = true; 170 this.parameterCollectionView.ShowDetails = true; 171 this.parameterCollectionView.Size = new System.Drawing.Size(722, 441); 172 this.parameterCollectionView.TabIndex = 8; 173 // 174 // solutionsTabPage 175 // 176 this.solutionsTabPage.Controls.Add(this.uploadSolutionsButton); 177 this.solutionsTabPage.Controls.Add(this.refreshSolutionsButton); 178 this.solutionsTabPage.Controls.Add(this.solutionsViewHost); 179 this.solutionsTabPage.Location = new System.Drawing.Point(4, 22); 180 this.solutionsTabPage.Name = "solutionsTabPage"; 181 this.solutionsTabPage.Padding = new System.Windows.Forms.Padding(3); 182 this.solutionsTabPage.Size = new System.Drawing.Size(728, 447); 183 this.solutionsTabPage.TabIndex = 3; 184 this.solutionsTabPage.Text = "Solutions"; 185 this.solutionsTabPage.UseVisualStyleBackColor = true; 186 // 187 // flaAnalysisTabPage 188 // 189 this.flaAnalysisTabPage.Controls.Add(this.flaSplitContainer); 190 this.flaAnalysisTabPage.Location = new System.Drawing.Point(4, 22); 191 this.flaAnalysisTabPage.Name = "flaAnalysisTabPage"; 192 this.flaAnalysisTabPage.Padding = new System.Windows.Forms.Padding(3); 193 this.flaAnalysisTabPage.Size = new System.Drawing.Size(728, 447); 194 this.flaAnalysisTabPage.TabIndex = 2; 195 this.flaAnalysisTabPage.Text = "Fitness Landscape Analysis"; 196 this.flaAnalysisTabPage.UseVisualStyleBackColor = true; 197 // 198 // flaSplitContainer 199 // 200 this.flaSplitContainer.Dock = System.Windows.Forms.DockStyle.Fill; 201 this.flaSplitContainer.FixedPanel = System.Windows.Forms.FixedPanel.Panel2; 202 this.flaSplitContainer.Location = new System.Drawing.Point(3, 3); 203 this.flaSplitContainer.Name = "flaSplitContainer"; 204 // 205 // flaSplitContainer.Panel1 206 // 207 this.flaSplitContainer.Panel1.Controls.Add(this.calculateButton); 208 // 209 // flaSplitContainer.Panel2 210 // 211 this.flaSplitContainer.Panel2.Controls.Add(this.characteristicsMatrixView); 212 this.flaSplitContainer.Panel2.Controls.Add(this.uploadCharacteristicsButton); 213 this.flaSplitContainer.Panel2.Controls.Add(this.downloadCharacteristicsButton); 214 this.flaSplitContainer.Size = new System.Drawing.Size(722, 441); 215 this.flaSplitContainer.SplitterDistance = 363; 216 this.flaSplitContainer.TabIndex = 7; 217 // 218 // calculateButton 219 // 220 this.calculateButton.Location = new System.Drawing.Point(3, 3); 221 this.calculateButton.Name = "calculateButton"; 222 this.calculateButton.Size = new System.Drawing.Size(26, 23); 223 this.calculateButton.TabIndex = 8; 224 this.calculateButton.Text = "Calculate"; 225 this.calculateButton.UseVisualStyleBackColor = true; 226 this.calculateButton.Click += new System.EventHandler(this.calculateButton_Click); 227 // 228 // characteristicsMatrixView 229 // 230 this.characteristicsMatrixView.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) 231 | System.Windows.Forms.AnchorStyles.Left) 232 | System.Windows.Forms.AnchorStyles.Right))); 233 this.characteristicsMatrixView.Caption = "StringConvertibleMatrix View"; 234 this.characteristicsMatrixView.Content = null; 235 this.characteristicsMatrixView.Location = new System.Drawing.Point(3, 32); 236 this.characteristicsMatrixView.Name = "characteristicsMatrixView"; 237 this.characteristicsMatrixView.ReadOnly = false; 238 this.characteristicsMatrixView.ShowRowsAndColumnsTextBox = false; 239 this.characteristicsMatrixView.ShowStatisticalInformation = false; 240 this.characteristicsMatrixView.Size = new System.Drawing.Size(349, 406); 241 this.characteristicsMatrixView.TabIndex = 4; 242 // 243 // uploadCharacteristicsButton 244 // 245 this.uploadCharacteristicsButton.Location = new System.Drawing.Point(35, 3); 246 this.uploadCharacteristicsButton.Name = "uploadCharacteristicsButton"; 247 this.uploadCharacteristicsButton.Size = new System.Drawing.Size(26, 23); 248 this.uploadCharacteristicsButton.TabIndex = 5; 249 this.uploadCharacteristicsButton.Text = "Upload"; 250 this.uploadCharacteristicsButton.UseVisualStyleBackColor = true; 251 this.uploadCharacteristicsButton.Click += new System.EventHandler(this.uploadCharacteristicsButton_Click); 252 // 253 // downloadCharacteristicsButton 254 // 255 this.downloadCharacteristicsButton.Location = new System.Drawing.Point(3, 3); 256 this.downloadCharacteristicsButton.Name = "downloadCharacteristicsButton"; 257 this.downloadCharacteristicsButton.Size = new System.Drawing.Size(26, 23); 258 this.downloadCharacteristicsButton.TabIndex = 6; 259 this.downloadCharacteristicsButton.Text = "Download"; 260 this.downloadCharacteristicsButton.UseVisualStyleBackColor = true; 261 this.downloadCharacteristicsButton.Click += new System.EventHandler(this.downloadCharacteristicsButton_Click); 262 // 263 // solutionsViewHost 264 // 265 this.solutionsViewHost.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) 266 | System.Windows.Forms.AnchorStyles.Left) 267 | System.Windows.Forms.AnchorStyles.Right))); 268 this.solutionsViewHost.Caption = "View"; 269 this.solutionsViewHost.Content = null; 270 this.solutionsViewHost.Enabled = false; 271 this.solutionsViewHost.Location = new System.Drawing.Point(0, 35); 272 this.solutionsViewHost.Name = "solutionsViewHost"; 273 this.solutionsViewHost.ReadOnly = false; 274 this.solutionsViewHost.Size = new System.Drawing.Size(728, 412); 275 this.solutionsViewHost.TabIndex = 0; 276 this.solutionsViewHost.ViewsLabelVisible = true; 277 this.solutionsViewHost.ViewType = null; 278 // 279 // refreshSolutionsButton 280 // 281 this.refreshSolutionsButton.Location = new System.Drawing.Point(6, 6); 282 this.refreshSolutionsButton.Name = "refreshSolutionsButton"; 283 this.refreshSolutionsButton.Size = new System.Drawing.Size(26, 23); 284 this.refreshSolutionsButton.TabIndex = 1; 285 this.refreshSolutionsButton.Text = "Refresh"; 286 this.refreshSolutionsButton.UseVisualStyleBackColor = true; 287 this.refreshSolutionsButton.Click += new System.EventHandler(this.refreshSolutionsButton_Click); 288 // 289 // uploadSolutionsButton 290 // 291 this.uploadSolutionsButton.Location = new System.Drawing.Point(38, 6); 292 this.uploadSolutionsButton.Name = "uploadSolutionsButton"; 293 this.uploadSolutionsButton.Size = new System.Drawing.Size(26, 23); 294 this.uploadSolutionsButton.TabIndex = 1; 295 this.uploadSolutionsButton.Text = "Upload"; 296 this.uploadSolutionsButton.UseVisualStyleBackColor = true; 297 this.uploadSolutionsButton.Click += new System.EventHandler(this.uploadSolutionsButton_Click); 131 298 // 132 299 // OKBProblemView … … 134 301 this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); 135 302 this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; 303 this.Controls.Add(this.tabControl); 136 304 this.Controls.Add(this.problemComboBox); 137 this.Controls.Add(this.parameterCollectionView);138 305 this.Controls.Add(this.problemLabel); 139 306 this.Controls.Add(this.cloneProblemButton); 140 307 this.Controls.Add(this.refreshButton); 141 308 this.Name = "OKBProblemView"; 142 this.Size = new System.Drawing.Size(7 06, 393);309 this.Size = new System.Drawing.Size(742, 526); 143 310 this.Controls.SetChildIndex(this.refreshButton, 0); 144 311 this.Controls.SetChildIndex(this.cloneProblemButton, 0); 145 312 this.Controls.SetChildIndex(this.problemLabel, 0); 146 this.Controls.SetChildIndex(this.parameterCollectionView, 0); 313 this.Controls.SetChildIndex(this.problemComboBox, 0); 314 this.Controls.SetChildIndex(this.tabControl, 0); 147 315 this.Controls.SetChildIndex(this.nameTextBox, 0); 148 316 this.Controls.SetChildIndex(this.nameLabel, 0); 149 317 this.Controls.SetChildIndex(this.infoLabel, 0); 150 this.Controls.SetChildIndex(this.problemComboBox, 0);151 318 ((System.ComponentModel.ISupportInitialize)(this.errorProvider)).EndInit(); 319 this.tabControl.ResumeLayout(false); 320 this.parametersTabPage.ResumeLayout(false); 321 this.solutionsTabPage.ResumeLayout(false); 322 this.flaAnalysisTabPage.ResumeLayout(false); 323 this.flaSplitContainer.Panel1.ResumeLayout(false); 324 this.flaSplitContainer.Panel2.ResumeLayout(false); 325 ((System.ComponentModel.ISupportInitialize)(this.flaSplitContainer)).EndInit(); 326 this.flaSplitContainer.ResumeLayout(false); 152 327 this.ResumeLayout(false); 153 328 this.PerformLayout(); … … 161 336 private System.Windows.Forms.Button refreshButton; 162 337 private System.Windows.Forms.Button cloneProblemButton; 163 private HeuristicLab.Core.Views.ParameterCollectionView parameterCollectionView; 338 private System.Windows.Forms.TabControl tabControl; 339 private System.Windows.Forms.TabPage parametersTabPage; 340 private Core.Views.ParameterCollectionView parameterCollectionView; 341 private System.Windows.Forms.TabPage flaAnalysisTabPage; 342 private System.Windows.Forms.Button calculateButton; 343 private System.Windows.Forms.SplitContainer flaSplitContainer; 344 private Data.Views.StringConvertibleMatrixView characteristicsMatrixView; 345 private System.Windows.Forms.Button uploadCharacteristicsButton; 346 private System.Windows.Forms.Button downloadCharacteristicsButton; 347 private System.Windows.Forms.TabPage solutionsTabPage; 348 private MainForm.WindowsForms.ViewHost solutionsViewHost; 349 private System.Windows.Forms.Button uploadSolutionsButton; 350 private System.Windows.Forms.Button refreshSolutionsButton; 164 351 165 352 -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBProblemView.cs
r12012 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. … … 20 20 #endregion 21 21 22 using HeuristicLab.Common.Resources; 23 using HeuristicLab.Core; 24 using HeuristicLab.Core.Views; 25 using HeuristicLab.Data; 26 using HeuristicLab.MainForm; 27 using HeuristicLab.Optimization; 28 using HeuristicLab.PluginInfrastructure; 22 29 using System; 30 using System.Collections.Generic; 31 using System.Drawing; 23 32 using System.Linq; 24 33 using System.Windows.Forms; 25 using HeuristicLab.Core.Views;26 using HeuristicLab.MainForm;27 34 28 35 namespace HeuristicLab.Clients.OKB.RunCreation { … … 31 38 [Content(typeof(MultiObjectiveOKBProblem), true)] 32 39 public sealed partial class OKBProblemView : NamedItemView { 40 private readonly CheckedItemList<ICharacteristicCalculator> calculatorList; 41 33 42 public new OKBProblem Content { 34 43 get { return (OKBProblem)base.Content; } … … 38 47 public OKBProblemView() { 39 48 InitializeComponent(); 49 var calculatorListView = new CheckedItemListView<ICharacteristicCalculator>() { 50 Anchor = AnchorStyles.Left | AnchorStyles.Bottom | AnchorStyles.Right | AnchorStyles.Top, 51 Location = new Point(flaSplitContainer.Padding.Left, calculateButton.Location.Y + calculateButton.Height + calculateButton.Padding.Bottom + 3), 52 }; 53 calculatorListView.Size = new Size(flaSplitContainer.Panel1.Size.Width - flaSplitContainer.Panel1.Padding.Horizontal, 54 flaSplitContainer.Panel1.Height - calculatorListView.Location.Y - flaSplitContainer.Panel1.Padding.Bottom); 55 calculatorList = new CheckedItemList<ICharacteristicCalculator>(); 56 calculatorList.ItemsAdded += CalculatorListOnChanged; 57 calculatorList.ItemsRemoved += CalculatorListOnChanged; 58 calculatorList.ItemsReplaced += CalculatorListOnChanged; 59 calculatorList.CollectionReset += CalculatorListOnChanged; 60 calculatorList.CheckedItemsChanged += CalculatorListOnChanged; 61 62 calculatorListView.Content = calculatorList.AsReadOnly(); 63 64 flaSplitContainer.Panel1.Controls.Add(calculatorListView); 65 calculateButton.Text = string.Empty; 66 calculateButton.Image = VSImageLibrary.Play; 67 refreshButton.Text = string.Empty; 68 refreshButton.Image = VSImageLibrary.Refresh; 69 cloneProblemButton.Text = string.Empty; 70 cloneProblemButton.Image = VSImageLibrary.Clone; 71 downloadCharacteristicsButton.Text = string.Empty; 72 downloadCharacteristicsButton.Image = VSImageLibrary.Refresh; 73 uploadCharacteristicsButton.Text = string.Empty; 74 uploadCharacteristicsButton.Image = VSImageLibrary.PublishToWeb; 75 refreshSolutionsButton.Text = string.Empty; 76 refreshSolutionsButton.Image = VSImageLibrary.Refresh; 77 uploadSolutionsButton.Text = string.Empty; 78 uploadSolutionsButton.Image = VSImageLibrary.PublishToWeb; 79 } 80 81 private void CalculatorListOnChanged(object sender, EventArgs e) { 82 SetEnabledStateOfControls(); 40 83 } 41 84 … … 54 97 base.RegisterContentEvents(); 55 98 Content.ProblemChanged += new EventHandler(Content_ProblemChanged); 99 Content.Solutions.ItemsAdded += SolutionsOnChanged; 100 Content.Solutions.ItemsReplaced += SolutionsOnChanged; 101 Content.Solutions.ItemsRemoved += SolutionsOnChanged; 102 Content.Solutions.CollectionReset += SolutionsOnChanged; 103 } 104 105 private void SolutionsOnChanged(object sender, EventArgs e) { 106 if (InvokeRequired) { Invoke((Action<object, EventArgs>)SolutionsOnChanged, sender, e); return; } 107 SetEnabledStateOfControls(); 56 108 } 57 109 … … 61 113 problemComboBox.SelectedIndex = -1; 62 114 parameterCollectionView.Content = null; 115 solutionsViewHost.Content = null; 63 116 } else { 64 117 problemComboBox.SelectedItem = RunCreationClient.Instance.Problems.FirstOrDefault(x => x.Id == Content.ProblemId); 65 118 parameterCollectionView.Content = Content.Parameters; 66 } 119 solutionsViewHost.Content = Content.Solutions; 120 } 121 UpdateCharacteristicCalculators(); 67 122 } 68 123 … … 73 128 refreshButton.Enabled = (Content != null) && !ReadOnly && !Locked; 74 129 parameterCollectionView.Enabled = Content != null; 130 characteristicsMatrixView.Enabled = Content != null; 131 downloadCharacteristicsButton.Enabled = Content != null && Content.ProblemId != -1 && !Locked; 132 uploadCharacteristicsButton.Enabled = Content != null && Content.ProblemId != -1 && !Locked && !ReadOnly 133 && characteristicsMatrixView.Content != null && characteristicsMatrixView.Content.Rows > 0; 134 calculateButton.Enabled = Content != null && Content.ProblemId != -1 && !Locked && !ReadOnly && calculatorList.CheckedItems.Any(); 135 refreshSolutionsButton.Enabled = Content != null && !ReadOnly && !Locked && Content.ProblemId != -1; 136 uploadSolutionsButton.Enabled = Content != null && !ReadOnly && !Locked && Content.ProblemId != -1 && Content.Solutions.Any(x => x.SolutionId == -1); 75 137 } 76 138 … … 79 141 RunCreationClient.Instance.Refreshed -= new EventHandler(RunCreationClient_Refreshed); 80 142 base.OnClosed(e); 143 } 144 145 private void UpdateCharacteristicCalculators() { 146 calculatorList.Clear(); 147 if (Content == null || Content.ProblemId == -1) return; 148 var problem = Content.CloneProblem(); 149 var calculators = ApplicationManager.Manager.GetInstances<ICharacteristicCalculator>().ToList(); 150 foreach (var calc in calculators) { 151 calc.Problem = problem; 152 if (!calc.CanCalculate()) continue; 153 calculatorList.Add(calc, true); 154 } 81 155 } 82 156 … … 103 177 if (InvokeRequired) 104 178 Invoke(new EventHandler(Content_ProblemChanged), sender, e); 105 else 179 else { 106 180 OnContentChanged(); 181 SetEnabledStateOfControls(); 182 } 107 183 } 108 184 #endregion … … 123 199 } 124 200 } 201 private void downloadCharacteristicsButton_Click(object sender, EventArgs e) { 202 var values = RunCreationClient.Instance.GetCharacteristicValues(Content.ProblemId).ToList(); 203 var content = new StringMatrix(values.Count, 3); 204 for (var i = 0; i < values.Count; i++) { 205 content[i, 0] = values[i].Name; 206 content[i, 1] = values[i].GetValue(); 207 content[i, 2] = values[i].GetType().Name; 208 } 209 characteristicsMatrixView.Content = content; 210 SetEnabledStateOfControls(); 211 } 212 private void uploadCharacteristicsButton_Click(object sender, EventArgs e) { 213 var matrix = characteristicsMatrixView.Content as StringMatrix; 214 if (matrix == null) return; 215 var values = new List<Value>(matrix.Rows); 216 for (var i = 0; i < matrix.Rows; i++) { 217 var name = matrix[i, 0]; 218 var strValue = matrix[i, 1]; 219 var type = matrix[i, 2]; 220 values.Add(Value.Create(name, strValue, type)); 221 } 222 try { 223 RunCreationClient.Instance.SetCharacteristicValues(Content.ProblemId, values); 224 } catch (Exception ex) { ErrorHandling.ShowErrorDialog(ex); } 225 } 226 private void calculateButton_Click(object sender, EventArgs e) { 227 var calculators = calculatorList.CheckedItems.Select(x => x.Value).Where(x => x.CanCalculate()).ToList(); 228 if (calculators.Count == 0) return; 229 230 var results = new Dictionary<string, Value>(); 231 foreach (var calc in calculators) { 232 foreach (var result in calc.Calculate()) 233 results[result.Name] = RunCreationClient.Instance.ConvertToValue(result.Value, result.Name); 234 } 235 var matrix = (characteristicsMatrixView.Content as StringMatrix) ?? (new StringMatrix(results.Count, 3)); 236 try { 237 for (var i = 0; i < matrix.Rows; i++) { 238 Value r; 239 if (results.TryGetValue(matrix[i, 0], out r)) { 240 matrix[i, 1] = r.GetValue(); 241 matrix[i, 2] = r.GetType().Name; 242 results.Remove(matrix[i, 0]); 243 } 244 } 245 if (results.Count == 0) return; 246 var resultsList = results.ToList(); 247 var counter = resultsList.Count - 1; 248 for (var i = 0; i < matrix.Rows; i++) { 249 if (string.IsNullOrEmpty(matrix[i, 0])) { 250 matrix[i, 0] = resultsList[counter].Key; 251 matrix[i, 1] = resultsList[counter].Value.GetValue(); 252 matrix[i, 2] = resultsList[counter].Value.GetType().Name; 253 resultsList.RemoveAt(counter); 254 counter--; 255 if (counter < 0) return; 256 } 257 } 258 if (counter >= 0) { 259 ((IStringConvertibleMatrix)matrix).Rows += counter + 1; 260 for (var i = matrix.Rows - 1; counter >= 0; i--) { 261 matrix[i, 0] = resultsList[0].Key; 262 matrix[i, 1] = resultsList[0].Value.GetValue(); 263 matrix[i, 2] = resultsList[0].Value.GetType().Name; 264 resultsList.RemoveAt(0); 265 counter--; 266 } 267 } 268 } finally { 269 characteristicsMatrixView.Content = matrix; 270 SetEnabledStateOfControls(); 271 } 272 } 125 273 #endregion 126 274 … … 132 280 } 133 281 #endregion 282 283 private void refreshSolutionsButton_Click(object sender, EventArgs e) { 284 Content.RefreshSolutions(); 285 } 286 287 private void uploadSolutionsButton_Click(object sender, EventArgs e) { 288 foreach (var solution in Content.Solutions.Where(x => x.SolutionId == -1)) 289 solution.Upload(); 290 SetEnabledStateOfControls(); 291 } 292 134 293 } 135 294 } -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBRunView.Designer.cs
r12012 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. -
branches/2521_ProblemRefactoring/HeuristicLab.Clients.OKB.Views/3.3/RunCreation/Views/OKBRunView.cs
r12012 r16692 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 5Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2018 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab.
Note: See TracChangeset
for help on using the changeset viewer.