티스토리 뷰
반응형
UWP에는 MenuFlyout이 있어서 버튼이나 특정 컨트롤에 넣어 놓으면 클릭했을 때 ContextMenu 처럼 자동으로 표시가 됩니다. 아래 이미지와 같이 표시가 됩니다.
WPF에서 위와 비슷한 메뉴를 구성해 보았습니다.
<Window x:Class="CoreWpfContextMenu.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:CoreWpfContextMenu"
mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800">
<Grid>
<Button Content="Open ContextMenu" Width="100" Height="30">
<Button.ContextMenu>
<ContextMenu>
<MenuItem Header="Menu1"/>
<MenuItem Header="Menu2"/>
<Separator/>
<MenuItem Header="Menu3"/>
</ContextMenu>
</Button.ContextMenu>
</Button>
</Grid>
</Window>
그런데, 이 컨텍스트 메뉴는 마우스 오른쪽 클릭을 했을 때만 나오기 때문에, 왼쪽 클릭시에도 열리도록 만들기 위해 Behavior를 추가했습니다.
추가한 Nuget package는 Microsoft.Xaml.Behaviors.Wpf 입니다.
XAML에 namespace를 추가하고 EventTrigger와 ChangePropertyAction을 이용해서 컨택스트 메뉴가 열리도록 수정했습니다.
<Window x:Class="CoreWpfContextMenu.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:CoreWpfContextMenu"
xmlns:b="http://schemas.microsoft.com/xaml/behaviors"
mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800">
<Grid>
<Button Content="Open ContextMenu" Width="100" Height="30">
<b:Interaction.Triggers>
<b:EventTrigger EventName="Click">
<b:ChangePropertyAction TargetName="contextMenu"
PropertyName="IsOpen"
Value="True"/>
</b:EventTrigger>
</b:Interaction.Triggers>
<Button.ContextMenu>
<ContextMenu x:Name="contextMenu">
<MenuItem Header="Menu1"/>
<MenuItem Header="Menu2"/>
<Separator/>
<MenuItem Header="Menu3"/>
</ContextMenu>
</Button.ContextMenu>
</Button>
</Grid>
</Window>
Telerik RadContextMenu를 이용하면 버튼 바로위에 이쁘게 메뉴를 출력할 수 있는데.. ContextMenu 컨트롤은 Placement와 PlacementTarget이 제대로 동작을 하지 않는 것 같습니다.
소스
WpfTest/CoreWpfContextMenu at master · kaki104/WpfTest (github.com)
반응형
'WPF .NET' 카테고리의 다른 글
ComboBox 목록에서 선택된 아이템을 뷰모델에서 사용하기 (0) | 2021.05.22 |
---|---|
Localization in WPF (5) | 2021.03.22 |
Visual Studio를 이용한 Memory Leak 확인 방법 (3) | 2021.03.08 |
.NET Core WPF 프로젝트에서 System.Windows.Forms 사용 (0) | 2021.03.07 |
Telerik - DockingRegionAdapter (0) | 2021.02.24 |
댓글
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- kiosk
- windows 11
- WPF
- visual studio 2019
- IOT
- #Windows Template Studio
- #MVVM
- ef core
- uno-platform
- PRISM
- Microsoft
- UWP
- Visual Studio 2022
- LINQ
- Always Encrypted
- Windows 10
- MVVM
- XAML
- .net 5.0
- C#
- Bot Framework
- .net
- #uwp
- ComboBox
- uno platform
- Cross-platform
- Build 2016
- #prism
- Behavior
- dotNETconf
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함