#region License Information /* HeuristicLab * Copyright (C) 2002-2008 Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * HeuristicLab is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with HeuristicLab. If not, see . */ #endregion using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; using System.Data; using System.Text; using System.Windows.Forms; using HeuristicLab.MainForm; namespace HeuristicLab.Data { /// /// The visual representation of the class , /// symbolizing an array of double values. /// [Content(typeof(DoubleArrayData), true)] public partial class DoubleArrayDataView : ArrayDataBaseView { /// /// Gets or sets the double array to represent as . /// /// Uses property of /// base class . No own data storage present. public DoubleArrayData DoubleArrayData { get { return (DoubleArrayData)base.ArrayDataBase; } set { base.ArrayDataBase = value; } } /// /// Initializes a new instance of the class . /// public DoubleArrayDataView() { InitializeComponent(); // round-trip format for all cells dataGridView.DefaultCellStyle.Format = "r"; } /// /// Initializes a new instance of the class with the given /// . /// No CopyConstructor! is not copied! /// /// The double array to represent visually. public DoubleArrayDataView(DoubleArrayData doubleArrayData) : this() { DoubleArrayData = doubleArrayData; } /// /// Sets the element on position to the /// given as double value. /// /// The position where to substitute the element. /// The element to insert. protected override void SetArrayElement(int index, string element) { double result; double.TryParse(element, out result); DoubleArrayData.Data[index] = result; } /// /// Checks whether the given can be converted to a double value. /// /// The data to validate. /// true if the could be converted, /// false otherwise. protected override bool ValidateData(string element) { double result; return element != null && double.TryParse(element, out result); } } }