// 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.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.Piping.Forms.Properties; using Ringtoets.Piping.Primitives; using PipingDataResources = Ringtoets.Piping.Data.Properties.Resources; namespace Ringtoets.Piping.Forms.Views { /// /// Factory for creating based on information used as input in the piping failure mechanism. /// public static class PipingChartDataFactory { /// /// Create a instance with a name, but without data. /// /// The name of the . /// An empty object. public static ChartLineData CreateEmptyLineData(string name) { return new ChartLineData(Enumerable.Empty(), name); } /// /// Create a instance with a name, but without data. /// /// The name of the . /// An empty object. public static ChartPointData CreateEmptyPointData(string name) { return new ChartPointData(Enumerable.Empty(), name); } /// /// Create with default styling based on the . /// /// The for which to create . /// based on the . /// Thrown when is null. public static ChartData Create(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return new ChartLineData(surfaceLine.ProjectGeometryToLZ(), surfaceLine.Name) { Style = new ChartLineStyle(Color.Sienna, 2, DashStyle.Solid) }; } /// /// Create a with default styling based on the . /// /// The horizontal distance from the origin at which to place the entry point /// on the . /// The to place the entry point on. /// based on the . /// Thrown when is NaN. /// Thrown when is null. public static ChartData CreateEntryPoint(RoundedDouble entryPoint, RingtoetsPipingSurfaceLine surfaceLine) { if (double.IsNaN(entryPoint)) { throw new ArgumentException("Entry point should have a value.", "entryPoint"); } if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreatePointWithZAtL(entryPoint, surfaceLine, Resources.PipingInput_EntryPointL_DisplayName, Color.Gold); } /// /// Create a with default styling based on the . /// /// The horizontal distance from the origin at which to place the exit point /// on the . /// The to place the exit point on. /// based on the . /// Thrown when is NaN. /// Thrown when is null. public static ChartData CreateExitPoint(RoundedDouble exitPoint, RingtoetsPipingSurfaceLine surfaceLine) { if (double.IsNaN(exitPoint)) { throw new ArgumentException("Exit point should have a value.", "exitPoint"); } if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreatePointWithZAtL(exitPoint, surfaceLine, Resources.PipingInput_ExitPointL_DisplayName, Color.Tomato); } /// /// Create a with default styling based on the . /// /// The which contains a point which /// characterizes the ditch at polder side, to create for. /// based on the . /// Thrown when is null or /// the contains no . public static ChartData CreateDitchPolderSide(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreateCharacteristicPoint(surfaceLine.DitchPolderSide, surfaceLine, PipingDataResources.CharacteristicPoint_DitchPolderSide, Color.IndianRed); } /// /// Create a with default styling based on the . /// /// The which contains a point which /// characterizes the bottom ditch at polder side, to create for. /// based on the . /// Thrown when is null or /// the contains no . public static ChartData CreateBottomDitchPolderSide(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreateCharacteristicPoint(surfaceLine.BottomDitchPolderSide, surfaceLine, PipingDataResources.CharacteristicPoint_BottomDitchPolderSide, Color.Teal); } /// /// Create a with default styling based on the . /// /// The which contains a point which /// characterizes the bottom ditch at dike side, to create for. /// based on the . /// Thrown when is null or /// the contains no . public static ChartData CreateBottomDitchDikeSide(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreateCharacteristicPoint(surfaceLine.BottomDitchDikeSide, surfaceLine, PipingDataResources.CharacteristicPoint_BottomDitchDikeSide, Color.DarkSeaGreen); } /// /// Create a with default styling based on the . /// /// The which contains a point which /// characterizes the ditch at dike side, to create for. /// based on the . /// Thrown when is null or /// the contains no . public static ChartData CreateDitchDikeSide(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreateCharacteristicPoint(surfaceLine.DitchDikeSide, surfaceLine, PipingDataResources.CharacteristicPoint_DitchDikeSide, Color.MediumPurple); } /// /// Create a with default styling based on the . /// /// The which contains a point which /// characterizes the dike toe at river side, to create for. /// based on the . /// Thrown when is null or /// the contains no . public static ChartData CreateDikeToeAtRiver(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreateCharacteristicPoint(surfaceLine.DikeToeAtRiver, surfaceLine, PipingDataResources.CharacteristicPoint_DikeToeAtRiver, Color.DarkBlue); } /// /// Create a with default styling based on the . /// /// The which contains a point which /// characterizes the dike toe at polder side, to create for. /// based on the . /// Thrown when is null or /// the contains no . public static ChartData CreateDikeToeAtPolder(RingtoetsPipingSurfaceLine surfaceLine) { if (surfaceLine == null) { throw new ArgumentNullException("surfaceLine"); } return CreateCharacteristicPoint(surfaceLine.DikeToeAtPolder, surfaceLine, PipingDataResources.CharacteristicPoint_DikeToeAtPolder, Color.SlateGray); } private static ChartData CreatePointWithZAtL(RoundedDouble pointL, RingtoetsPipingSurfaceLine surfaceLine, string name, Color color) { ChartPointData pointWithZatLData; try { var pointZ = surfaceLine.GetZAtL(pointL); pointWithZatLData = new ChartPointData(new[] { new Point2D(pointL, pointZ), }, name) { Style = new ChartPointStyle(color, 8, Color.Transparent, 0, ChartPointSymbol.Triangle) }; } catch (ArgumentOutOfRangeException) { // TODO Should not have to handle when WTI-673 and WTI-396 are done. pointWithZatLData = CreateEmptyPointData(name); } return pointWithZatLData; } private static ChartData CreateCharacteristicPoint(Point3D worldPoint, RingtoetsPipingSurfaceLine surfaceLine, string name, Color color) { return CreateLocalPoint(worldPoint, surfaceLine, name, new ChartPointStyle(color, 8, Color.Transparent, 0, ChartPointSymbol.Circle)); } private static ChartData CreateLocalPoint(Point3D worldPoint, RingtoetsPipingSurfaceLine surfaceLine, string name, ChartPointStyle style) { Point2D firstPoint = Point3DToPoint2D(surfaceLine.Points.First()); Point2D lastPoint = Point3DToPoint2D(surfaceLine.Points.Last()); return new ChartPointData(new[] { worldPoint.ProjectIntoLocalCoordinates(firstPoint, lastPoint) }, name) { Style = style }; } private static Point2D Point3DToPoint2D(Point3D point3D) { return new Point2D(point3D.X, point3D.Y); } } }