我正在创建一个加载装饰器,上面有一个旋转的图标。我尝试直接在XAML中绑定可见性属性,但这实际上隐藏了层次结构中的所有内容。
我的XAML中有以下内容:
<AdornerDecorator Visibility="{Binding Path=RootGroup.Loading, Converter={StaticResource VisibilityConverter}}">
<TreeView x:Name="groupTreeView" />
</AdornerDecorator>在我的构造函数中
LoadingAdorner adorner = new LoadingAdorner(groupTreeView);
AdornerLayer.GetAdornerLayer(groupTreeView).Add(adorner);这不是我想要的,所以我尝试在代码中绑定它:
LoadingAdorner adorner = new LoadingAdorner(groupTreeView);
Binding bind = new Binding("RootGroup.Loading");
bind.Source = this.DataContext;
bind.Converter = new VisibilityConverter();
adorner.SetBinding(LoadingAdorner.VisibilityProperty, bind);
AdornerLayer.GetAdornerLayer(groupTreeView).Add(adorner);如果DataContext不是null,这将起作用,因为它实际上可以找到RootGroup.Loading。但是如果它是空的,那么绑定就没有源可以查看了。
所以我想知道XAML数据绑定使用什么作为它的.Source?XAML中的绑定直接绑定到正确的属性,但不能达到同样的效果。所以我想知道,为了绑定到RootGroup.Loading,我应该将我的.Source设置为什么?
谢谢,劳尔
发布于 2009-11-21 06:20:19
这并没有直接回答你的问题,但是为什么你要使用装饰器来获得加载动画效果。
为什么不使用一个边框元素,它是你的TreeView的兄弟元素,在上面Z排序,然后在里面做你的动画。
所以你做这样的事情
<Grid>
<TreeView />
<Border x:Name="myBorder">... </Border>
</Grid>然后,您可以在XAML中执行所有绑定,而无需隐藏整个Visual Tree。
https://stackoverflow.com/questions/1772394
复制相似问题