WPFでメニューバーを作成しますか?


119

WPFアプリケーションのWindowsフォームと同じメニューバーを作成したいのですが。

どうすればいいですか?

WPFコントロールツールボックスのメニューオプションでは、空白のバーしか表示されません。

回答:


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

10
なぜ下線があるのですか?なぜ隠されているのですか?
C4d 2016年

26
@ C4u:ショートカットキーを設定します(たとえば、「ファイル」のAlt + f)
BlueRaja-Danny Pflughoeft

WPFメニュー、ショートカットキーを追加するコマンドバインディングなどに関する包括的なチュートリアルをyoutu.be/bdmVWGjpA_8で作成しました
Zaheer

45

はい、メニューにはバーが表示されますが、バーに配置するアイテムは表示されません。あなたは(私の独自のプロジェクトの1つから)のようなものが必要です:

<!-- 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" />
AlanFoster 2013

3
@AlanFoster ヒントを含めて、独自の回答投稿してください。私はそれをほとんど逃した、そしてそれは残念だ!承認された回答からセットアップを再利用できます。一番簡単だと思います。そして、最適にフォーマットされています。
Konrad Viltersten、2015年

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>
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.