.NET MAUI Map Selection
The Map allows users to select one or many shapes out of the source applied by each ShapefileLayer
. This feature provides both visual and programmatic feedback for the actions of the user.
The following members of the ShapefileLayer class are related to the selection:
-
SelectionMode
: Enum property which indicates what will be the selection. It can receive the following values:None
Single
Multiple
SelectedShape
(of typeIShape
): Defines the currently selected shape instance. When multiple selection is enabled, this value is set to the first selected shape.SelectedShapes
(of typeObservableCollection<IShape>
): Reads the collection with the currently selected shapes. When the selection is single only one shape can be selected – thus the collection will have count = 1.SelectedShapeStyle
(of typeMapShapeStyle
): Defines the way selected shape look through the providedStrokeWidth
,StrokeColor
andFillColor
properties. For more details on theMapShapeStyle
usage go to Shapes Styling topic.
Define RadMap
with SelectionMode
:
<telerik:RadMap x:Name="map">
<telerik:RadMap.Layers>
<telerik:MapShapefileLayer x:Name="mapShapeLayer" SelectionMode="Multiple">
<telerik:MapShapefileLayer.Reader>
<telerik:MapShapeReader x:Name="reader"/>
</telerik:MapShapefileLayer.Reader>
</telerik:MapShapefileLayer>
</telerik:RadMap.Layers>
</telerik:RadMap>
Where the Source
and the DataSource
of the MapShapeReader
have to be set to a .shp
and .dbf
files, respectively:
var assembly = this.GetType().Assembly;
var source = MapSource.FromResource("SDKBrowserMaui.Examples.MapControl.world.shp", assembly);
var dataSource = MapSource.FromResource("SDKBrowserMaui.Examples.MapControl.world.dbf", assembly);
this.reader.Source = source;
this.reader.DataSource = dataSource;
Add the namespace:
xmlns:telerik="http://schemas.telerik.com/2022/xaml/maui"
Check below how RadMap
with a few selected shapes will look like:
Example with Programmatical Shape Selection
The snippet below demonstrates how you can select a shape programmatically. In the example the used ESRI file contains the world map, so the shape that is selected is a country. The example uses the Shapes
property of the Map to traverse through all the available shapes.
Let's select/deselect "France", for example, on clicking buttons:
<Button Text="Select France" Clicked="SelectFranceClicked" Padding="5"/>
<Button Text="Deselect France" Clicked="DeselectFranceClicked" Padding="5" />
And the event handlers:
private void SelectFranceClicked(object sender, EventArgs e)
{
var shape = this.GetItemFromCountryName("France");
if (shape != null)
{
this.mapShapeLayer.SelectedShapes.Add(shape);
}
}
private void DeselectFranceClicked(object sender, EventArgs e)
{
var shape = this.GetItemFromCountryName("France");
if (shape != null && this.mapShapeLayer.SelectedShapes.Contains(shape))
{
this.mapShapeLayer.SelectedShapes.Remove(shape);
}
}
private IShape GetItemFromCountryName(string countryName)
{
foreach (var shape in this.reader.Shapes)
{
var name = shape.GetAttribute("CNTRY_NAME").ToString();
if (name == countryName)
{
return shape;
}
}
return null;
}
xmlns:telerik="http://schemas.telerik.com/2022/xaml/maui"
Here is the result:
A sample Programmatic Selection example can be found in the Map/Selection folder of the SDK .NET MAUI Demo application.