WPF —— ContextMenu右键菜单 Canvas控件详解

ContextMenu右键菜单的实例

​​​​​​​WPF中的右键菜单主要是通过ContextMenu来实现,

在控件中使用ContextMenu

直接在控件的ContextMenu属性中关联即可。

XML 复制代码
<Label Content="右键弹出内容菜单" FontSize="20" Width="200" Height="40">
    <Label.ContextMenu>
        <ContextMenu Name="c1" ItemsSource="{Binding}">
            <ContextMenu.ItemTemplate>
                <HierarchicalDataTemplate ItemsSource="{Binding Path=SubMenus}">
                    <TextBlock Text="{Binding}"></TextBlock>
                </HierarchicalDataTemplate>
            </ContextMenu.ItemTemplate>
        </ContextMenu>
    </Label.ContextMenu>
</Label>

创建一个模型类

XML 复制代码
    private void Window_Loaded_1(object sender, RoutedEventArgs e)
    {
        this.c1.DataContext = CreateMenu();
    }
    // 以后有可能在menu菜单和右键菜单等相似的控件中来进行使用,所以最好封装
    public List<Menu1> CreateMenu()
    {
        List<Menu1> list = new List<Menu1>();

        // 一级菜单
        Menu1 duandian = new Menu1("断点", null);

        // 二级菜单对象
        Menu1 duandian2_1 = new Menu1("插入断点", duandian);
        Menu1 duandian2_2 = new Menu1("插入跟踪点", duandian);
        Menu1 duandian2_3 = new Menu1("插入临时断点", duandian);

        // 一级菜单
        Menu1 pianduan = new Menu1("片段", null);

        // 二级菜单
        Menu1 pianduan2_1 = new Menu1("外侧代码", pianduan);
        list.Add(duandian);
        list.Add(pianduan);


        return list;
    }
}



public class Menu1
{
    // 树形结构的模型定义的方法
    public List<Menu1> SubMenu { get; set; } // 存储下层数据的list对象
    public string Name { get; set; } // 存储标题

    // new Menu1 (军事,null)
    // new Menu1 (军事1,父级菜单对象) 当前对象添加到父级对象中
    public Menu1(string name,Menu1 m1)
    {
        Name = name;
        if(m1 != null)
        {
            List<Menu1> m2 = m1.SubMenu ?? new List<Menu1>();
            m2.Add(this);
            m1.SubMenu = m2;
        }
    }
}

Canvas控件

定义一个区域,可以是其中的子元素相对于canvas进行定位-->

<!--Canvas.Right="0" 距离canvas右边的距离是0 上下左同理

定位元素 不要设置两个相对的距离,例如设置了Canvas。Right,就不要设置Canvas.Left

XML 复制代码
    <Canvas Width="500" Height="300">
        <StackPanel Width="100" Height="100" Background="Red"></StackPanel>
        <StackPanel Width="100" Height="100" Background="Black"
                    Canvas.Right="0"
                    Canvas.Top="0"></StackPanel>
        <StackPanel Width="100" Height="100" Background="Gray" Canvas.Left="0" Canvas.Bottom="0">
            
        </StackPanel>
        <StackPanel Width="100" Height="100" Background="Pink" Canvas.Right="0" Canvas.Bottom="0">

        </StackPanel>
        <WrapPanel Width="100" Height="100" Background="Yellow" Canvas.Left="200"
                   Canvas.Top="100">
            
        </WrapPanel>
    </Canvas>
    <!--<StackPanel Width="500" Height="300" Background="Red">
        <Button Width="100"
                Height="100"
                VerticalAlignment="Top"
                HorizontalAlignment="Left"
                Margin="400,0,0,0">
            按钮
        </Button>
    </StackPanel>-->
</Grid>

效果图如下

相关推荐
烟话63 天前
MVVM核心机制:属性通知与命令绑定解析
wpf
不知名君3 天前
WPF 的原生窗体标题栏主题自适应系统深浅主题
wpf
碎碎念的安静3 天前
WPF 与 Qt 进程间通信(IPC)
开发语言·qt·wpf
军训猫猫头4 天前
7.带输入参数的线程启动 C# + WPF 完整示例
开发语言·前端·c#·.net·wpf
周杰伦fans5 天前
WPF Prism 框架完全入门指南:从环境搭建到弹窗导航实战
wpf
雨浓YN5 天前
WPF MVVM 模式(无调库)项目创建笔记
笔记·wpf
周杰伦fans5 天前
.NET AOT技术深度解析:为什么WPF不支持而Avalonia/UWP支持?
.net·wpf
雨浓YN5 天前
WPF MVVM 模式(调Prism库)项目创建笔记 —— 包含C++/CLI OpenCV互操作
c++·笔记·wpf
七夜zippoe6 天前
DolphinDB数据模型:表、分区与分布式表
分布式·wpf·数据模型··dolphindb
一念春风6 天前
Qwen2.5 (AI模型 PC搭建)
人工智能·ai·c#·wpf·模型