// Copyright (C) Stichting Deltares 2016. All rights reserved. // // This file is part of Ringtoets. // // Ringtoets 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. // // This program 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 this program. If not, see . // // All names, logos, and references to "Deltares" are registered trademarks of // Stichting Deltares and remain full property of Stichting Deltares at all times. // All rights reserved. using System; using System.Collections.Generic; using System.Drawing; using System.Drawing.Drawing2D; using System.Linq; using Core.Common.Base.Data; using Core.Common.Base.Geometry; using Core.Components.Charting.Data; using Core.Components.Charting.Styles; using Ringtoets.GrassCoverErosionInwards.Data; using Ringtoets.GrassCoverErosionInwards.Forms.Properties; namespace Ringtoets.GrassCoverErosionInwards.Forms.Views { /// /// Factory for creating based on information used as input /// in the grass cover erosion inwards failure mechanism. /// public static class GrassCoverErosionInwardsChartDataFactory { /// /// Create with default styling for the . /// /// The geometry of the for which to create /// . /// The name of the . /// based on the . /// Thrown when /// is null. public static ChartData Create(RoughnessPoint[] dikeGeometry, string name) { if (dikeGeometry == null) { throw new ArgumentNullException("dikeGeometry"); } return new ChartLineData(dikeGeometry.Select(dg => dg.Point), string.Format(Resources.GrassCoverErosionInwardsChartDataFactory_Create_DataIdentifier_0_DataTypeDisplayName_1_, name, Resources.DikeProfile_DisplayName)) { Style = new ChartLineStyle(Color.SaddleBrown, 2, DashStyle.Solid) }; } /// /// Create with default styling for the . /// /// The forshore geometry of the /// for which to create . /// The name of the . /// based on the . /// Thrown when /// is null. public static ChartData Create(RoundedPoint2DCollection foreshoreGeometry, string name) { if (foreshoreGeometry == null) { throw new ArgumentNullException("foreshoreGeometry"); } return new ChartLineData(foreshoreGeometry, string.Format(Resources.GrassCoverErosionInwardsChartDataFactory_Create_DataIdentifier_0_DataTypeDisplayName_1_, name, Resources.Foreshore_DisplayName)) { Style = new ChartLineStyle(Color.DarkOrange, 2, DashStyle.Solid) }; } /// /// Create with default styling for the . /// /// The dike height of the for which /// to create . /// The geometry of the to determine /// the position of the marker. /// The name of the . /// based on the . /// Thrown when is NaN. /// Thrown when /// is null. public static ChartData Create(RoundedDouble dikeHeight, RoughnessPoint[] dikeGeometry, string name) { if (double.IsNaN(dikeHeight)) { throw new ArgumentException("Dike height should have a value.", "dikeHeight"); } if (dikeGeometry == null) { throw new ArgumentNullException("dikeGeometry"); } return new ChartLineData(CreateDikeHeightData(dikeHeight, dikeGeometry), Resources.DikeHeight_ChartName) { Style = new ChartLineStyle(Color.MediumSeaGreen, 2, DashStyle.Dash) }; } private static IEnumerable CreateDikeHeightData(RoundedDouble dikeHeight, RoughnessPoint[] dikeGeometry) { return new[] { new Point2D(dikeGeometry.First().Point.X, dikeHeight), new Point2D(dikeGeometry.Last().Point.X, dikeHeight) }; } } }