0

これは私を困惑させました。したがって、マウスが境界要素の上に置かれたときに境界要素の不透明度をアニメーション化することになっている次のサンプルアプリがあります。`

<UserControl.Resources>
    <Style x:Key="borderstyle" TargetType="ContentControl">
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="ContentControl">
                    <Grid>

                        <VisualStateManager.VisualStateGroups>

                            <VisualStateGroup>
                                <VisualState x:Name="FirstState">
                                    <Storyboard>
                                        <DoubleAnimation To="1.0" Storyboard.TargetName="border" Storyboard.TargetProperty="Opacity" FillBehavior="HoldEnd"/>
                                    </Storyboard>
                                </VisualState>
                            </VisualStateGroup>

                        </VisualStateManager.VisualStateGroups>

                        <Border Background="Blue" x:Name="border" Opacity="0.0"/>

                    </Grid>
                </ControlTemplate>
            </Setter.Value>
        </Setter>

    </Style>
</UserControl.Resources>


<Grid x:Name="LayoutRoot" Background="White">
    <Border BorderBrush="Red" BorderThickness="1" Width="51" Height="51">
        <ContentControl Width="50" Height="50" Style="{StaticResource borderstyle}"  MouseEnter="OnMouseEntered" />
    </Border>
</Grid>

`

そして、コードビハインドには次のコードがあります...

    private void OnMouseEntered(object sender, MouseEventArgs e)
    {
        bool status = VisualStateManager.GoToState(this, "FirstState", true);
    }

そして...何も起こりません。statusは常に false で、アニメーションは起動しません。

ここに何が欠けているのかわかりません。

4

3 に答える 3

3

ContentControlどの状態が変化するかをコントロールとして自分を指定する必要があります。

private void OnMouseEntered(object sender, MouseEventArgs e)
{
    bool status = VisualStateManager.GoToState((ContentControl)sender, "FirstState", false);
}
于 2010-12-17T17:48:28.803 に答える
1

コントロールに追加ApplyTemplate()します(コントロールが動的に(プログラムで)追加される場合に必要です。

于 2012-03-14T23:32:55.180 に答える