gpt4 book ai didi

c# - WPF TabItem - 图像绑定(bind)

转载 作者:太空宇宙 更新时间:2023-11-03 12:51:07 31 4
gpt4 key购买 nike

问题


我正在尝试将图像从我的 TabItem 绑定(bind)到我的 TabControlResource 部分,但我似乎无法做到这一点。 Header 文本很好,因为 TabItem 具有 Header 属性,但我无法将图像添加到其中。

代码


这是我的整个 TabControl 代码:

<TabControl Margin="10" BorderBrush="#c83620" BorderThickness="4" Background="#e37e6e" FontFamily="Segoe UI" FontSize="14" >
<TabControl.Resources>
<Style TargetType="TabItem">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="TabItem">
<Border Name="Border" BorderThickness="4,4,4,0" BorderBrush="#c83620" CornerRadius="4,4,0,0" Padding="6,4,6,4" Margin="6,0">
<StackPanel Orientation="Horizontal" Margin="6,4,6,4">
<Image Name="img" Height="15" Width="15" Margin="0,0,4,0" Source="../Images/delete.png" />
<Label Grid.Row="0" Name="Text" Foreground="Black" Content="{TemplateBinding Header}"/>
</StackPanel>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter TargetName="Border" Property="Background" Value="#e37e6e" />
<Setter TargetName="Text" Property="TextBlock.Foreground" Value="White"/>
<Setter TargetName="Text" Property="TextBlock.FontWeight" Value="Bold"/>
<Setter TargetName="Border" Property="Margin" Value="1,1,1,-4"/>
<Setter TargetName="Border" Property="Padding" Value="2"/>
</Trigger>
<Trigger Property="IsSelected" Value="False">
<Setter TargetName="Text" Property="TextBlock.Foreground" Value="#c83620"/>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</TabControl.Resources>
<TabItem Margin="-3,0,0,0" Header="Login">
</TabItem>
<TabItem Header="General" >
<Label Content="Content goes here..." />
</TabItem>
<TabItem Header="Security" />
<TabItem Header="Details" />
</TabControl>

正如您从下面的部分中看到的那样,我将标签的内容绑定(bind)到 TabItem 的 header 并且它工作正常:

<Border Name="Border" BorderThickness="4,4,4,0" BorderBrush="#c83620" CornerRadius="4,4,0,0" Padding="6,4,6,4" Margin="6,0">
<StackPanel Orientation="Horizontal" Margin="6,4,6,4">
<Image Name="img" Height="15" Width="15" Margin="0,0,4,0" Source="../Images/delete.png" />
<Label Grid.Row="0" Name="Text" Foreground="Black" Content="{TemplateBinding Header}"/>
</StackPanel>
</Border>

但我想为每个 TabItems 使用不同的图像。在哪里可以将图像绑定(bind)到 TabItem 以获得正确的图像?

最佳答案

您可以使用模板的其他属性来做到这一点,例如 Tag 属性。所以图像绑定(bind)应该是这样的。

<Image Name="img" Height="15" Width="15" Margin="0,0,4,0" 
Source="{Binding RelativeSource={RelativeSource Mode=TemplatedParent}, Path=Tag.Source}" />

并且您应该在资源中定义所有这样的图像。

<Image x:Key="testImage" Source="/WPFTest;component/Images/Reload.png" />

并将其绑定(bind)到TabItemTag 属性。

<TabItem Header="General" Tag="{StaticResource testImage}" >

关于c# - WPF TabItem - 图像绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35505254/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com