2009-06-20 106 views
0

我有一個自定義的TabItem和一個關閉按鈕(用X表示),所以它可以很容易地關閉。在這個標籤我想提出一個圖片或者邊框項目,即在左上角爲中心與關閉按鈕WPF用按鈕覆蓋圖像

控制這個模板是

<ControlTemplate TargetType="{x:Type local:CloseableTabItem}"> 
     <Grid SnapsToDevicePixels="true"> 
     <Border x:Name="Bd" Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="1,1,1,0" > 
      <DockPanel x:Name="ContentPanel"> 
      <Button x:Name="PART_Close" Panel.ZIndex="1" HorizontalAlignment="Right" Margin="0,1,1,0" VerticalAlignment="Top" Width="16" Height="16" DockPanel.Dock="Right" Style="{DynamicResource CloseableTabItemButtonStyle}" ToolTip="Close Tab"> 
       <Path x:Name="Path" Stretch="Fill" StrokeThickness="0.5" Stroke="#FF333333" Fill="#FF969696" Data="F1 M 2.28484e-007,1.33331L 1.33333,0L 4.00001,2.66669L 6.66667,6.10352e-005L 8,1.33331L 5.33334,4L 8,6.66669L 6.66667,8L 4,5.33331L 1.33333,8L 1.086e-007,6.66669L 2.66667,4L 2.28484e-007,1.33331 Z " HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/> 
      </Button> 
      <ContentPresenter Panel.ZIndex="0" x:Name="Content" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" ContentSource="Header" RecognizesAccessKey="True" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="{TemplateBinding Padding}"/> 
      </DockPanel> 
     </Border> 
     </Grid> 

(控制觸發已被刪除) 並插入邊框/圖片到該選項卡標題我用下面的

<TabControl Margin="0" TabStripPlacement="Left"> 
     <local:CloseableTabItem> 
      <local:CloseableTabItem.Header> 
       <Border Height="50" Width="50" Background="Red" BorderThickness="1" BorderBrush="Black" Margin="5" /> 
      </local:CloseableTabItem.Header>  
     </local:CloseableTabItem> 
    </TabControl> 

使用此我得到以下結果:

alt text http://lloydsparkes.co.uk/files/CloseTab.png

它似乎按鈕是限制邊框元素的寬度,所以它沒有達到我設置的全寬(它被設置爲50x50,所以應該是一個正方形)。我試圖把它們放到不同的Z層上,但它看起來並沒有像我期望的那樣工作。

所以問題是,我怎樣才能使按鈕覆蓋邊界控制沒有影響邊界控制的大小的按鈕?

回答

2

這種行爲是因爲這裏的DockPanel中的:

<DockPanel x:Name="ContentPanel"> 
     <Button x:Name="PART_Close" Panel.ZIndex="1" HorizontalAlignment="Right" Margin="0,1,1,0" VerticalAlignment="Top" Width="16" Height="16" DockPanel.Dock="Right" Style="{DynamicResource CloseableTabItemButtonStyle}" ToolTip="Close Tab"> 
      <Path x:Name="Path" Stretch="Fill" StrokeThickness="0.5" Stroke="#FF333333" Fill="#FF969696" Data="F1 M 2.28484e-007,1.33331L 1.33333,0L 4.00001,2.66669L 6.66667,6.10352e-005L 8,1.33331L 5.33334,4L 8,6.66669L 6.66667,8L 4,5.33331L 1.33333,8L 1.086e-007,6.66669L 2.66667,4L 2.28484e-007,1.33331 Z " HorizontalAlignment="Stretch" VerticalAlignment="Stretch"/> 
     </Button> 
     <ContentPresenter Panel.ZIndex="0" x:Name="Content" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" ContentSource="Header" RecognizesAccessKey="True" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="{TemplateBinding Padding}"/> 
     </DockPanel> 

卸下固定面板和你的財產進行必要的調整和問題將得到解決。

+0

謝謝,即時通訊仍在學習WPF/XAML,所以這是有用的知道。 – lloydsparkes 2009-06-20 18:56:24