wpf中团队独立开发模块和左侧2个菜单的框架演示

news2024/11/19 1:41:07

         此篇文章和上一篇文章wpf中开发独立模块功能和左侧1个菜单的框架演示-CSDN博客的结构是一样的,有1点不同的是,左侧有2层菜单,所以,就会更加的复杂。建议,先看明白上一篇的内容,再看这篇文章,否则可能有点难度。

        其余的功能开发模式和团队分工管理都和上一篇文章是一样的,在此就不再叙述了。 现在就解释一下下面的图的意思。

其中“功能123”菜单栏包含了“功能1”,“功能2”,“功能3”,而“功能1”就是WpfControlLibrary1项目,“功能2”就是WpfControlLibrary2项目,“功能3”就是WpfControlLibrary3项目。

依次类推,“功能456”菜单栏包含了“功能4”,“功能5”,“功能6”,“功能4”就是UserControl4界面,“功能5”就是UserControl5界面,“功能6”就是UserControl6界面,这里我们使用了UC界面,而不是项目了,当然也可以使用项目的,只是为了区分一下。此时就相当于 UserControl4到UserControl9界面是框架里面的内容了,由HCDemo这个项目的人,全部负责,与WpfControlLibrary1项目是有区别的,需要注意一下。

 

同“功能456”所示,“功能789”菜单栏包含了“功能7”,“功能8”,“功能9”,“功能7”就是UserControl7界面,“功能8”就是UserControl8界面,“功能9”就是UserControl9界面。

对于2层菜单的设计说明:

首先把界面分成3部分,左1是“蓝色部分”,中间是具体的菜单栏,右侧是菜单栏呈现的最终效果。

代码如下:

   <ListBox Name="lstMenu" Grid.Column="0" BorderThickness="0" Style="{ x:Null}" Background="#409EFF" ItemContainerStyle="{StaticResource CustomLstMenuItemContainerStyle}"  SelectionChanged="lstMenu_SelectionChanged"  >
       <ListBoxItem Tag="功能123" Cursor="Hand"  >
           <StackPanel Width="auto" VerticalAlignment="Center" HorizontalAlignment="Center" Margin="0,0,0,15"     >
               <Image Source="/imgs/1.png" Width="40" Height="40" />
               <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center" Margin="0,5,0,0">
                   <TextBlock Text="功能123" Style="{StaticResource CustomTextBlockStyle}"/>
               </StackPanel>
           </StackPanel>
       </ListBoxItem>
       <ListBoxItem Tag="功能456"  Cursor="Hand" >
           <StackPanel Width="auto" VerticalAlignment="Center" HorizontalAlignment="Center" Margin="0,0,0,15"      >
               <Image Source="/imgs/2.png" Width="40" Height="40" />
               <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center" Margin="0,5,0,0">
                   <TextBlock Text="功能456" Style="{StaticResource CustomTextBlockStyle}"/>
               </StackPanel>
           </StackPanel>
       </ListBoxItem>
       <ListBoxItem  Tag="功能789"  Cursor="Hand"  >
           <StackPanel Width="auto" VerticalAlignment="Center" HorizontalAlignment="Center" Margin="0,0,0,15"      >
               <Image Source="/imgs/3.png" Width="40" Height="40" />
               <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center" Margin="0,5,0,0">
                   <TextBlock Text="功能789" Style="{StaticResource CustomTextBlockStyle}"/>
               </StackPanel>
           </StackPanel>
       </ListBoxItem>
   </ListBox>
   <ListBox x:Name="lstDetails" Grid.Column="1" BorderThickness="0" Style="{ x:Null}" Background="#F5F5F5" ItemContainerStyle="{StaticResource CustomItemContainerStyle}" SelectionChanged="lstDetails_SelectionChanged"  />
   <hc:TabControl Name="tabMenu" Grid.Column="2" IsAnimationEnabled="True" IsDraggable="True" ShowCloseButton="True"  OverflowMenuDisplayMemberPath="Header"/>

lstMenu控件只是一个功能1,功能2,功能3的总标识, lstDetails控件是具体的功能1,所以这里是动态增加的,而tabMenu是TabControl,菜单栏不停地向里面增加界面,所以也是动态增加的。这里最核心的就是,菜单是动态的,所以,不管增加多少个都是可以的,在对应的功能里面写代码即可。

对于此软件的目录结构来说,与上一篇是一样的。

Libs文件夹同级别的,是整个软件框架的资源

Libs里面的dll,都是各个业务的功能模块 

对于整个软件的目录设计来说,清晰明了,后期我们可以对于相应的dll进行独立升级或者替换,而不需要每次都复制一大堆文件给用户了,定量定点的去解决问题,提高效率。 

最终效果:

当需要左侧有1个菜单栏的时候,请参考: 

wpf中开发独立模块功能和左侧1个菜单的框架演示-CSDN博客

本文运行的程序(带环境): 

https://download.csdn.net/download/u012563853/89591412

本文源码:

https://download.csdn.net/download/u012563853/89591744

本文来源:

wpf中团队独立开发模块和左侧2个菜单的框架演示-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1955366.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CSS实现表格无限轮播

<div className{styles.tableTh}><div className{styles.thItem} style{{ width: 40% }}>报警名称</div><div className{styles.thItem} style{{ width: 35% }}>开始时间</div><div className{styles.thItem} style{{ width: 25% }}>状态&…

前端三大主流框架对比

在现代前端开发中&#xff0c;React、Vue和Angular是三大流行的框架/库。它们各自有独特的优缺点&#xff0c;适用于不同的开发需求和项目规模。下面是对这三者的详细比较&#xff1a; 一、 React 简介&#xff1a; 由Facebook开发和维护&#xff0c;是一个用于构建用户界面…

亚博科技和幻尔科技的十轴IMU在Ros2 Humble下驱动后数值无限趋于0的解决方案

在做机器人导航以及建模的时候&#xff0c;考虑到多传感器融合可能会带来更好的效果&#xff0c;于是决定使用幻尔科技的十轴IMU&#xff08;其实亚博科技与幻尔科技这块IMU的内部完全一致&#xff0c;驱动代码都完全一致&#xff09;驱动后使用以下命令输出传来的四元数等数据…

自写ApiTools工具,功能参考Postman和ApiPost

近日在使用ApiPost的时候&#xff0c;发现新版本8和7不兼容&#xff0c;也就是说8不支持离线操作&#xff0c;而7可以。 我想说&#xff0c;我就是因为不想登录使用才从Postman换到ApiPost的。 众所周知&#xff0c;postman时国外软件&#xff0c;登录经常性抽风&#xff0c;…

Mike SHE里如何正确设置分区降雨

前言&#xff1a; MIKE SHE分布式水文模型现阶段用于流域洪水的项目比较多&#xff0c;因属于大尺度模型&#xff0c;基本可以模拟水循环全过程&#xff0c;包含降雨—蒸发——产汇流—地表水—地下水等。同时还可以耦合MIKE11水动力水质模型。 今天给大家介绍下MIKESHE是如何…

从零到一使用 Ollama、Dify 和 Docker 构建 Llama 3.1 模型服务

本篇文章聊聊&#xff0c;如何使用 Ollama、Dify 和 Docker 来完成本地 Llama 3.1 模型服务的搭建。 如果你需要将 Ollama 官方不支持的模型运行起来&#xff0c;或者将新版本 llama.cpp 转换的模型运行起来&#xff0c;并且想更轻松的使用 Dify 构建 AI 应用&#xff0c;那么…

进程间的通信(IPC)--管道

1.进程间通信常用的方式 1 &#xff0c;管道通信&#xff1a;有名管道&#xff0c;无名管道 2 &#xff0c;信号 - 系统开销小 3 &#xff0c;消息队列 - 内核的链表 4 &#xff0c;信号量 - 计数器 5 &#xff0c;共享内存 6 &#xff0c;内存映射 7 &#xff0c;套接…

人称“灯爷”的灯光师到底要做些什么,看看他的岗位说明书

灯光师又称“灯爷”,是摄影制作部门负责灯光设备的技术人员,一般归摄影指导调配。被尊称“爷”,可见灯光师的地位不容小觑。那么这个岗位到底要做些什么呢&#xff1f; 岗位职责&#xff1a; 1、负责公司灯光设备的调制、维护和保养&#xff1b; 2、负责各包房灯光设备的调制、…

Mac环境报错 error: symbol(s) not found for architecture x86_64

Mac 环境Qt Creator报错 error: symbol(s) not found for architecture x86_64 错误信息 "symbol(s) not found for architecture x86_64" 通常是在编译或链接过程中出现的问题。这种错误提示通常涉及到符号未找到或者是因为编译器没有找到适当的库文件或函数定义。 …

基于springboot+vue+uniapp的养老院系统小程序

开发语言&#xff1a;Java框架&#xff1a;springbootuniappJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#…

初识git工具~~上传代码到gitee仓库的方法

目录 1.背景~~其安装 2.gitee介绍 2.1新建仓库 2.2进行相关配置 3.拉取仓库 4.服务器操作 4.1克隆操作 4.2查看本地仓库 4.3代码拖到本地仓库 4.4关于git三板斧介绍 4.4.1add操作 4.4.2commit操作 4.4.3push操作 5.一些其他说明 5.1.ignore说明 5.2git log命令 …

ACC:Automatic ECN Tuning for High-Speed Datacenter Networks 相关知识点介绍(二)

目录 PerfTest工具 Incast traffic Incast Traffic 的原因 Incast Traffic 的影响 解决方法 流量负载 简单解释 影响因素 影响 管理方法 LINKPACK 主要特点 LinkPack 的应用 运行结果 Quantum ESPRESSO 主要特点 TensorFlow 主要特点 主要组件 Incast与qp …

Ubuntu2023.04 浏览器不能上网的问题

1.问题描述 ping www.baidu.com 是可以连接的&#xff0c;但是打开网页就是不能上网&#xff0c;但是自己查看了浏览器上面的设置&#xff0c;代理设置都是关闭的 再看了系统的设置代理也是关闭的&#xff0c;就是上不了网 解决方案&#xff1a; 455 echo $http_proxy456 e…

JavaWeb项目中动态拼接sql语句

业务需求描述&#xff1a; 图中的查询框在分条件查询用户信息列表时&#xff0c;前端可能会传回一个条件或多个条件&#xff0c;此时要对不同的条件进行sql语句的不同书写&#xff0c;前端传的情况有很多种&#xff0c;所以如果分情况写sql语句会比较死&#xff0c;并且不够灵活…

机器学习之人脸识别-使用 scikit-learn 和人工神经网络进行高效人脸识别

文章摘要 本文将介绍如何使用 Python 的 scikit-learn 库和人工神经网络&#xff08;ANN&#xff09;来识别人脸。我们将使用 LFW 数据集&#xff08;Labeled Faces in the Wild&#xff09;&#xff0c;这是一个广泛用于人脸识别基准测试的大型人脸数据库。我们将展示如何准备…

RedHat Enterprise Linux 7 YUM源(本地/网络源)配置详解

目录 一、挂载 二、建立本地源 三、建立网络源 四、验证可行性 一、挂载 ——将光盘挂载到 /mnt 下 当/mnt中有如图内容时&#xff0c;即挂载成功 若挂载光驱/dev/sr0时报错&#xff1a;mount: no medium found on /dev/sr0 解决措施&#xff1a;查看该设备状态是否全部勾选…

数仓实践:一文读懂数仓 ODS 层模型设计

引言 OneData 体系中,数据划分为三层: ODS(Operational Data Store):操作数据层。它相当于数据中台通用数据模型层的一个数据准备区,同时又承担着基础数据的记录以及历史变化,主要完成业务系统、日志等结构化和半结构化数据引入到数据中台。保留业务系统原始数据,包括…

【HZHY-AI300G智能盒试用连载体验】设置RKNN的开发环境

目录 安装RKNN工具 安装pip3 安装RKNN Toolkit Lite2 安装RKNPU2运行库 本文首发于电子发烧友论坛&#xff1a;【新提醒】【HZHY-AI300G智能盒试用连载体验】 智能工业互联网网关 - 北京合众恒跃科技有限公司 - 电子技术论坛 - 广受欢迎的专业电子论坛! (elecfans.com) 前…

WordPress文章标题定制化前缀插件

引言 在当今互联网的海洋中&#xff0c;吸引读者眼球的第一步往往始于文章标题的设计。对于WordPress博主而言&#xff0c;如何让每篇文章的标题更加个性化和吸引人&#xff0c;成为了一项重要的任务。传统的自定义CSS方法虽然可行&#xff0c;但其繁琐的操作和有限的美学效果…