mirror of
https://github.com/ClemensFischer/XAML-Map-Control.git
synced 2025-12-06 07:12:04 +01:00
MapItemsControl implementation
This commit is contained in:
parent
367d54037f
commit
e3b221a80b
|
|
@ -20,6 +20,11 @@ namespace MapControl
|
||||||
SelectItemsByPosition(geometry.FillContains);
|
SelectItemsByPosition(geometry.FillContains);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public new MapItem ContainerFromItem(object item)
|
||||||
|
{
|
||||||
|
return (MapItem)base.ContainerFromItem(item);
|
||||||
|
}
|
||||||
|
|
||||||
protected override bool NeedsContainerOverride(object item, int index, out object recycleKey)
|
protected override bool NeedsContainerOverride(object item, int index, out object recycleKey)
|
||||||
{
|
{
|
||||||
recycleKey = null;
|
recycleKey = null;
|
||||||
|
|
@ -35,26 +40,13 @@ namespace MapControl
|
||||||
protected override void PrepareContainerForItemOverride(Control container, object item, int index)
|
protected override void PrepareContainerForItemOverride(Control container, object item, int index)
|
||||||
{
|
{
|
||||||
base.PrepareContainerForItemOverride(container, item, index);
|
base.PrepareContainerForItemOverride(container, item, index);
|
||||||
|
PrepareContainer(container, item);
|
||||||
if (LocationMemberPath != null && container is MapItem mapItem)
|
|
||||||
{
|
|
||||||
mapItem.SetBinding(MapItem.LocationProperty,
|
|
||||||
new Binding
|
|
||||||
{
|
|
||||||
Path = new PropertyPath(LocationMemberPath),
|
|
||||||
Source = item
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void ClearContainerForItemOverride(Control container)
|
protected override void ClearContainerForItemOverride(Control container)
|
||||||
{
|
{
|
||||||
base.ClearContainerForItemOverride(container);
|
base.ClearContainerForItemOverride(container);
|
||||||
|
ClearContainer(container);
|
||||||
if (LocationMemberPath != null && container is MapItem mapItem)
|
|
||||||
{
|
|
||||||
mapItem.ClearValue(MapItem.LocationProperty);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void UpdateSelection(MapItem mapItem, PointerEventArgs e)
|
internal void UpdateSelection(MapItem mapItem, PointerEventArgs e)
|
||||||
|
|
|
||||||
|
|
@ -2,12 +2,15 @@
|
||||||
#if WPF
|
#if WPF
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
|
using System.Windows.Data;
|
||||||
#elif UWP
|
#elif UWP
|
||||||
using Windows.UI.Xaml;
|
using Windows.UI.Xaml;
|
||||||
using Windows.UI.Xaml.Controls;
|
using Windows.UI.Xaml.Controls;
|
||||||
|
using Windows.UI.Xaml.Data;
|
||||||
#elif WINUI
|
#elif WINUI
|
||||||
using Microsoft.UI.Xaml;
|
using Microsoft.UI.Xaml;
|
||||||
using Microsoft.UI.Xaml.Controls;
|
using Microsoft.UI.Xaml.Controls;
|
||||||
|
using Microsoft.UI.Xaml.Data;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace MapControl
|
namespace MapControl
|
||||||
|
|
@ -114,5 +117,26 @@ namespace MapControl
|
||||||
SelectItemsInRect(new Rect(xMin, yMin, xMax - xMin, yMax - yMin));
|
SelectItemsInRect(new Rect(xMin, yMin, xMax - xMin, yMax - yMin));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void PrepareContainer(DependencyObject container, object item)
|
||||||
|
{
|
||||||
|
if (LocationMemberPath != null && container is MapItem mapItem)
|
||||||
|
{
|
||||||
|
mapItem.SetBinding(MapItem.LocationProperty,
|
||||||
|
new Binding
|
||||||
|
{
|
||||||
|
Path = new PropertyPath(LocationMemberPath),
|
||||||
|
Source = item
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ClearContainer(DependencyObject container)
|
||||||
|
{
|
||||||
|
if (LocationMemberPath != null && container is MapItem mapItem)
|
||||||
|
{
|
||||||
|
mapItem.ClearValue(MapItem.LocationProperty);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
using System.Windows.Data;
|
|
||||||
using System.Windows.Media;
|
using System.Windows.Media;
|
||||||
|
|
||||||
namespace MapControl
|
namespace MapControl
|
||||||
|
|
@ -40,26 +39,13 @@ namespace MapControl
|
||||||
protected override void PrepareContainerForItemOverride(DependencyObject container, object item)
|
protected override void PrepareContainerForItemOverride(DependencyObject container, object item)
|
||||||
{
|
{
|
||||||
base.PrepareContainerForItemOverride(container, item);
|
base.PrepareContainerForItemOverride(container, item);
|
||||||
|
PrepareContainer(container, item);
|
||||||
if (LocationMemberPath != null && container is MapItem mapItem)
|
|
||||||
{
|
|
||||||
mapItem.SetBinding(MapItem.LocationProperty,
|
|
||||||
new Binding
|
|
||||||
{
|
|
||||||
Path = new PropertyPath(LocationMemberPath),
|
|
||||||
Source = item
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void ClearContainerForItemOverride(DependencyObject container, object item)
|
protected override void ClearContainerForItemOverride(DependencyObject container, object item)
|
||||||
{
|
{
|
||||||
base.ClearContainerForItemOverride(container, item);
|
base.ClearContainerForItemOverride(container, item);
|
||||||
|
ClearContainer(container);
|
||||||
if (LocationMemberPath != null && container is MapItem mapItem)
|
|
||||||
{
|
|
||||||
mapItem.ClearValue(MapItem.LocationProperty);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,7 @@
|
||||||
#if UWP
|
#if UWP
|
||||||
using Windows.UI.Xaml;
|
using Windows.UI.Xaml;
|
||||||
using Windows.UI.Xaml.Data;
|
|
||||||
#else
|
#else
|
||||||
using Microsoft.UI.Xaml;
|
using Microsoft.UI.Xaml;
|
||||||
using Microsoft.UI.Xaml.Data;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace MapControl
|
namespace MapControl
|
||||||
|
|
@ -34,26 +32,13 @@ namespace MapControl
|
||||||
protected override void PrepareContainerForItemOverride(DependencyObject container, object item)
|
protected override void PrepareContainerForItemOverride(DependencyObject container, object item)
|
||||||
{
|
{
|
||||||
base.PrepareContainerForItemOverride(container, item);
|
base.PrepareContainerForItemOverride(container, item);
|
||||||
|
PrepareContainer(container, item);
|
||||||
if (LocationMemberPath != null && container is MapItem mapItem)
|
|
||||||
{
|
|
||||||
mapItem.SetBinding(MapItem.LocationProperty,
|
|
||||||
new Binding
|
|
||||||
{
|
|
||||||
Path = new PropertyPath(LocationMemberPath),
|
|
||||||
Source = item
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void ClearContainerForItemOverride(DependencyObject container, object item)
|
protected override void ClearContainerForItemOverride(DependencyObject container, object item)
|
||||||
{
|
{
|
||||||
base.ClearContainerForItemOverride(container, item);
|
base.ClearContainerForItemOverride(container, item);
|
||||||
|
ClearContainer(container);
|
||||||
if (LocationMemberPath != null && container is MapItem mapItem)
|
|
||||||
{
|
|
||||||
mapItem.ClearValue(MapItem.LocationProperty);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue