繁体   English   中英

如何在WP7中更改VisualState

[英]How do I change the VisualState in WP7

我在Expression Blend中定义了以下两种状态。 我一直在努力遵循这个指南,但当我需要有关如何以及何时改变状态的信息时,我觉得它让我感到不知所措。

在此输入图像描述

根据指南,我将一个行为(我假设“GotoState”)附加到我的UserControl - 不幸的是我不认为我实际上有一个User Control - 即使我这样做,我是否必须将行为附加到我的两个PortraitState和我的LandscapeState

我似乎可以将GotoState附加到我的LayoutRoot元素。 那么我是否将这种行为与两种状态中的行为联系起来? 任何帮助将不胜感激。

*编辑:我正在我的xaml.cs文件中玩,并认为这可能是以编程方式执行此操作的方法。 调试和更改方向时,我进入开关盒并找到正确的方向。 然而,国家从未切换过。 我究竟做错了什么?

    protected override void OnOrientationChanged(OrientationChangedEventArgs e)
    {
        switch (e.Orientation)
        {
            case PageOrientation.Landscape:
                ExtendedVisualStateManager.GoToElementState(root:this.LayoutRoot, stateName: "LandscapeState", useTransitions: true);
                break;
            case PageOrientation.LandscapeRight:
                ExtendedVisualStateManager.GoToElementState(root:this.LayoutRoot, stateName: "LandscapeState", useTransitions: true);
                break;
            case PageOrientation.LandscapeLeft:
                ExtendedVisualStateManager.GoToElementState(root:LayoutRoot, stateName: "LandscapeState", useTransitions: true);
                break;
            case PageOrientation.Portrait:
                ExtendedVisualStateManager.GoToElementState(root:this.LayoutRoot, stateName: "PortraitState", useTransitions: true);
                break;
            case PageOrientation.PortraitUp:
                ExtendedVisualStateManager.GoToElementState(root:this.LayoutRoot, stateName: "PortraitState", useTransitions: true);
                break;
            case PageOrientation.PortraitDown:
                ExtendedVisualStateManager.GoToElementState(root:this.LayoutRoot, stateName: "PortraitState", useTransitions: true);
                break;
            default:
                break;
        }
    }

edit2:当尝试上述时GotoElementState似乎返回false,并且根据MSDN:“如果控件成功转换到新状态,则返回true;否则返回false。”

现在我留下了一个问题:什么可能导致我的状态转换失败?

像这样在WP7中更改VisualState:

  

通过执行以下操作,我设法找到了解决我自己问题的方法。

事实证明,使用ExtendedVisualStateManager.GotoElementState(UIElement,String,bool)目前效果不佳,所以我不得不找到一种方法来使用VisualStateManager.GotoState。

我通过简单地将LayoutRoot包装在UserControl中解决了我的问题:

<UserControl x:Name="userControl">
    <Grid x:Name="LayoutRoot" Background="Transparent">
        <VisualStateManager.VisualStateGroups>
    ...
</UserControl>

切换状态现在只是调用VisualStateManager.GotoState的问题,正如我最初尝试做的那样。

    protected override void OnOrientationChanged(OrientationChangedEventArgs e)
    {
        base.OnOrientationChanged(e);

        switch (e.Orientation)
        {
            case PageOrientation.Landscape:
            case PageOrientation.LandscapeRight:
            case PageOrientation.LandscapeLeft:
                VisualStateManager.GoToState(control: userControl,
                                                        stateName: "LandscapeState", 
                                                        useTransitions: true);
                break;
            case PageOrientation.Portrait:
            case PageOrientation.PortraitUp:
            case PageOrientation.PortraitDown:
                VisualStateManager.GoToState(control: userControl,
                                                        stateName: "PortraitState", 
                                                        useTransitions: true);
                break;
            default:
                VisualStateManager.GoToState(control: userControl,
                                    stateName: "PortraitState",
                                    useTransitions: true);
                break;
        }
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM