// 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 Application.Ringtoets.Storage.DbContext; using Core.Common.Base.Geometry; using Ringtoets.Integration.Data; using Ringtoets.Piping.Primitives; namespace Application.Ringtoets.Storage.Read { /// /// This class defines extension methods for read operations for an /// based on the . /// internal static class SurfaceLineEntityReadExtensions { /// /// Read the and use the information to construct /// a . /// /// The to create /// for. /// The object keeping track of read operations. /// A new . /// Thrown when is null. internal static RingtoetsPipingSurfaceLine Read(this SurfaceLineEntity entity, ReadConversionCollector collector) { if (collector == null) { throw new ArgumentNullException("collector"); } var surfaceLine = new RingtoetsPipingSurfaceLine { StorageId = entity.SurfaceLineEntityId, Name = entity.Name, ReferenceLineIntersectionWorldPoint = new Point2D( Convert.ToDouble(entity.ReferenceLineIntersectionX), Convert.ToDouble(entity.ReferenceLineIntersectionY)) }; entity.ReadSurfaceLineGeometryAndCharacteristicPoints(surfaceLine, collector); return surfaceLine; } private static void ReadSurfaceLineGeometryAndCharacteristicPoints(this SurfaceLineEntity entity, RingtoetsPipingSurfaceLine surfaceLine, ReadConversionCollector collector) { var geometryPoints = new Point3D[entity.SurfaceLinePointEntities.Count]; var characteristicPoints = new Dictionary(); foreach (SurfaceLinePointEntity pointEntity in entity.SurfaceLinePointEntities) { var geometryPoint = pointEntity.Read(collector); geometryPoints[pointEntity.Order] = geometryPoint; foreach (CharacteristicPointEntity characteristicPointEntity in pointEntity.CharacteristicPointEntities) { characteristicPoints[(CharacteristicPointType)characteristicPointEntity.CharacteristicPointType] = geometryPoint; } } surfaceLine.SetGeometry(geometryPoints); foreach (KeyValuePair keyValuePair in characteristicPoints) { SetCharacteristicPoint(surfaceLine, keyValuePair.Key, keyValuePair.Value); } } private static void SetCharacteristicPoint(RingtoetsPipingSurfaceLine surfaceLine, CharacteristicPointType type, Point3D geometryPoint) { switch (type) { case CharacteristicPointType.DikeToeAtRiver: surfaceLine.SetDikeToeAtRiverAt(geometryPoint); break; case CharacteristicPointType.DikeToeAtPolder: surfaceLine.SetDikeToeAtPolderAt(geometryPoint); break; case CharacteristicPointType.DitchDikeSide: surfaceLine.SetDitchDikeSideAt(geometryPoint); break; case CharacteristicPointType.BottomDitchDikeSide: surfaceLine.SetBottomDitchDikeSideAt(geometryPoint); break; case CharacteristicPointType.BottomDitchPolderSide: surfaceLine.SetBottomDitchPolderSideAt(geometryPoint); break; case CharacteristicPointType.DitchPolderSide: surfaceLine.SetDitchPolderSideAt(geometryPoint); break; default: throw new NotImplementedException(); } } } }