#region License Information /* HeuristicLab * Copyright (C) 2002-2019 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.Globalization; using System.Windows.Forms; using HeuristicLab.Problems.DataAnalysis; namespace HeuristicLab.Algorithms.DataAnalysis.Views { public partial class DensityTrackbar : UserControl { public decimal Value { get { return TickToValue(trackBar.Value); } set { trackBar.Value = ValueToTick(value); } } public event EventHandler ValueChanged; public bool Checked { get { return radioButton.Checked; } set { radioButton.Checked = value; } } public event EventHandler CheckedChanged; public DoubleLimit Limits { get { return doubleLimitView.Content; } } public event EventHandler LimitsChanged; private IList trainingValues; public DensityTrackbar(string name, DoubleLimit limit, IList trainingValues) { InitializeComponent(); this.trainingValues = trainingValues; doubleLimitView.Content = limit; doubleLimitView.Content.ValueChanged += doubleLimit_ValueChanged; textBox.Text = Value.ToString(CultureInfo.InvariantCulture); radioButton.Text = name; UpdateDensityChart(); } public void UpdateTrainingValues(IList trainingValues) { this.trainingValues = trainingValues; UpdateDensityChart(); } private void UpdateDensityChart() { chart.UpdateChart(trainingValues, Limits.Lower, Limits.Upper, numBuckets: trackBar.Maximum - trackBar.Minimum, minimumHeight: 0.1); } #region Event Handlers private void trackBar_ValueChanged(object sender, EventArgs e) { textBox.Text = Value.ToString(CultureInfo.CurrentUICulture); textBox.Update(); OnValueChanged(); } private void doubleLimit_ValueChanged(object sender, EventArgs e) { UpdateDensityChart(); OnLimitsChanged(); OnValueChanged(); } private void radioButton_CheckedChanged(object sender, EventArgs e) { Checked = radioButton.Checked; trackBar.Enabled = !Checked; textBox.Enabled = !Checked; textBox.Text = Checked ? "Plotted" : Value.ToString(CultureInfo.CurrentUICulture); radioButton.BackColor = Checked ? SystemColors.ActiveCaption : SystemColors.Control; OnCheckedChanged(); } protected override void OnTextChanged(EventArgs e) { base.OnTextChanged(e); radioButton.Text = Text; } private void textBox_Validating(object sender, CancelEventArgs e) { if (Checked) return; decimal number; if (!decimal.TryParse(textBox.Text, NumberStyles.Any, CultureInfo.CurrentUICulture.NumberFormat, out number)) { e.Cancel = true; errorProvider.SetIconAlignment(textBox, ErrorIconAlignment.MiddleLeft); errorProvider.SetIconPadding(textBox, 2); errorProvider.SetError(textBox, "Illegal number format"); } } private void textBox_Validated(object sender, EventArgs e) { if (Checked) return; errorProvider.SetError(textBox, string.Empty); Value = decimal.Parse(textBox.Text, NumberStyles.Any, CultureInfo.CurrentUICulture.NumberFormat); } #endregion protected virtual void OnValueChanged() { if (ValueChanged != null) ValueChanged(this, EventArgs.Empty); } protected virtual void OnCheckedChanged() { if (CheckedChanged != null) CheckedChanged(this, EventArgs.Empty); } protected virtual void OnLimitsChanged() { if (LimitsChanged != null) LimitsChanged(this, EventArgs.Empty); } #region Helpers private decimal TickToValue(int tick) { return TickToValue(tick, trackBar.Maximum - trackBar.Minimum, (decimal)Limits.Lower, (decimal)Limits.Upper); } private int ValueToTick(decimal value) { return ValueToTick(value, trackBar.Maximum - trackBar.Minimum, (decimal)Limits.Lower, (decimal)Limits.Upper); } private static decimal TickToValue(int tick, int numberOfTicks, decimal lower, decimal upper) { return lower + (upper - lower) * tick / numberOfTicks; } private static int ValueToTick(decimal value, int numberOfTicks, decimal lower, decimal upper) { return (int)((value - lower) / ((upper - lower) / numberOfTicks)); } #endregion } }