4

から派生したカスタムコントロールがあり、そのカスタムをストックTabItemにデータバインドしたいと思います。このまれなケースのためだけに、新しいものを作成することは避けたいと思います。TabItemTabControlTabControl

これは私が持っているものであり、正しいコントロールをロードすることができません。ClosableTabItemこの場合、ストックコントロールの代わりに自分のコントロールを使用したいと思いTabItemます。

<TabControl x:Name="tabCases" IsSynchronizedWithCurrentItem="True" 
            Controls:ClosableTabItem.TabClose="TabClosed" >
    <TabControl.ItemTemplate>
        <DataTemplate DataType="{x:Type Controls:ClosableTabItem}" >
            <TextBlock Text="{Binding Path=Id}" />
        </DataTemplate>
    </TabControl.ItemTemplate>
    <TabControl.ContentTemplate>
        <DataTemplate DataType="{x:Type Entities:Case}">
            <CallLog:CaseReadOnlyDisplay DataContext="{Binding}" />
        </DataTemplate>
    </TabControl.ContentTemplate>
</TabControl>

編集:これは、カスタムコントロールをバインドしようとするのではなく、私が最終的に得たものです。前の質問から取得した「CloseCommand 」 。

    <Style TargetType="{x:Type TabItem}" BasedOn="{StaticResource {x:Type TabItem}}" >
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type TabItem}">
                    <Border 
                            Name="Border"
                            Background="LightGray"
                            BorderBrush="Black" 
                            BorderThickness="1" 
                            CornerRadius="25,0,0,0"
                            SnapsToDevicePixels="True">
                        <StackPanel Orientation="Horizontal">
                        <ContentPresenter x:Name="ContentSite"
                              VerticalAlignment="Center"
                              HorizontalAlignment="Center"
                              ContentSource="Header"
                              Margin="20,1,5,1"/>
                            <Button 
                                Command="{Binding Path=CloseCommand}"
                                Cursor="Hand"
                                DockPanel.Dock="Right"
                                Focusable="False"
                                Margin="1,1,5,1"
                                Background="Transparent"
                                BorderThickness="0">
                                <Image Source="/Russound.Windows;component/Resources/Delete.png" Height="10" />
                            </Button>
                        </StackPanel>
                    </Border>
                    <ControlTemplate.Triggers>
                        <Trigger Property="IsSelected" Value="True">
                            <Setter Property="FontWeight" Value="Bold" />
                            <Setter TargetName="Border" Property="Background" Value="LightBlue" />                            
                            <Setter TargetName="Border" Property="BorderThickness" Value="1,1,1,0" />
                            <Setter TargetName="Border" Property="BorderBrush" Value="DarkBlue" />
                        </Trigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
4

2 に答える 2

7

方法を見つけ、TabControlからクラスを派生させ、この関数をオーバーライドします。私の場合、タブコントロールのアイテム(バインドされている場合)をCloseableTabItemsにします。

public class CloseableTabControl : TabControl
    {
        protected override DependencyObject GetContainerForItemOverride()
        {
            return new CloseableTabItem();
        }
    }

HTH誰か

サム

于 2010-05-08T22:02:25.693 に答える
1

この場合DataType、のを設定する必要はありません。DataTemplateプロパティの値はItemTemplate、新しいアイテムを追加する必要がある場合は常に使用され、タブコントロールの場合は、新しいアイテムを作成するために使用されますTabItemDataTemplateクラスのインスタンスをそれ自体の中で宣言する必要があります。

<TabControl x:Name="tabCases" IsSynchronizedWithCurrentItem="True" Controls:ClosableTabItem.TabClose="TabClosed">
    <TabControl.ItemTemplate>
        <DataTemplate>
            <Controls:ClosableTabItem>
                <TextBlock Text="{Binding Path=Id}" />
            </Controls:ClosableTabItem>
        </DataTemplate>
    </TabControl.ItemTemplate>
    <TabControl.ContentTemplate>
        <DataTemplate DataType="{x:Type Entities:Case}">
            <CallLog:CaseReadOnlyDisplay DataContext="{Binding}" />
        </DataTemplate>
    </TabControl.ContentTemplate>
</TabControl>

これによりClosableTabItem、新しいタブがに追加されるたびに新しいタブが作成されますTabControl

更新; あなたのコメントから、それ自体を変更するのではなく、ItemTemplate内で作成されるものを制御しているように聞こえます。やりたいことをするために、しかし、のために、あなたはを設定するでしょう。残念ながら、のプロパティは表示されません。TabItemTabItemTreeViewHeaderTemplateHeaderTemplateTabControl

私はいくつかの検索を行いました、そしてこのチュートリアルはにコントロールを追加することによってタブヘッダーの内容を変更しますTabItem.Header。たぶん、あなたはあなたのクラスが現在追加している閉じるボタンを追加するStyleあなたのためにを作成することができますか?TabItems

于 2009-06-01T19:41:52.443 に答える