A line layer can be used to render LineString
and MultiLineString
features as paths or routes on the map. A line layer can also be used to render the outline of Polygon
and MultiPolygon
features. A data source is connected to a line layer to provide it with data to render.
@page "/Layers/LineLayerOnReady"
@using AzureMapsControl.Components.Map
<AzureMap Id="map"
CameraOptions="new CameraOptions { Center = new Components.Atlas.Position(11.581990, 48.143534), Zoom = 14 }"
StyleOptions="StyleOptions"
EventActivationFlags="MapEventActivationFlags
.None()
.Enable(MapEventType.Ready, MapEventType.SourceAdded)"
OnReady="OnMapReady"
OnSourceAdded="OnDatasourceAdded"/>
@code {
private readonly string _dataSourceId = "dataSource";
public StyleOptions StyleOptions = new StyleOptions
{
Style = MapStyle.GrayscaleDark
};
public async Task OnMapReady(MapEventArgs eventArgs)
{
var dataSource = new AzureMapsControl.Components.Data.DataSource(_dataSourceId)
{
Options = new Components.Data.DataSourceOptions
{
LineMetrics = true
}
};
await eventArgs.Map.AddSourceAsync(dataSource);
await dataSource.AddAsync(new AzureMapsControl.Components.Atlas.Shape<AzureMapsControl.Components.Atlas.LineString>(
new AzureMapsControl.Components.Atlas.LineString(new[] {
new AzureMapsControl.Components.Atlas.Position(11.575454, 48.137392),
new AzureMapsControl.Components.Atlas.Position(11.576029, 48.137094),
new AzureMapsControl.Components.Atlas.Position(11.577248, 48.138912),
new AzureMapsControl.Components.Atlas.Position(11.578434, 48.138737),
new AzureMapsControl.Components.Atlas.Position(11.578826, 48.139409),
new AzureMapsControl.Components.Atlas.Position(11.580140, 48.139179),
new AzureMapsControl.Components.Atlas.Position(11.581237, 48.141555),
new AzureMapsControl.Components.Atlas.Position(11.581155, 48.141852),
new AzureMapsControl.Components.Atlas.Position(11.581990, 48.143534),
new AzureMapsControl.Components.Atlas.Position(11.583355, 48.143896),
new AzureMapsControl.Components.Atlas.Position(11.583662, 48.144258)
}),
new Dictionary<string, object>()
{
{ "Color", "#00FF00" }
}));
await dataSource.AddAsync(new AzureMapsControl.Components.Atlas.Shape<AzureMapsControl.Components.Atlas.LineString>(
new AzureMapsControl.Components.Atlas.LineString(new[] {
new AzureMapsControl.Components.Atlas.Position(11.585458, 48.145596),
new AzureMapsControl.Components.Atlas.Position(11.587910, 48.145779),
new AzureMapsControl.Components.Atlas.Position(11.589632, 48.146608),
new AzureMapsControl.Components.Atlas.Position(11.590771, 48.148219),
new AzureMapsControl.Components.Atlas.Position(11.591979, 48.150743),
new AzureMapsControl.Components.Atlas.Position(11.592885, 48.150611),
new AzureMapsControl.Components.Atlas.Position(11.593161, 48.150874),
new AzureMapsControl.Components.Atlas.Position(11.593594, 48.151084),
new AzureMapsControl.Components.Atlas.Position(11.594028, 48.151803),
new AzureMapsControl.Components.Atlas.Position(11.592281, 48.152074)
}),
new Dictionary<string, object>()
{
{ "Color", "#FF0000" }
}));
}
public async Task OnDatasourceAdded(MapSourceEventArgs eventArgs)
{
var layer = new AzureMapsControl.Components.Layers.LineLayer
{
Options = new AzureMapsControl.Components.Layers.LineLayerOptions
{
Source = _dataSourceId,
StrokeWidth = new AzureMapsControl.Components.Atlas.ExpressionOrNumber(6),
StrokeColor = new AzureMapsControl.Components.Atlas.ExpressionOrString(
new AzureMapsControl.Components.Atlas.Expression[]
{
new AzureMapsControl.Components.Atlas.ExpressionOrString("get"),
new AzureMapsControl.Components.Atlas.ExpressionOrString("Color")
})
}
};
await eventArgs.Map.AddLayerAsync(layer);
}
}