我有一个带有属性的模型:
/// <summary>
/// List of available map modes
/// </summary>
public Array MapModes { get; private set; }
/// <summary>
/// The current cartographic mode of the map
/// </summary>
public MapCartographicMode MapMode
{
get { return _mapMode; }
set
{
if (value == _mapMode) return;
_mapMode = value;
OnPropertyChanged();
}
}
/// <summary>
/// List of available map color modes
/// </summary>
public Array MapColorModes { get; private set; }
//The current color mode of the map
public MapColorMode MapColorMode
{
get { return _mapColorMode; }
set
{
if (value == _mapColorMode) return;
_mapColorMode = value;
OnPropertyChanged();
}
}
protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
{
PropertyChangedEventHandler handler = PropertyChanged;
if (handler != null)
handler(this, new PropertyChangedEventArgs(propertyName));
}
我的XAML看起来像这样:
<maps:Map x:Name="MainMap"
Height="{Binding MapHeight}"
ColorMode="{Binding MapColorMode, Converter={StaticResource MapTestConverter}}">
属性在另一页上更新。
<toolkit:ListPicker Header="Map mode"
ItemsSource="{Binding MapModes}"
SelectedItem="{Binding Path=MapMode, Mode=TwoWay}"/>
<toolkit:ListPicker Header="Map color mode"
ItemsSource="{Binding MapColorModes}"
SelectedItem="{Binding Path=MapColorMode, Mode=TwoWay}"/>
现在ListPickers的绑定工作得很好,模型中的值总是表示最后选择的内容。
Map绑定也有效,它获取初始值,并在第一次更改属性时更新。
但就是这样。在第一次更改属性后,它拒绝更新。 (未调用虚拟IValueConverter)。
该模型仍然可以很好地引发Property更改事件,并且该属性在模型中具有正确的值(例如在页面加载时手动分配它可以完美地工作)
由于看起来Binding正在“破碎”,我尝试在每次更新属性时重新创建它
Binding b = new Binding("MapMode");
BindingOperations.SetBinding(MainMap, Map.CartographicModeProperty, b);
这很有效。我开始认为wp8地图实现中存在一个bug或者什么。 (或者我可能会错过一些完全明显的东西^^)
答案 0 :(得分:1)
我也一样。 解决方案是为绑定提供Mode = TwoWay。我不知道为什么会这样,但似乎。 在这个博客上我看到了这个解决方案: http://dotnetbyexample.blogspot.ch/2012/10/introducing-new-windows-8-map-control.html