using System; using System.Drawing; using System.Collections.Generic; using HeuristicLab.Visualization.LabelProvider; namespace HeuristicLab.Visualization { public enum Action { Added, Modified, Deleted } public delegate void DataRowChangedHandler(IDataRow row); public delegate void ValuesChangedHandler(IDataRow row, double[] values, int index, Action action); public delegate void ValueChangedHandler(IDataRow row, double value, int index, Action action); public class DataRow : DataRowBase { private readonly List dataRow = new List(); // TODO implement calculation of min and max values private double minValue = double.MaxValue; private double maxValue = double.MinValue; public DataRow() { } public DataRow(string label) { this.Label = label; } public DataRow(string label, Color color, int thickness, DrawingStyle style, List dataRow) { this.Label = label; this.Color = color; this.Thickness = thickness; this.Style = style; this.dataRow = dataRow; } public override void AddValue(double value) { UpdateMinMaxValue(value); dataRow.Add(value); OnValueChanged(value, dataRow.Count - 1, Action.Added); } public override void AddValue(double value, int index) { //check if index is valid if (index >= 0 && index < dataRow.Count) { dataRow.Insert(index, value); OnValueChanged(value, index, Action.Added); } else { throw new IndexOutOfRangeException(); } } public override void AddValues(double[] values) { int startInd = dataRow.Count; foreach (double d in values) { dataRow.Add(d); } OnValuesChanged(values, startInd, Action.Added); } public override void AddValues(double[] values, int index) { int j = index; //check if index to start changes is valid if (index >=0 && (index + values.Length) < dataRow.Count) { foreach (double d in values) { dataRow.Insert(j, d); j++; } OnValuesChanged(values, index, Action.Added); } else { throw new IndexOutOfRangeException(); } } public override void ModifyValue(double value, int index) { //check if index is valid if (index >= 0 && index < dataRow.Count) { dataRow[index] = value; OnValueChanged(value, index, Action.Modified); } else { throw new IndexOutOfRangeException(); } } public override void ModifyValues(double[] values, int index) { int startInd = index; int modInd = index; //check if index to start modification is valid if (startInd >=0 && startInd + values.Length < dataRow.Count) { foreach (double d in values) { dataRow[modInd] = d; modInd++; } OnValuesChanged(values, startInd, Action.Modified); } else { throw new IndexOutOfRangeException(); } } public override void RemoveValue(int index) { double remVal = dataRow[index]; //check if index is valid if (index >= 0 && index < dataRow.Count) { dataRow.RemoveAt(index); OnValueChanged(remVal, index, Action.Deleted); } else { throw new IndexOutOfRangeException(); } } public override void RemoveValues(int index, int count) { double[] remValues = new double[count]; //removed values int j = 0; //check if count is valid if (count > 0) { //check if index is valid if ((index >= 0) && (index + count <= dataRow.Count)) { for (int i = index; i < (index + count); i++) { remValues.SetValue(i, j); dataRow.RemoveAt(i); j++; } OnValuesChanged(remValues, index, Action.Deleted); } else { throw new IndexOutOfRangeException(); } } else { throw new Exception("parameter count must be > 0!"); } } public override int Count { get { return dataRow.Count; } } public override double this[int index] { get { return dataRow[index]; } set { dataRow[index] = value; OnValueChanged(value, index, Action.Modified); } } public override double MinValue { get { return minValue; } } public override double MaxValue { get { return maxValue; } } private void UpdateMinMaxValue(double value) { maxValue = Math.Max(value, maxValue); minValue = Math.Min(value, minValue); } } }