Створити рядок меню у WPF?


120

Я хочу створити рядок меню, ідентичний тому, що у формах Windows у моїй програмі WPF.

Як би я це зробив?

Параметр меню на панелі інструментів керування WPF дає лише порожню панель.

Відповіді:


228
<DockPanel>
    <Menu DockPanel.Dock="Top">
        <MenuItem Header="_File">
            <MenuItem Header="_Open"/>
            <MenuItem Header="_Close"/>
            <MenuItem Header="_Save"/>
        </MenuItem>
    </Menu>
    <StackPanel></StackPanel>
</DockPanel>

11
Чому є підкреслення? Чому вони приховані?
C4d

27
@ C4u: Ті встановлюють клавіші швидкого доступу (напр., Alt + f для "файла")
BlueRaja - Danny Pflughoeft

Я підготував вичерпний підручник з меню WPF, прив'язки команд, додавання клавіш швидкого доступу тощо на youtu.be/bdmVWGjpA_8
Zaheer

45

Так, меню дає вам панель, але вона не дає жодних пунктів, які потрібно помістити в панель. Вам потрібно щось на кшталт (з одного з моїх власних проектів):

<!-- Menu. -->
<Menu Width="Auto" Height="20" Background="#FFA9D1F4" DockPanel.Dock="Top">
    <MenuItem Header="_Emulator">
    <MenuItem Header="Load..." Click="MenuItem_Click" />
    <MenuItem Header="Load again" Click="menuEmulLoadLast" />
    <Separator />
    <MenuItem Click="MenuItem_Click">
        <MenuItem.Header>
            <DockPanel>
                <TextBlock>Step</TextBlock>
                <TextBlock Width="10"></TextBlock>
                <TextBlock HorizontalAlignment="Right">F2</TextBlock>
            </DockPanel>
        </MenuItem.Header>
    </MenuItem>
    :

39
Привіт, замість цього вкладеного DockPanel, ви можете використовувати атрибут InputGestureText. Наприклад<MenuItem Header="Step" Click="MenuItem_Click" InputGestureText="F2" />
АланФостер

3
@AlanFoster Ви повинні опублікувати власну відповідь, включаючи цю підказку. Я майже пропустив це, і це прикро! Ви можете використовувати повторно налаштування з прийнятої відповіді. Я б сказав, це найпростіший. І найкраще відформатований.
Конрад Вільтерстен

9
<StackPanel VerticalAlignment="Top">
    <Menu Width="Auto" Height="20">
        <MenuItem Header="_File">
            <MenuItem x:Name="AppExit" Header="E_xit" HorizontalAlignment="Left" Width="140" Click="AppExit_Click"/>
        </MenuItem>
        <MenuItem Header="_Tools">
            <MenuItem x:Name="Options" Header="_Options" HorizontalAlignment="Left" Width="140"/>
        </MenuItem>
        <MenuItem Header="_Help">
            <MenuItem x:Name="About" Header="&amp;About" HorizontalAlignment="Left" Width="140"/>
        </MenuItem>
    </Menu>
    <Label Content="Label"/>
</StackPanel>

2
<Container>
    <Menu>
        <MenuItem Header="File">
            <MenuItem Header="New">
               <MenuItem Header="File1"/>
               <MenuItem Header="File2"/>
               <MenuItem Header="File3"/>
            </MenuItem>
            <MenuItem Header="Open"/>
            <MenuItem Header="Save"/>
        </MenuItem>
    </Menu>
</Container>
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.