Static MapLayerMenuItem.MapLayerFactory

This commit is contained in:
ClemensFischer 2025-09-17 22:25:50 +02:00
parent 5afea53c7c
commit 62ffed2caf
6 changed files with 35 additions and 49 deletions

View file

@ -10,6 +10,10 @@ namespace MapControl.UiTools
{ {
public abstract partial class MapMenuItem : MenuItem public abstract partial class MapMenuItem : MenuItem
{ {
public abstract bool GetIsChecked(MapBase map);
public abstract Task ExecuteAsync(MapBase map);
protected MapMenuItem() protected MapMenuItem()
{ {
Icon = new TextBlock Icon = new TextBlock
@ -31,7 +35,7 @@ namespace MapControl.UiTools
{ {
if (DataContext is MapBase map) if (DataContext is MapBase map)
{ {
await Execute(map); await ExecuteAsync(map);
foreach (var item in ParentMenuItems) foreach (var item in ParentMenuItems)
{ {
@ -51,10 +55,6 @@ namespace MapControl.UiTools
protected override Type StyleKeyOverride => typeof(MenuItem); protected override Type StyleKeyOverride => typeof(MenuItem);
protected abstract bool GetIsChecked(MapBase map);
public abstract Task Execute(MapBase map);
protected override void OnPropertyChanged(AvaloniaPropertyChangedEventArgs args) protected override void OnPropertyChanged(AvaloniaPropertyChangedEventArgs args)
{ {
base.OnPropertyChanged(args); base.OnPropertyChanged(args);

View file

@ -22,23 +22,27 @@ namespace MapControl.UiTools
#elif UWP || WINUI #elif UWP || WINUI
[ContentProperty(Name = nameof(MapLayer))] [ContentProperty(Name = nameof(MapLayer))]
#endif #endif
public class MapLayerMenuItem : MapMenuItem public partial class MapLayerMenuItem : MapMenuItem
{ {
public static Func<string, Task<FrameworkElement>> MapLayerFactory { get; set; } =
async sourcePath => sourcePath.EndsWith(".kmz") || sourcePath.EndsWith(".kml")
? (FrameworkElement)await GroundOverlay.CreateAsync(sourcePath)
: (FrameworkElement)await GeoImage.CreateAsync(sourcePath);
#if AVALONIA #if AVALONIA
[Content] [Content]
#endif #endif
public FrameworkElement MapLayer { get; set; } public FrameworkElement MapLayer { get; set; }
public Func<Task<FrameworkElement>> MapLayerFactory { get; set; } public string SourcePath { get; set; }
protected override bool GetIsChecked(MapBase map) public override bool GetIsChecked(MapBase map)
{ {
return MapLayer != null && map.Children.Contains(MapLayer); return MapLayer != null && map.Children.Contains(MapLayer);
} }
public override async Task Execute(MapBase map) public override async Task ExecuteAsync(MapBase map)
{ {
MapLayer ??= await MapLayerFactory?.Invoke(); MapLayer ??= await MapLayerFactory?.Invoke(SourcePath);
if (MapLayer != null) if (MapLayer != null)
{ {
@ -47,33 +51,13 @@ namespace MapControl.UiTools
} }
} }
public class MapOverlayMenuItem : MapLayerMenuItem public partial class MapOverlayMenuItem : MapLayerMenuItem
{ {
private string sourcePath;
public string SourcePath
{
get => sourcePath;
set
{
sourcePath = value;
if (sourcePath.EndsWith(".kmz") || sourcePath.EndsWith(".kml"))
{
MapLayerFactory = async () => await GroundOverlay.CreateAsync(sourcePath);
}
else
{
MapLayerFactory = async () => await GeoImage.CreateAsync(sourcePath);
}
}
}
public int InsertOrder { get; set; } public int InsertOrder { get; set; }
public override async Task Execute(MapBase map) public override async Task ExecuteAsync(MapBase map)
{ {
MapLayer ??= await MapLayerFactory?.Invoke(); MapLayer ??= await MapLayerFactory?.Invoke(SourcePath);
if (MapLayer != null) if (MapLayer != null)
{ {

View file

@ -18,19 +18,19 @@ namespace MapControl.UiTools
#elif UWP || WINUI #elif UWP || WINUI
[ContentProperty(Name = nameof(MapProjection))] [ContentProperty(Name = nameof(MapProjection))]
#endif #endif
public class MapProjectionMenuItem : MapMenuItem public partial class MapProjectionMenuItem : MapMenuItem
{ {
#if AVALONIA #if AVALONIA
[Content] [Content]
#endif #endif
public string MapProjection { get; set; } public string MapProjection { get; set; }
protected override bool GetIsChecked(MapBase map) public override bool GetIsChecked(MapBase map)
{ {
return map.MapProjection.ToString() == MapProjection; return map.MapProjection.ToString() == MapProjection;
} }
public override Task Execute(MapBase map) public override Task ExecuteAsync(MapBase map)
{ {
if (!GetIsChecked(map)) if (!GetIsChecked(map))
{ {

View file

@ -40,7 +40,9 @@ namespace MapControl.UiTools
if (initialItem != null) if (initialItem != null)
{ {
await initialItem.Execute(Map); initialItem.IsChecked = true;
await initialItem.ExecuteAsync(Map);
} }
} }
} }

View file

@ -5,8 +5,12 @@ using System.Windows.Controls;
namespace MapControl.UiTools namespace MapControl.UiTools
{ {
public abstract class MapMenuItem : MenuItem public abstract partial class MapMenuItem : MenuItem
{ {
public abstract bool GetIsChecked(MapBase map);
public abstract Task ExecuteAsync(MapBase map);
protected MapMenuItem() protected MapMenuItem()
{ {
Loaded += (s, e) => Loaded += (s, e) =>
@ -21,7 +25,7 @@ namespace MapControl.UiTools
{ {
if (DataContext is MapBase map) if (DataContext is MapBase map)
{ {
await Execute(map); await ExecuteAsync(map);
foreach (var item in ParentMenuItems) foreach (var item in ParentMenuItems)
{ {
@ -38,9 +42,5 @@ namespace MapControl.UiTools
} }
protected IEnumerable<MapMenuItem> ParentMenuItems => ((ItemsControl)Parent).Items.OfType<MapMenuItem>(); protected IEnumerable<MapMenuItem> ParentMenuItems => ((ItemsControl)Parent).Items.OfType<MapMenuItem>();
protected abstract bool GetIsChecked(MapBase map);
public abstract Task Execute(MapBase map);
} }
} }

View file

@ -11,8 +11,12 @@ using Microsoft.UI.Xaml.Media;
namespace MapControl.UiTools namespace MapControl.UiTools
{ {
public abstract class MapMenuItem : ToggleMenuFlyoutItem public abstract partial class MapMenuItem : ToggleMenuFlyoutItem
{ {
public abstract bool GetIsChecked(MapBase map);
public abstract Task ExecuteAsync(MapBase map);
protected MapMenuItem() protected MapMenuItem()
{ {
Loaded += (s, e) => Loaded += (s, e) =>
@ -29,7 +33,7 @@ namespace MapControl.UiTools
{ {
if (DataContext is MapBase map) if (DataContext is MapBase map)
{ {
await Execute(map); await ExecuteAsync(map);
foreach (var item in ParentMenuItems) foreach (var item in ParentMenuItems)
{ {
@ -40,9 +44,5 @@ namespace MapControl.UiTools
} }
protected IList<MapMenuItem> ParentMenuItems { get; private set; } protected IList<MapMenuItem> ParentMenuItems { get; private set; }
protected abstract bool GetIsChecked(MapBase map);
public abstract Task Execute(MapBase map);
} }
} }