// 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 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.Drawing; using System.Linq; using Core.Common.Base.Geometry; using Core.Components.Gis.Data; using Core.Components.Gis.Features; using DotSpatial.Controls; using DotSpatial.Data; using DotSpatial.Symbology; using DotSpatial.Topology; namespace Core.Components.DotSpatial.Converter { /// /// The abstract base class for transforming in specific instances. /// public abstract class MapDataConverter : IMapDataConverter where T : MapData { public bool CanConvertMapData(MapData data) { return data is T; } public IList Convert(MapData data) { if (data == null) { throw new ArgumentNullException("data", @"Null data cannot be converted into feature sets."); } if (!CanConvertMapData(data)) { var message = string.Format("The data of type {0} cannot be converted by this converter.", data.GetType()); throw new ArgumentException(message); } return Convert((T) data); } /// /// Creates one or more based on the that was given. /// /// The data to transform into one or more . /// A new of . protected abstract IList Convert(T data); protected static IEnumerable ConvertPoint2DElementsToCoordinates(IEnumerable points) { return points.Select(point => new Coordinate(point.X, point.Y)); } protected static void AddMetaDataAsAttributes(MapFeature ringtoetsMapFeature, FeatureSet featureSet, Feature feature) { foreach (var attribute in ringtoetsMapFeature.MetaData) { if (!featureSet.DataTable.Columns.Contains(attribute.Key)) { featureSet.DataTable.Columns.Add(attribute.Key, typeof(string)); } feature.DataRow[attribute.Key] = attribute.Value; } } protected static MapLabelLayer GetLabelLayer(FeatureSet featureSet, bool showLabels, string labelToShow) { var labelLayer = new MapLabelLayer(); if (featureSet.DataTable.Columns.Count > 0 && showLabels) { labelLayer.Symbology.Categories[0].Symbolizer = new LabelSymbolizer { Orientation = ContentAlignment.MiddleRight, OffsetX = 5 }; labelLayer.Symbology.Categories[0].Expression = string.Format("[{0}]", labelToShow); } return labelLayer; } } }