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