Use style trigger to set property of a nested object

前端 未结 3 1045
感动是毒
感动是毒 2020-12-06 06:21

I have a small polygon written on the large canvas. I want to highlight a polygon when mouse is moving over the canvas. The code is like this:



        
相关标签:
3条回答
  • 2020-12-06 07:03

    It's looking for a property of the Canvas called 'polygon', which in turn has a property called 'Stroke'. You need to use TargetName if you want the setter to target a different object.

    <Setter TargetName="polygon" Property="Stroke" Value="#EEEEEE" />
    
    0 讨论(0)
  • 2020-12-06 07:09

    You cannot use Setters like that, if you use this kind of notation the engine will look for an attached property, or if no Style.TargetType was set for a property on the type before the dot.

    The easiest thing to do is probably applying a style to the polygon itself and using a DataTrigger which binds to the Canvas so you can trigger on its properties.

      <Polygon Points="11,1 16,6 16,16 11,21" Name="polygon">
           <Polygon.Fill>
               <SolidColorBrush Color="#EEEEEE"/>
           </Polygon.Fill>
           <Polygon.Style>
              <Style TargetType="{x:Type Polygon}">
                 <Style.Triggers> 
                    <DataTrigger
                       Binding="{Binding Path=IsMouseOver,
                                         RelativeSource={RelativeSource
                                         AncestorType={x:Type Canvas}}}"
                       Value="True">
                       <Setter Property="Stroke" Value="Red"/>
                    </DataTrigger>
                 </Style.Triggers>
              </Style>
           <Polygon.Style>
      </Polygon>
    
    0 讨论(0)
  • 2020-12-06 07:22

    Try EventTrigger, because other kinds of triggers you could only use in templates or styles. And we already know that Style.Trigger doesn't allow your scenario. So here is working example for you:

    <Canvas Name="canvas" Height="22" Width="22">
        <Polygon Points="11,1 16,6 16,16 11,21" Name="polygon">
            <Polygon.Fill>
                <SolidColorBrush x:Name="brush" Color="#EEEEEE"/>
            </Polygon.Fill>
            <Polygon.Triggers>
                <EventTrigger RoutedEvent="UIElement.MouseEnter">
                    <BeginStoryboard>
                        <Storyboard Storyboard.TargetName="brush" Storyboard.TargetProperty="Color">
                            <ColorAnimation From="#EEEEEE" To="Aqua" Duration="00:00:00.01" />
                        </Storyboard>
                    </BeginStoryboard>
                </EventTrigger>
                <EventTrigger RoutedEvent="UIElement.MouseLeave">
                    <BeginStoryboard>
                        <Storyboard Storyboard.TargetName="brush" Storyboard.TargetProperty="Color">
                            <ColorAnimation From="Aqua" To="#EEEEEE" Duration="00:00:00.01" />
                        </Storyboard>
                    </BeginStoryboard>
                </EventTrigger>
            </Polygon.Triggers>
        </Polygon>
    </Canvas>
    
    0 讨论(0)
提交回复
热议问题