// 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);
}
}
}