Reorder tabs in WPF TabControl

前端 未结 1 566
小蘑菇
小蘑菇 2020-12-30 06:24

Is there an easy way to customize the WPF TabControl so that it supports TabItem drag and drop - similar to what IE and firefox do.

相关标签:
1条回答
  • 2020-12-30 07:11

    You could use or get started with Bea Stollnitz's existing helpers for Dragging and Dropping in an ItemsControl. It does have some limitations as she mentions, but it's a great place to start, and probably will work as is for most all of the functionality you will require.

    After importing her DragDropHelper and Adorner classes, it's very simple to use them with the TabControl (Since it is a descendant of ItemsControl).

    Setting a simple drag template, and the properties on the TabControl are all we need. Since the solution is set up to handle dragging of data bound items, if your tabs are statically declared in XAML instead of using the TabControl.ItemsSource then you can just bind their DataContext to themselves.

    <Window x:Class="Samples.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:dd="clr-namespace:DragDropListBox"
        Title="Dragging TabItems"
        Height="300"
        Width="300">
    
    <Window.Resources>
        <DataTemplate x:Key="Local_TabItemDragTemplate">
            <Border CornerRadius="5"
                    BorderBrush="Black"
                    BorderThickness="2"
                    Background="DodgerBlue">
                <TextBlock Margin="5"
                           Text="{Binding Path=Header}" />
            </Border>
        </DataTemplate>
    </Window.Resources>
    
    <StackPanel>
        <TabControl dd:DragDropHelper.IsDragSource="true"
                    dd:DragDropHelper.IsDropTarget="true"
                    dd:DragDropHelper.DragDropTemplate="{StaticResource Local_TabItemDragTemplate}">
            <TabControl.ItemContainerStyle>
                <Style TargetType="{x:Type TabItem}">
                    <Setter Property="DataContext"
                            Value="{Binding RelativeSource={RelativeSource Self}}" />
                </Style>
            </TabControl.ItemContainerStyle>
            <TabItem Header="Tab 1" />
            <TabItem Header="Tab 2" />
            <TabItem Header="Tab 3" />
            <TabItem Header="Tab 4" />
        </TabControl>
        <TabControl dd:DragDropHelper.IsDragSource="true"
                    dd:DragDropHelper.IsDropTarget="true"
                    dd:DragDropHelper.DragDropTemplate="{StaticResource Local_TabItemDragTemplate}">
            <TabControl.ItemContainerStyle>
                <Style TargetType="{x:Type TabItem}">
                    <Setter Property="DataContext"
                            Value="{Binding RelativeSource={RelativeSource Self}}" />
                </Style>
            </TabControl.ItemContainerStyle>
            <TabItem Header="Tab 5" />
            <TabItem Header="Tab 6" />
            <TabItem Header="Tab 7" />
            <TabItem Header="Tab 8" />
        </TabControl>
    </StackPanel>
    

    0 讨论(0)
提交回复
热议问题