如何在绑定ItemSsource时插入ToolBar分隔符

时间:2009-11-28 04:15:59

标签: wpf toolbar separator itemcontainerstyle itemsource

我将ToolBar绑定到命令视图模型对象的集合。集合中的对象具有属性IsSeparator,如果属实,我希望在<Separator/>中使用ToolBar表示。

我的基本标记如下:

<ToolBar Grid.Row="1" ItemsSource="{Binding Path=ToolBarCommands}">
    <ToolBar.ItemTemplate>
        <DataTemplate>
            <Button ToolTip="{Binding Path=ToolTip}" Command="{Binding Path=Command}">
                <Button.Content>
                    <Image Width="16" Height="16"  Source="{Binding Path=IconStream}"/>
                </Button.Content>
            </Button>                    
        </DataTemplate>
    </ToolBar.ItemTemplate>
</ToolBar>

ItemContainerStyle和我MenuItem的{​​{1}}非常相似,但无济于事。

感谢任何帮助。

2 个答案:

答案 0 :(得分:4)

我遵循Josh关于使用DataTemplateSelector的建议,我只是发布代码来帮助其他人。

public class ToolBarItemTemplateSelector : DataTemplateSelector
{
    public DataTemplate ButtonTemplate { get; set; }
    public DataTemplate SeparatorTemplate { get; set; }

    public override DataTemplate SelectTemplate(object item, DependencyObject container)
    {
        var toolBarItem = (ToolBarItemViewModel) item;
        Debug.Assert(toolBarItem != null);
        if (!toolBarItem.IsSeparator)
        {
            return ButtonTemplate;
        }
        return SeparatorTemplate;
    }
}

    <DataTemplate x:Key="buttonTemplate" DataType="{x:Type infrastructure:ToolBarItemViewModel}">
        <Button Command="{Binding Command}" ToolTip="{Binding ToolTip}" Style="{DynamicResource ResourceKey={x:Static ToolBar.ButtonStyleKey}}">
            <Image Source="{Binding ImageSource}" Width="16" Height="16" />
        </Button>
    </DataTemplate>

    <DataTemplate x:Key="separatorTemplate">
        <Separator Style="{StaticResource {x:Static ToolBar.SeparatorStyleKey}}" />
    </DataTemplate>

    <local:ToolBarItemTemplateSelector ButtonTemplate="{StaticResource buttonTemplate}" SeparatorTemplate="{StaticResource separatorTemplate}" x:Key="toolBarItemTemplateSelector" />


<ToolBar AutomationProperties.AutomationId="toolBar" ItemsSource="{Binding ToolBarItems}" x:Name="toolBar" Band="1" BandIndex="1" ItemTemplateSelector="{StaticResource toolBarItemTemplateSelector}"/>

答案 1 :(得分:3)

您可以只抓住Separator的ControlTemplate(在Blend中,右键单击分隔符 - &gt;编辑模板 - &gt;编辑副本),然后将其直接合并到按钮模板中,而不是插入Separator对象。您可以使用DataTrigger来控制其可见性,可能绑定到对象上的“BeginGroup”属性。

如果您想在集合中拥有专用的Separator对象,可以使用DataTemplateSelector。