Changeset 10433
- Timestamp:
- 01/31/14 17:34:11 (11 years ago)
- Location:
- trunk/sources
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/sources/HeuristicLab.Encodings.ScheduleEncoding.Views/3.3/JobView.Designer.cs
r9456 r10433 80 80 this.dueDateLabel.Name = "dueDateLabel"; 81 81 this.dueDateLabel.Size = new System.Drawing.Size(56, 13); 82 this.dueDateLabel.TabIndex = 0;82 this.dueDateLabel.TabIndex = 2; 83 83 this.dueDateLabel.Text = "Due Date:"; 84 84 // … … 90 90 this.dueDateTextBox.Name = "dueDateTextBox"; 91 91 this.dueDateTextBox.Size = new System.Drawing.Size(451, 20); 92 this.dueDateTextBox.TabIndex = 1;92 this.dueDateTextBox.TabIndex = 3; 93 93 this.dueDateTextBox.Validating += new System.ComponentModel.CancelEventHandler(this.dueDateTextBox_Validating); 94 94 // … … 101 101 this.tasksGroupBox.Name = "tasksGroupBox"; 102 102 this.tasksGroupBox.Size = new System.Drawing.Size(510, 214); 103 this.tasksGroupBox.TabIndex = 2;103 this.tasksGroupBox.TabIndex = 4; 104 104 this.tasksGroupBox.TabStop = false; 105 105 this.tasksGroupBox.Text = "Tasks"; -
trunk/sources/HeuristicLab.Encodings.ScheduleEncoding.Views/3.3/TaskView.Designer.cs
r9456 r10433 83 83 this.resourceNrLabel.Name = "resourceNrLabel"; 84 84 this.resourceNrLabel.Size = new System.Drawing.Size(70, 13); 85 this.resourceNrLabel.TabIndex = 0;85 this.resourceNrLabel.TabIndex = 2; 86 86 this.resourceNrLabel.Text = "Resource Nr:"; 87 87 // … … 93 93 this.resourceNrTextBox.Name = "resourceNrTextBox"; 94 94 this.resourceNrTextBox.Size = new System.Drawing.Size(437, 20); 95 this.resourceNrTextBox.TabIndex = 1;95 this.resourceNrTextBox.TabIndex = 3; 96 96 this.resourceNrTextBox.Validating += new System.ComponentModel.CancelEventHandler(this.resourceNrTextBox_Validating); 97 97 // … … 106 106 this.jobNrLabel.Name = "jobNrLabel"; 107 107 this.jobNrLabel.Size = new System.Drawing.Size(41, 13); 108 this.jobNrLabel.TabIndex = 0;108 this.jobNrLabel.TabIndex = 4; 109 109 this.jobNrLabel.Text = "Job Nr:"; 110 110 // … … 116 116 this.jobNrTextBox.Name = "jobNrTextBox"; 117 117 this.jobNrTextBox.Size = new System.Drawing.Size(437, 20); 118 this.jobNrTextBox.TabIndex = 1;118 this.jobNrTextBox.TabIndex = 5; 119 119 this.jobNrTextBox.Validating += new System.ComponentModel.CancelEventHandler(this.jobNrTextBox_Validating); 120 120 // … … 125 125 this.durationLabel.Name = "durationLabel"; 126 126 this.durationLabel.Size = new System.Drawing.Size(50, 13); 127 this.durationLabel.TabIndex = 0;127 this.durationLabel.TabIndex = 6; 128 128 this.durationLabel.Text = "Duration:"; 129 129 // … … 135 135 this.durationTextBox.Name = "durationTextBox"; 136 136 this.durationTextBox.Size = new System.Drawing.Size(437, 20); 137 this.durationTextBox.TabIndex = 1;137 this.durationTextBox.TabIndex = 7; 138 138 this.durationTextBox.Validating += new System.ComponentModel.CancelEventHandler(this.durationTextBox_Validating); 139 139 // -
trunk/sources/HeuristicLab.Encodings.ScheduleEncoding/3.3/ScheduleEncoding/Job.cs
r9456 r10433 20 20 #endregion 21 21 22 using System; 22 23 using System.ComponentModel; 23 24 using System.Text; 25 using HeuristicLab.Collections; 24 26 using HeuristicLab.Common; 25 27 using HeuristicLab.Core; … … 38 40 bool changed = dueDate != value; 39 41 dueDate = value; 40 if (changed) OnPropertyChanged("DueDate"); 42 if (changed) { 43 OnPropertyChanged("DueDate"); 44 OnToStringChanged(); 45 } 41 46 } 42 47 } … … 49 54 bool changed = index != value; 50 55 index = value; 51 if (changed) OnPropertyChanged("Index"); 56 if (changed) { 57 OnPropertyChanged("Index"); 58 OnToStringChanged(); 59 } 52 60 } 53 61 } … … 71 79 this.Index = original.Index; 72 80 this.Tasks = cloner.Clone(original.Tasks); 81 RegisterEventHandlers(); 73 82 } 74 83 public Job() : this(-1, double.MaxValue) { } … … 78 87 Index = index; 79 88 Tasks = new ItemList<Task>(); 89 RegisterEventHandlers(); 80 90 } 81 91 82 92 public override IDeepCloneable Clone(Cloner cloner) { 83 93 return new Job(this, cloner); 94 } 95 96 [StorableHook(HookType.AfterDeserialization)] 97 private void AfterDeserialization() { 98 RegisterEventHandlers(); 99 } 100 101 private void RegisterEventHandlers() { 102 Tasks.ItemsAdded += TasksOnItemsChanged; 103 Tasks.ItemsRemoved += TasksOnItemsChanged; 104 Tasks.ItemsReplaced += TasksOnItemsChanged; 105 Tasks.CollectionReset += TasksOnItemsChanged; 106 foreach (var task in Tasks) { 107 task.PropertyChanged += TaskOnPropertyChanged; 108 task.ToStringChanged += TaskOnToStringChanged; 109 } 110 } 111 112 private void TasksOnItemsChanged(object sender, CollectionItemsChangedEventArgs<IndexedItem<Task>> e) { 113 foreach (var task in e.OldItems) { 114 task.Value.PropertyChanged -= TaskOnPropertyChanged; 115 task.Value.ToStringChanged -= TaskOnToStringChanged; 116 } 117 foreach (var task in e.Items) { 118 task.Value.PropertyChanged += TaskOnPropertyChanged; 119 task.Value.ToStringChanged += TaskOnToStringChanged; 120 } 121 OnTasksChanged(); 122 OnToStringChanged(); 123 } 124 125 private void TaskOnPropertyChanged(object sender, EventArgs e) { 126 OnTasksChanged(); 127 } 128 129 private void TaskOnToStringChanged(object sender, EventArgs e) { 130 OnToStringChanged(); 84 131 } 85 132 … … 100 147 } 101 148 149 public event EventHandler TasksChanged; 150 protected virtual void OnTasksChanged() { 151 var handler = TasksChanged; 152 if (handler != null) handler(this, EventArgs.Empty); 153 } 154 102 155 public event PropertyChangedEventHandler PropertyChanged; 103 156 protected virtual void OnPropertyChanged(string propertyName) { -
trunk/sources/HeuristicLab.Encodings.ScheduleEncoding/3.3/ScheduleEncoding/Task.cs
r9456 r10433 38 38 bool changed = taskNr != value; 39 39 taskNr = value; 40 if (changed) OnPropertyChanged("TaskNr"); 40 if (changed) { 41 OnPropertyChanged("TaskNr"); 42 OnToStringChanged(); 43 } 41 44 } 42 45 } … … 48 51 bool changed = resourceNr != value; 49 52 resourceNr = value; 50 if (changed) OnPropertyChanged("ResourceNr"); 53 if (changed) { 54 OnPropertyChanged("ResourceNr"); 55 OnToStringChanged(); 56 } 51 57 } 52 58 } … … 115 121 } 116 122 117 public override bool Equals(object obj) {118 if (obj.GetType() == typeof(Task))119 return AreEqual(this, obj as Task);120 else121 return false;122 }123 124 public override int GetHashCode() {125 return TaskNr ^ JobNr;126 }127 128 public static bool AreEqual(Task task1, Task task2) {129 return (task1.Duration == task2.Duration &&130 task1.IsScheduled == task2.IsScheduled &&131 task1.JobNr == task2.JobNr &&132 task1.ResourceNr == task2.ResourceNr &&133 task1.TaskNr == task2.TaskNr);134 }135 136 123 public event PropertyChangedEventHandler PropertyChanged; 137 124 protected virtual void OnPropertyChanged(string propertyName) { -
trunk/sources/HeuristicLab.Problems.Scheduling.Views/3.3/JobShopSchedulingProblemView.cs
r10213 r10433 20 20 #endregion 21 21 22 using System; 22 23 using System.Windows.Forms; 24 using HeuristicLab.Collections; 25 using HeuristicLab.Encodings.ScheduleEncoding; 23 26 using HeuristicLab.MainForm; 24 27 using HeuristicLab.Optimization.Views; … … 43 46 protected override void OnContentChanged() { 44 47 base.OnContentChanged(); 45 if (Content == null) { 46 ganttChart.Reset(); 47 } else { 48 FillGanttChart(Content); 49 } 48 FillGanttChart(); 50 49 } 51 50 52 51 protected override void DeregisterContentEvents() { 53 Content.JobDataParameter.ValueChanged -= JobDataParameter_ValueChanged; 52 Content.JobDataParameter.ValueChanged -= JobDataParameterOnValueChanged; 53 Content.JobData.ItemsAdded -= JobsOnChanged; 54 Content.JobData.ItemsRemoved -= JobsOnChanged; 55 Content.JobData.ItemsReplaced -= JobsOnChanged; 56 Content.JobData.CollectionReset -= JobsOnChanged; 57 foreach (var job in Content.JobData) { 58 job.TasksChanged -= JobOnTasksChanged; 59 } 54 60 base.DeregisterContentEvents(); 55 61 } 56 62 protected override void RegisterContentEvents() { 57 63 base.RegisterContentEvents(); 58 Content.JobDataParameter.ValueChanged += JobDataParameter_ValueChanged; 59 } 60 61 void JobDataParameter_ValueChanged(object sender, System.EventArgs e) { 62 if (Content != null) { 63 FillGanttChart(Content); 64 Content.JobDataParameter.ValueChanged += JobDataParameterOnValueChanged; 65 Content.JobData.ItemsAdded += JobsOnChanged; 66 Content.JobData.ItemsRemoved += JobsOnChanged; 67 Content.JobData.ItemsReplaced += JobsOnChanged; 68 Content.JobData.CollectionReset += JobsOnChanged; 69 foreach (var job in Content.JobData) { 70 job.TasksChanged += JobOnTasksChanged; 64 71 } 65 72 } 66 73 67 private void FillGanttChart(JobShopSchedulingProblem content) { 74 private void JobsOnChanged(object sender, CollectionItemsChangedEventArgs<IndexedItem<Job>> e) { 75 foreach (var job in e.OldItems) 76 job.Value.TasksChanged -= JobOnTasksChanged; 77 foreach (var job in e.Items) 78 job.Value.TasksChanged += JobOnTasksChanged; 79 FillGanttChart(); 80 } 81 82 private void JobDataParameterOnValueChanged(object sender, EventArgs e) { 83 Content.JobData.ItemsAdded += JobsOnChanged; 84 Content.JobData.ItemsRemoved += JobsOnChanged; 85 Content.JobData.ItemsReplaced += JobsOnChanged; 86 Content.JobData.CollectionReset += JobsOnChanged; 87 foreach (var job in Content.JobData) { 88 job.TasksChanged += JobOnTasksChanged; 89 } 90 FillGanttChart(); 91 } 92 93 private void JobOnTasksChanged(object sender, EventArgs e) { 94 FillGanttChart(); 95 } 96 97 private void FillGanttChart() { 68 98 ganttChart.Reset(); 99 if (Content == null) return; 69 100 int jobCount = 0; 70 foreach (var j in content.JobData) {101 foreach (var j in Content.JobData) { 71 102 double lastEndTime = 0; 72 foreach (var t in content.JobData[jobCount].Tasks) {103 foreach (var t in Content.JobData[jobCount].Tasks) { 73 104 int categoryNr = t.JobNr; 74 105 string categoryName = "Job" + categoryNr; … … 78 109 lastEndTime + 1, 79 110 lastEndTime + t.Duration, 80 "Job" + t.JobNr + " - " + "Task#" + t.TaskNr .ToString());111 "Job" + t.JobNr + " - " + "Task#" + t.TaskNr); 81 112 lastEndTime += t.Duration; 82 113 }
Note: See TracChangeset
for help on using the changeset viewer.