// Copyright (C) Stichting Deltares 2019. All rights reserved. // // This file is part of Riskeer. // // Riskeer is free software: you can redistribute it and/or modify // it under the terms of the GNU Lesser 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 Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser 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.Linq; using Core.Common.Base.Geometry; using Core.Components.Gis.Features; using Core.Components.Gis.Geometries; using Core.Components.Gis.IO.Properties; using DotSpatial.Data; using GeoAPI.Geometries; using NetTopologySuite.Geometries; using FeatureType = DotSpatial.Data.FeatureType; namespace Core.Components.Gis.IO.Writers { /// /// Class to be used to write polylines to a shapefile. /// public class PolylineShapeFileWriter : ShapeFileWriterBase { /// /// Initializes a new instance of the class. /// public PolylineShapeFileWriter() { ShapeFile = new LineShapefile { FeatureType = FeatureType.Line }; } protected override IFeature AddFeature(MapFeature mapFeature) { LineString lineString = CreateLineStringFromMapFeature(mapFeature); return ShapeFile.AddFeature(lineString); } private static LineString CreateLineStringFromMapFeature(MapFeature mapFeature) { if (mapFeature.MapGeometries.Count() != 1) { throw new ArgumentException(Resources.PointShapeFileWriter_CreatePointFromMapFeature_A_feature_can_only_contain_one_geometry); } MapGeometry geometry = mapFeature.MapGeometries.First(); IEnumerable mapGeometryPointCollection = geometry.PointCollections.First(); Coordinate[] coordinates = mapGeometryPointCollection.Select(p => new Coordinate(p.X, p.Y)).ToArray(); return new LineString(coordinates); } } }