是否有WPF相当于UWP的SplitView汉堡菜单?

时间:2015-10-13 13:30:41

标签: .net wpf uwp

通用Windows平台中的Hamburger-style SplitView control非常完美,IMO。但是,我的项目有一个WPF前端。

有没有人知道WPF与此相当(最好是开源)?

3 个答案:

答案 0 :(得分:10)

要研究的另一个实现是https://github.com/alicanerdogan/HamburgerMenu

enter image description here

答案 1 :(得分:7)

现在MahappsMetro中有一个非常好的

hamburger image

答案 2 :(得分:3)

使用 GridSplitter 控件和 StoryBoard ,您可以非常轻松地进行设置。您可能需要稍微调整一下这段代码,使其看起来像汉堡包,但这样可以帮助您顺利完成。

<UserControl
x:Class="Namespace.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
x:Name="mainPage">

<Grid>
    <Grid.Resources>
        <Storyboard x:Name="CloseLeft">
            <DoubleAnimation x:Name="animNavLinksClose"
                             Storyboard.TargetName="mainPage" Storyboard.TargetProperty="NavLinksWidth"
                             To="0.0" Duration="00:00:00.2" />
        </Storyboard>
        <Storyboard x:Name="OpenLeft">
            <DoubleAnimation x:Name="animNavLinksOpen"
                             Storyboard.TargetName="mainPage" Storyboard.TargetProperty="NavLinksWidth"
                             From="0" To="170" Duration="00:00:00.2" />
        </Storyboard>
    </Grid.Resources>

    <Grid.ColumnDefinitions>
        <ColumnDefinition Width="170" x:Name="NavLinksColumn" />
        <ColumnDefinition Width="Auto" />
        <ColumnDefinition Width="*" />
    </Grid.ColumnDefinitions>

    <Grid x:Name="grdNavLinks" Grid.Column="0">
        <!-- Navigation Buttons -->
    </Grid>

    <GridSplitter x:Name="spltNavLinks" Grid.Column="1" />

    <Grid x:Name="contentSection" Grid.Column="2">
        <!-- Content or Frame -->
    </Grid>
</Grid>
</UserControl>

然后你就可以从代码隐藏中调用你的故事板,就像这样

// Begin Opening Animation
OpenLeft.Begin();

// Begin Closing Animation
CloseLeft.Begin();