【问题标题】:Setter.TargetName does not work against an element from the BasedOn settingSetter.TargetName 不适用于 BasedOn 设置中的元素
【发布时间】:2012-08-06 00:00:10
【问题描述】:

我有许多 PathGeometry 实例,它们为不同的按钮绘制各种图形。所以我创建了一个按钮类型来显示一个路径,然后根据按钮状态更新 Path.Stroke。因此,禁用时显示为灰色,鼠标悬停时显示不同的颜色。标准的东西...

<Style x:Key="BasePathButton" TargetType="{x:Type Button}">
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type Button}">
                <Border Name="Border"
                    <Path x:Name="Path" />
                </Border>
                <ControlTemplate.Triggers>
                    <Trigger Property="IsEnabled" Value="False">
                        <Setter TargetName="Path" Property="Stroke" Value="Gray"/>
                    </Trigger>
                    <Trigger Property="IsMouseOver" Value="True">
                        <Setter TargetName="Path" Property="Stroke" Value="Green"/>
                    </Trigger>
                    <Trigger Property="IsPressed" Value="True">
                        <Setter TargetName="Path" Property="Stroke" Value="Red"/>
                    </Trigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

但显然我需要为每个按钮实例使用不同的 Path.Data。所以我创建了一个 BasedOn 样式来设置 Path.Data 像这样......

<Style x:Key="NLB" TargetType="{x:Type Button}" BasedOn="{StaticResource BasePathButton}">
    <Setter TargetName="Path" Property="Data" Value="{StaticResource LeftPathGeometry}"/>
</Style>

...但这会失败,并出现无法找到 TargetName="Path" 的错误。任何想法如何解决这一问题?或者也许是一种更好的方法来创建一个具有使用几何参数化的路径的按钮?

【问题讨论】:

    标签: wpf button styles pathgeometry


    【解决方案1】:

    您不能通过名称定位模板中的元素,这是一个不同的名称范围,我认为TargetName 仅适用于ControlTemplate.Triggers。您可以将数据引用为DynamicResource,然后将资源添加到您的个人样式中。

    例如

    <Path Data="{DynamicResource PathData}" .../>
    
    <Style x:Key="..." BasedOn="...">
        <Style.Resources>
            <!-- not sure if this actually works, you could also try DynamicResource here -->
            <StaticResource x:Key="PathData" ResourceKey="LeftPathGeometry"/>
        </Style.Resources>
    </Style>
    

    这是一个完整的独立示例,展示了这种技术(似乎只适用于动态编译的 XAML!)

    <Page xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:sys="clr-namespace:System;assembly=mscorlib" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
      <Page.Resources>
        <SolidColorBrush x:Key="RedBrush" Color="Red"/>
        <SolidColorBrush x:Key="BlueBrush" Color="Blue"/>
    
        <Style x:Key="BaseStyle" TargetType="Button">
          <Setter Property="Template">
            <Setter.Value>
              <ControlTemplate TargetType="Button">
                <Border BorderBrush="{DynamicResource StyleBrush}" BorderThickness="3" Padding="5">
                  <ContentPresenter TextElement.Foreground="{DynamicResource StyleBrush}"/>
                </Border>
              </ControlTemplate>
            </Setter.Value>
          </Setter>
        </Style>
        <Style x:Key="RedStyle" BasedOn="{StaticResource BaseStyle}" TargetType="Button">
          <Style.Resources>
            <StaticResource x:Key="StyleBrush" ResourceKey="RedBrush"/>
          </Style.Resources>
        </Style>
        <Style x:Key="BlueStyle" BasedOn="{StaticResource BaseStyle}" TargetType="Button">
          <Style.Resources>
            <StaticResource x:Key="StyleBrush" ResourceKey="BlueBrush"/>
          </Style.Resources>
        </Style>
      </Page.Resources>
      <StackPanel>
        <Button Content="Test" Style="{StaticResource RedStyle}"/>
        <Button Content="Test" Style="{StaticResource BlueStyle}"/>
      </StackPanel>
    </Page>
    

    【讨论】:

    • 但这不会将路径分配到基本样式中。
    • @PhilWright:它应该,因为引用是动态的,我只是用另一个属性测试了它,它做得很好。添加了一个独立的示例。
    • 很抱歉打扰,但我很难尝试做几乎相同的事情,如果你介意看一下:stackoverflow.com/questions/41062079/…
    猜你喜欢
    • 1970-01-01
    • 2011-10-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多