zoukankan      html  css  js  c++  java
  • uwp汉堡菜单的实现

    ---恢复内容开始---

    现在uwp上面的汉堡菜单(就是那个三道杠,点击之后会出现菜单)使用的越来越普遍,比如微软自己家的Cortana。现在我使用的实现方法是使用SplitView实现。首先SplitView将整个App的界面分成两块,一块是弹出来的汉堡菜单,一块是收起汉堡菜单之后App的界面。弹出来的汉堡菜单叫做Pane,这个界面在<SplitView.Pane></SplitView.Pane>标签下面写,就和普通的页面布局一样,该用Grid就用Grid(对了,现在微软所谓的响应式布局是不是推荐使用Grid?)

    <SplitView.Pane>
                    <Grid>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="auto"/>
                            <RowDefinition Height="*"/>
                            <RowDefinition Height="auto"/>
                        </Grid.RowDefinitions>
                        <Grid Grid.Row="0">
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="auto"/>
                                <ColumnDefinition Width="*"/>
                            </Grid.ColumnDefinitions>
                            <Button x:Name="btnSplitViewClose" Grid.Column="0" Click="btnSplitViewClose_Click">
                                <Image Source="Assets/Menu.png" Height="30" Width="30"/>
                            </Button>
                            <TextBlock Text="目录" Grid.Column="1" x:Name="PaneHeader"
                                   Margin="30,12,0,0" Style="{StaticResource BaseTextBlockStyle}"/>
                        </Grid>
                        <ListView x:Name="NavLinksList" Margin="0,12,0,0" SelectionMode="None" Grid.Row="1" VerticalAlignment="Stretch" 
                        ItemClick="NavLinksList_ItemClick" IsItemClickEnabled="True" 
                        ItemsSource="{x:Bind NavLinks}" ItemTemplate="{StaticResource NavLinkItemTemplate}"/>
                    </Grid>
                </SplitView.Pane>

    效果是这样的:

    剩下的Span收起后的界面就是和平常写界面的一样啦,把汉堡菜单忘掉之后接着写自己的App界面就好。

    这个界面的所有XAML是这样的:

                                                                            <Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}" x:Name="rootGrid">
            <SplitView
                       DisplayMode="Overlay"
                       OpenPaneLength="220"
                       x:Name="splitView">
                <SplitView.Pane>
                    <Grid>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="auto"/>
                            <RowDefinition Height="*"/>
                            <RowDefinition Height="auto"/>
                        </Grid.RowDefinitions>
                        <Grid Grid.Row="0">
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="auto"/>
                                <ColumnDefinition Width="*"/>
                            </Grid.ColumnDefinitions>
                            <Button x:Name="btnSplitViewClose" Grid.Column="0" Click="btnSplitViewClose_Click">
                                <Image Source="Assets/Menu.png" Height="30" Width="30"/>
                            </Button>
                            <TextBlock Text="目录" Grid.Column="1" x:Name="PaneHeader"
                                   Margin="30,12,0,0" Style="{StaticResource BaseTextBlockStyle}"/>
                        </Grid>
                        <ListView x:Name="NavLinksList" Margin="0,12,0,0" SelectionMode="None" Grid.Row="1" VerticalAlignment="Stretch" 
                        ItemClick="NavLinksList_ItemClick" IsItemClickEnabled="True" 
                        ItemsSource="{x:Bind NavLinks}" ItemTemplate="{StaticResource NavLinkItemTemplate}"/>
                        <!--<StackPanel Orientation="Horizontal"
                                    Grid.Row="2" Margin="14,24,0,24">
                            <SymbolIcon Symbol="Setting"/>
                            <TextBlock Text="Settings" Margin="24,0,0,0"
                                       VerticalAlignment="Center" Tapped="TextBlock_Tapped"/>
                        </StackPanel>-->
                    </Grid>
                </SplitView.Pane>
    
                <Grid>
                    <Grid.RowDefinitions>
                        <RowDefinition Height="auto"/>
                        <RowDefinition Height="*"/>
                        <RowDefinition Height="auto"/>
                        <RowDefinition Height="auto"/>
                        <RowDefinition Height="auto"/>
                    </Grid.RowDefinitions>
                    <Grid Grid.Row="0">
                        <Grid.ColumnDefinitions>
                            <ColumnDefinition Width="auto"/>
                            <ColumnDefinition Width="*"/>
                            <ColumnDefinition Width="auto"/>
                        </Grid.ColumnDefinitions>
                      <!--你的主界面代码-->
             </SplitView> </Grid> </Grid>
    private ObservableCollection<NavLink> _navLinks = new ObservableCollection<NavLink>()
            {
                new NavLink() {Label="个性化",Symbol=Symbol.People },
                new NavLink() {Label="地图",Symbol=Symbol.Map },
                new NavLink() { Label = "联系我", Symbol = Windows.UI.Xaml.Controls.Symbol.Mail },
                new NavLink() { Label = "使用帮助", Symbol = Symbol.Help  },
                new NavLink() {Label="Settings",Symbol=Symbol.Setting }
            };
    
            public ObservableCollection<NavLink> NavLinks
            {
                get { return _navLinks; }
            }
    
    
            private void NavLinksList_ItemClick(object sender, ItemClickEventArgs e)
            {
                switch((e.ClickedItem as NavLink).Label)
                {
                    case "个性化":
                        this.Frame.Navigate(typeof(PersonalSettings));                                                                    
                        break;
                    case "地图":
                        this.Frame.Navigate(typeof(Map));
                        break;
                    case "联系我":
                        conTool.SendEmail("cncmn@sina.cn", "反馈", "紧急求助反馈", "");
                        break;
                    case "使用帮助":
                        this.Frame.Navigate(typeof(UserGuide));
                        break;
                    case "Settings":
                        this.Frame.Navigate(typeof(Settings));
                        break;
                    default:
                        break;
                }
            }

    附上后台响应包括ListView数据源的C#代码。

    有时候大家打开这个汉堡菜单喜欢主界面上右划打开,左划关闭。实现起来也十分简单。

    private void RootGrid_PointerPressed(object sender, PointerRoutedEventArgs e)
            {
                beforePoint = e.GetCurrentPoint(rootGrid);
            }
    
            private void RootGrid_PointerReleased(object sender, PointerRoutedEventArgs e)
            {
                afterPoint = e.GetCurrentPoint(rootGrid);
                if((beforePoint.PointerId==afterPoint.PointerId&&(afterPoint.Position.X-beforePoint.Position.X>10))||
                    (beforePoint.PointerId == afterPoint.PointerId && (afterPoint.Position.Y - beforePoint.Position.Y > 10)))
                {
                    splitView.IsPaneOpen = true;
                }else if(beforePoint.PointerId == afterPoint.PointerId &&
                    ((afterPoint.Position.X - beforePoint.Position.X < -10)|| (afterPoint.Position.Y - beforePoint.Position.Y < -10))
                    && splitView.IsPaneOpen)
                {
                    splitView.IsPaneOpen = false;
                }
            }

    其中,rootGrid是上面定义的一个Grid的Name,通过SplitView.IsPaneOpen的赋值是True或者False来控制汉堡菜单的开关,其中,beforePoint和afterPoint是PointerPoint的两个对象,用于存储手势开始和结束的两个点。我这里定义向下和向右都可以打开汉堡菜单。

  • 相关阅读:
    法瑞意游记+攻略 一(巴黎 凡尔赛、荣军院,十二月二十六)
    [转]Exchange Server 2013部署系列之一:部署环境介绍
    [转]在Windows server 2012上部署DPM 2012 SP1 RTM之安装配置
    DinnerNow案例分析
    [转]DPM2012系列之六:在Win7上安装DPM远程管理控制台
    Windows Phone Dev Center Develop
    [转]DPM2012系列之十:备份exchange2010数据库
    [转]DPM2012系列之五:开启最终用户恢复功能
    Windows Phone Dev Center How do I join?
    [转]DPM2012系列之三:浅谈硬件需求
  • 原文地址:https://www.cnblogs.com/mengnan/p/4998531.html
Copyright © 2011-2022 走看看