首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >WP8滚动器不会在页面之间重置(WinRT)

WP8滚动器不会在页面之间重置(WinRT)
EN

Stack Overflow用户
提问于 2015-03-02 18:50:01
回答 1查看 107关注 0票数 1

我正在开发一个WP8 WinRT应用程序。在我的DetailPage.xaml上,我有一个包含ListView和图像的ScrollViewer。

ScrollViewer工作正常,只是当我在页面之间导航时,它不会重新设置自己。

如果我向下滚动到页面A的底部,然后导航到页面B,那么滚动查看器将显示内容的底部,而不是从顶部开始,然后再让我向下滚动。

这是我的详细信息页面中的XAML:

代码语言:javascript
运行
复制
<Page x:Class="LinuxBasics.RecipeDetailPage"
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:local="using:LinuxBasics"
  xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  xmlns:data="using:LinuxBasics.DataModel"
  mc:Ignorable="d"
  d:DataContext="{Binding AllGroups[1].Items[1], Source={d:DesignInstance Type=data:SampleDataSource, IsDesignTimeCreatable=True}}"
  DataContext="{Binding DefaultViewModel, RelativeSource={RelativeSource Self}}">

<Page.Transitions>
    <TransitionCollection>
        <NavigationThemeTransition>
            <NavigationThemeTransition.DefaultNavigationTransitionInfo>
                <CommonNavigationTransitionInfo IsStaggeringEnabled="True" />
            </NavigationThemeTransition.DefaultNavigationTransitionInfo>
        </NavigationThemeTransition>
    </TransitionCollection>
</Page.Transitions>

<Page.Resources>

</Page.Resources>
<!--<Page.BottomAppBar>
    <CommandBar>
        <AppBarButton x:Name="btnPinToStart" Icon="Pin" Click="btnPinToStart_Click" Label="Like"/>
        <AppBarButton x:Name="btnReminderTimer" Icon="Clock" Label="timer" Click="btnReminderTimer_Click"/>
        <AppBarButton x:Name="btnBrag" Icon="Camera" Label="brag">
            <AppBarButton.Flyout>
                <MenuFlyout>
                    <MenuFlyoutItem x:Name="menuPhoto" Text="Photo" Click="menuPhoto_Click"/>
                    <MenuFlyoutSeparator/>
                    <MenuFlyoutItem x:Name="menuVideo" Text="Video" Click="menuVideo_Click"/>
                </MenuFlyout>
            </AppBarButton.Flyout>
        </AppBarButton>
    </CommandBar>
</Page.BottomAppBar>-->


<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}"
      x:Name="LayoutRoot3"
      CommonNavigationTransitionInfo.IsStaggerElement="True"
      DataContext="{Binding Item}"
      d:DataContext="{Binding}">

    <Grid.RowDefinitions>
        <RowDefinition Height="Auto" />
        <RowDefinition Height="*" />

    </Grid.RowDefinitions>

    <StackPanel x:Name="TitlePanel"
                Grid.Row="0"
                Margin="20,12,0,28">

        <TextBlock x:Name="AppTiltle"
                   Text="LINUX BASICS"
                   Style="{ThemeResource TitleTextBlockStyle}"
                   Typography.Capitals="SmallCaps" />

        <TextBlock x:Name="AppCommand"
                   d:DataContext="{Binding}"
                   Text="{Binding Title}"
                   Margin="0,12,0,0"
                   TextWrapping="Wrap"
                   Style="{ThemeResource HeaderTextBlockStyle}" />

    </StackPanel>

    <Grid x:Name="RecipePanel"
          Grid.Row="1">

    </Grid>
    <ScrollViewer Grid.Row="1"
                  Margin="0,10">
        <StackPanel>

        <Grid>
            <Grid.RowDefinitions>
                <RowDefinition Height="Auto" />
                <RowDefinition Height="Auto" />
            </Grid.RowDefinitions>

            <ListView ItemsSource="{Binding Ingredients}"
                      x:Uid="RecipeIngredientsPivotItem"
                      Grid.Row="0"
                      Margin="20,12,10,10">
                <ListView.ItemTemplate>
                    <DataTemplate>

                        <TextBlock Text="{Binding Mode=OneWay}"
                                   Style="{ThemeResource BodyTextBlockStyle}" />

                    </DataTemplate>
                </ListView.ItemTemplate>
            </ListView>

            <Image Source="{Binding ImagePath}"
                   Stretch="UniformToFill"
                   VerticalAlignment="Center"
                   HorizontalAlignment="Center"
                   Margin="20,20,10,20"
                   Grid.Row="1"/>

        </Grid>
    </StackPanel>
</ScrollViewer>
</Grid>

这就是背后的代码:

代码语言:javascript
运行
复制
public sealed partial class RecipeDetailPage : Page
{
    private NavigationHelper navigationHelper;
    private ObservableDictionary defaultViewModel = new ObservableDictionary();

    /// <summary>
    /// NavigationHelper is used on each page to aid in navigation and 
    /// process lifetime management
    /// </summary>
    public NavigationHelper NavigationHelper
    {
        get { return this.navigationHelper; }
    }

    /// <summary>
    /// This can be changed to a strongly typed view model.
    /// </summary>
    public ObservableDictionary DefaultViewModel
    {
        get { return this.defaultViewModel; }
    }

    public RecipeDetailPage()
    {
        this.InitializeComponent();

        this.NavigationCacheMode = Windows.UI.Xaml.Navigation.NavigationCacheMode.Required;

        this.navigationHelper = new NavigationHelper(this);
        this.navigationHelper.LoadState += navigationHelper_LoadState;
    }

    /// <summary>
    /// Populates the page with content passed during navigation.  Any saved state is also
    /// provided when recreating a page from a prior session.
    /// </summary>
    /// <param name="sender">
    /// The source of the event; typically <see cref="NavigationHelper"/>
    /// </param>
    /// <param name="e">Event data that provides both the navigation parameter passed to
    /// <see cref="Frame.Navigate(Type, Object)"/> when this page was initially requested and
    /// a dictionary of state preserved by this page during an earlier
    /// session.  The state will be null the first time a page is visited.</param>
    private async void navigationHelper_LoadState(object sender, LoadStateEventArgs e)
    {
        var item = await RecipeDataSource.GetItemAsync((String)e.NavigationParameter);
        this.DefaultViewModel["Group"] = item.Group;
        this.DefaultViewModel["Item"] = item;

        //// Is recipe already pinned?
        //if (SecondaryTile.Exists(item.UniqueId))
        //    btnPinToStart.Icon = new SymbolIcon(Symbol.UnPin);
    }


    #region NavigationHelper registration

    /// The methods provided in this section are simply used to allow
    /// NavigationHelper to respond to the page's navigation methods.
    /// 
    /// Page specific logic should be placed in event handlers for the  
    /// <see cref="GridCS.Common.NavigationHelper.LoadState"/>
    /// and <see cref="GridCS.Common.NavigationHelper.SaveState"/>.
    /// The navigation parameter is available in the LoadState method 
    /// in addition to page state preserved during an earlier session.

    protected override void OnNavigatedTo(NavigationEventArgs e)
    {
        navigationHelper.OnNavigatedTo(e);
    }

    protected override void OnNavigatedFrom(NavigationEventArgs e)
    {
        navigationHelper.OnNavigatedFrom(e);
    }

    #endregion


}

在我从我正在使用的应用程序示例中删除支点之前,我只想补充一下,ScrollViewer运行得很好。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-02 18:58:37

我想通了。

我的DetailsPage顶部的页面转换(从数据透视中遗留下来)导致了意想不到的行为。

如果需要的话请随时删除这个帖子..。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28817263

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档