簡體   English   中英

AvalonDock - 防止可錨定窗格停靠在文檔窗格中

[英]AvalonDock - prevent anchorable pane docking in document pane

是否可以防止錨定對象停靠在我的文檔窗格中? 我希望它們可以在屏幕上拖動和移動,但有時用戶將它們拖到文檔窗格中,這會使它們看起來很糟糕。 然后他們關閉選項卡,我無法重新打開可錨定。

如果它有助於我的 Avalon 代碼如下:

        <avalonDock:DockingManager.Theme>
            <avalonDock:VS2010Theme />
        </avalonDock:DockingManager.Theme>

        <avalonDock:DockingManager.DocumentHeaderTemplate>
            <DataTemplate>
                <StackPanel Orientation="Horizontal">
                    <StackPanel Orientation="Horizontal">
                        <!-- the TextBlock named Limiter is used to limit the height of the TextBlock for the workflow name. -->
                        <TextBlock x:Name="Limiter" TextWrapping="NoWrap" Visibility="Hidden"
                                                       TextTrimming="CharacterEllipsis">
                                                L
                        </TextBlock>
                        <TextBlock Text="{Binding Path=Title}" VerticalAlignment="Center"
                                   ToolTip="{StaticResource WorkflowTabItemToolTip}"
                                   MaxHeight="{Binding ActualHeight, ElementName=Limiter}" MaxWidth="150"
                                   TextWrapping="NoWrap" TextTrimming="CharacterEllipsis" Margin="0,0,2,0" 
                                   AutomationProperties.AutomationId="WorkflowTabTitleText"/>
                        <TextBlock Text=" *" 
                                   ToolTip="Has unsaved changes"
                                   Visibility="{Binding Content.UnsavedEdits, Converter={StaticResource BoolToVis}}"
                                   AutomationProperties.AutomationId="DirtyTabIndicator"/>
                    </StackPanel>
                </StackPanel>
            </DataTemplate>
        </avalonDock:DockingManager.DocumentHeaderTemplate>

        <avalonDock:DockingManager.LayoutItemContainerStyleSelector>
            <utilities1:PanesStyleSelector>
                <utilities1:PanesStyleSelector.WebUIStyle>
                    <Style TargetType="{x:Type avalonDock:LayoutAnchorableItem}">
                        <Setter Property="Title" Value="{Binding Model.Title}"/>
                        <Setter Property="IconSource" Value="{Binding Model.IconSource}"/>
                        <Setter Property="Visibility" Value="{Binding Model.IsVisible, Mode=TwoWay, Converter={StaticResource BoolToVisibilityConverter}, ConverterParameter={x:Static Visibility.Hidden}}"/>
                        <Setter Property="ContentId" Value="{Binding Model.ContentId}"/>
                        <Setter Property="IsSelected" Value="{Binding Model.IsSelected, Mode=TwoWay}"/>
                        <Setter Property="IsActive" Value="{Binding Model.IsActive, Mode=TwoWay}"/>
                    </Style>
                </utilities1:PanesStyleSelector.WebUIStyle>
                <utilities1:PanesStyleSelector.DocumentStyle>
                    <Style TargetType="{x:Type avalonDock:LayoutItem}">
                        <Setter Property="Title" Value="{Binding Model.WorkflowName}" />
                        <Setter Property="IsActive" Value="{Binding Model.IsActive}" />
                        <Setter Property="IsSelected" Value="{Binding Model.IsActive}" />
                    </Style>
                </utilities1:PanesStyleSelector.DocumentStyle>
            </utilities1:PanesStyleSelector>
        </avalonDock:DockingManager.LayoutItemContainerStyleSelector>

        <avalonDock:DockingManager.LayoutItemTemplateSelector>
            <utilities1:PanesTemplateSelector>
                <utilities1:PanesTemplateSelector.WorkflowDesignerViewTemplate>
                    <DataTemplate>
                        <ContentControl cal:View.Model="{Binding}" IsTabStop="False" />
                    </DataTemplate>
                </utilities1:PanesTemplateSelector.WorkflowDesignerViewTemplate>
                <utilities1:PanesTemplateSelector.WebUIViewTemplate>
                    <DataTemplate>
                        <ContentControl cal:View.Model="{Binding}" IsTabStop="False" />
                    </DataTemplate>
                </utilities1:PanesTemplateSelector.WebUIViewTemplate>
            </utilities1:PanesTemplateSelector> 
        </avalonDock:DockingManager.LayoutItemTemplateSelector>

        <avalonDock:LayoutRoot>
            <avalonDock:LayoutPanel Orientation="Horizontal">
                <avalonDock:LayoutDocumentPaneGroup>
                    <avalonDock:LayoutDocumentPane AutomationProperties.AutomationId="AvalonDocumentPane"/>
                </avalonDock:LayoutDocumentPaneGroup>
                <avalonDock:LayoutAnchorablePane DockWidth="800" DockMinWidth="400" AutomationProperties.AutomationId="WebUIPane"/>
                <avalonDock:LayoutAnchorablePane DockWidth="225" DockMinWidth="225" AutomationProperties.AutomationId="ActivitiesPane">
                    <avalonDock:LayoutAnchorable Title="Activities" AutoHideWidth="225" AutoHideMinWidth="225" CanClose="False" CanHide="False">
                        <toolbox:ToolboxControl Name="Toolbox" AutomationProperties.AutomationId="ActivitiesToolbox"
                                                        utilities1:ToolboxItemSource.ToolboxItems="{Binding ToolboxList}" />
                    </avalonDock:LayoutAnchorable>
                </avalonDock:LayoutAnchorablePane>
            </avalonDock:LayoutPanel>
        </avalonDock:LayoutRoot>

    </avalonDock:DockingManager>

盡管沒有找到防止停靠的直接方法,但我能夠解決基本問題,即為工具窗口和文檔窗口自定義不同的選項卡標題。 我的文檔窗口在選項卡標題中顯示星號(*)來指示更改(就像VS),而工具窗口則不應該這樣做。

解決方案是使用DocumentHeaderTemplateSelector並為其提供兩個不同的模板,每個模板用於文檔和工具窗口。 這是XAML:

<xcad:DockingManager.DocumentHeaderTemplateSelector>
  <bd:DocumentHeaderTemplateSelector>
    <bd:DocumentHeaderTemplateSelector.DocumentTemplate>
      <DataTemplate>
        <StackPanel Orientation="Horizontal">
          <Image Source="Resources\AppIcon.ico" Margin="0,0,4,0" Width="16" />
          <TextBlock Text="{Binding Title}" />
          <TextBlock Text=" *" Visibility="{Binding Content.IsDirty, Converter={StaticResource BoolToVisibilityConverter}}" />
        </StackPanel>
      </DataTemplate>
    </bd:DocumentHeaderTemplateSelector.DocumentTemplate>
    <bd:DocumentHeaderTemplateSelector.ToolWindowTemplate>
      <DataTemplate>
        <StackPanel Orientation="Horizontal">
          <TextBlock Text="{Binding Title}" />
        </StackPanel>
      </DataTemplate>
    </bd:DocumentHeaderTemplateSelector.ToolWindowTemplate>
  </bd:DocumentHeaderTemplateSelector>
</xcad:DockingManager.DocumentHeaderTemplateSelector>

選擇器類很簡單:

Public Class DocumentHeaderTemplateSelector
  Inherits DataTemplateSelector

  Public Property DocumentTemplate As DataTemplate
  Public Property ToolWindowTemplate As DataTemplate

  Public Overrides Function SelectTemplate(item As Object, container As System.Windows.DependencyObject) As System.Windows.DataTemplate
    Dim itemAsLayoutContent = TryCast(item, Xceed.Wpf.AvalonDock.Layout.LayoutContent)

    If TypeOf item Is Xceed.Wpf.AvalonDock.Layout.LayoutDocument AndAlso TypeOf DirectCast(item, Xceed.Wpf.AvalonDock.Layout.LayoutDocument).Content Is DocumentVM Then
      Return DocumentTemplate
    Else
      Return ToolWindowTemplate
    End If
  End Function
End Class

現在,即使將其移動到文檔窗格中,我的工具窗口也不會顯示星號(*)和圖標。

希望這可以幫助某人。

    <avalonDock:LayoutRoot>
                <avalonDock:LayoutPanel CanRepositionItems="False" Orientation="Vertical">

                    <avalonDock:LayoutAnchorablePane Name="ToolsPane" DockHeight="100" CanRepositionItems="False">

                        <avalonDock:LayoutAnchorable CanDockAsTabbedDocument="False"/>

                    </avalonDock:LayoutAnchorablePane>
                    
                </avalonDock:LayoutPanel>
                
</avalonDock:LayoutRoot>

avalonDock:LayoutAnchorable集中

CanDockAsTabbedDocument

屬性為False 這將禁用可錨定視圖停靠在文檔窗格中。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM