微信公众号:Dotnet9,网站:Dotnet9,问题或建议:请网站留言, 如果对您有所帮助:欢迎赞赏。

快到2020年了,祝大家新年快乐,今年2019最后一更,谢谢大家支持!

阅读导航

  1. 本文背景
  2. 代码实现
  3. 本文参考
  4. 源码

1. 本文背景

一个系统主界面,放上一个菜单,点击菜单在客户区切换不同的展示界面,这是很常规的设计,见下面展示效果图:

左侧一个菜单,点击菜单,右侧切换界面,界面切换动画使用MD控件的组件实现(自己使用动画也能实现)。

2. 代码实现

使用 .NET CORE 3.1 创建名为 “MenuChange” 的WPF模板项目,添加1个Nuget库:MaterialDesignThemes,版本为最新预览版3.1.0-ci948。

解决方案主要文件目录组织结构:

  • AnimatedMenuApp.xamlMainWindow.xamlMainWindow.xaml.cs..[数个演示模块用户控件]

2.1 引入样式

文件【App.xaml】,在 StartupUri 中设置启动的视图【MainWindow.xaml】,并在【Application.Resources】节点增加 MaterialDesignThemes库的样式文件:

    

2.2 演示窗体

文件【MainWindow.xaml】,布局代码、动画代码都在此文件中,源码如下:

                                                                                                                                                                                                                                                                

简单说明下:

  1. "GridPrincipal" 作为客户区子模块界面容器,展示新界面时,先移除旧用户控件,再添加新用户控件(站长以前使用时,是遍历容器中所有用户界面,对非选择用户控件作隐藏操作,然后添加新用户控件或者对已存在的被选择用户控件作显示操作)。
  2. 左侧菜单项使用 "ListView" 进行布局,实际开发需要运用模板,使用MVVM做成动态菜单,方便扩展。
  3. 右侧切换的子模块界面应该使用Prism或者其他框架(自已实现的模块dll)实现的子界面,方便动态扩展(需要和左侧菜单项进行关联)。

文件【MainWindow.xaml.cs】,后台关闭窗体、菜单点击切换子模块界面、窗体移动等事件处理:

using System.Windows;using System.Windows.Controls;using System.Windows.Input;namespace MenuChange{    ///     /// Interaction logic for MainWindow.xaml    ///     public partial class MainWindow : Window    {        public MainWindow()        {            InitializeComponent();        }        private void ButtonFechar_Click(object sender, RoutedEventArgs e)        {            Application.Current.Shutdown();        }        private void Grid_MouseDown(object sender, MouseButtonEventArgs e)        {            DragMove();        }        private void ListViewMenu_SelectionChanged(object sender, SelectionChangedEventArgs e)        {            int index = ListViewMenu.SelectedIndex;            MoveCursorMenu(index);            switch (index)            {                case 0:                    GridPrincipal.Children.Clear();                    GridPrincipal.Children.Add(new UserControlMain());                    break;                case 1:                    GridPrincipal.Children.Clear();                    GridPrincipal.Children.Add(new UserControlWPF());                    break;                case 2:                    GridPrincipal.Children.Clear();                    GridPrincipal.Children.Add(new UserControlWinform());                    break;                case 3:                    GridPrincipal.Children.Clear();                    GridPrincipal.Children.Add(new UserControlASPNETCORE());                    break;                case 4:                    GridPrincipal.Children.Clear();                    GridPrincipal.Children.Add(new UserControlXamarinForms());                    break;                case 5:                    GridPrincipal.Children.Clear();                    GridPrincipal.Children.Add(new UserControlCPP());                    break;                default:                    break;            }        }        private void MoveCursorMenu(int index)        {            TrainsitionigContentSlide.OnApplyTemplate();            GridCursor.Margin = new Thickness(0, (100 + (60 * index)), 0, 0);        }    }}

方便演示,点击菜单,切换子用户控件时时写死的,见上面的说明,左侧菜单及右侧切换的子用户控件需要进行关联配置,方便扩展,建议使用Prism的模块化开发。

2.3 演示主模块

文件【UserControlMain.xaml】,只展示其中一个子模块用户控件吧,其他类似,文末有源码、可运行Demo供下载参考。

注意: 需要使用MD控件的 TransitioningContent 组件将用户控件可视区域包裹起来,用于使用MD的移动切换动画,其中 OpeningEffect 见名思意,即是展示此用户控件时,动画如何播放,见下面代码,SlideInFromLeft 是指示展示时由左向右缓动,相反 SlideInFromRight即是由右向左缓动,其他属性可查阅MD官网或者Demo研究。

已奉上关键代码,全部代码文末有下载链接...

3.本文参考

  1. 视频一:C# WPF Material Design UI: Fast Food Sales,配套源码:Pizzaria1。
  2. C# WPF开源控件库《MaterialDesignInXAML》

4.源码

站长方便演示,文中的图片使用的本站外链图片:

演示Demo下载


除非注明,文章均由 Dotnet9 整理发布,欢迎转载。

转载请注明本文地址:https://dotnet9.com/7743.html


时间如流水,只能流去不流回!

delphi 登录界面 主窗体 切换_.NET CORE(C#) WPF 方便的实现用户控件切换(祝大家新年快乐)相关推荐

  1. delphi 登录界面 主窗体 切换_Python GUI项目实战(二)主窗体的界面设计与实现

    前言 上一节我们介绍了Python GUI项目实战(一)登录窗体的设计与实现,实现了该项目登录窗体的GUI的搭建,用户的账号和密码校验完成后应当跳转到主窗体界面,这一节我们将具体介绍主窗体界面的设计与 ...

  2. delphi 登录界面 主窗体 切换_winform项目——仿QQ即时通讯程序06:主界面交互逻辑...

    上一篇文章,我们搭建好了主界面的布局.本文将实现页面的交互逻辑,比如如何移动窗体.调整窗体大小.点击消息和联系人切换下方的panel面板.动态加载消息列表panel和好友列表panel等,并且左下角的 ...

  3. WPF框架嵌套用户控件,显示与切换(详细,代码复制可用)

    WPF框架手敲实现嵌套页面,点击显示与切换 下面附上成果图吧,看了之后觉得适用就可以参考一下,否则就不要浪费时间了 操作时间 1.此篇作为学习记录,是一个WPF框架window嵌套用户控件的使用.点击 ...

  4. 写一个登录界面——用窗体界面实现

    写一个登录界面--用窗体界面实现 我们在上网的时候总能看到各种各样的窗体界面,比如:网页角落突然弹出的小广告.登录界面.画图板--接下来我就来讲讲如何创建一个窗体界面并制作一个登录界面. 窗体类的英文 ...

  5. asp.net控件页面交互_ASP.NET Web窗体用户控件的基本交互

    asp.net控件页面交互 I saw a recent question regarding .NET - Render User Control Logo on Postback and deci ...

  6. 无边框窗体和用户控件以及权限

    无边框窗体: 就是吧窗体的边框去掉,然后自己做按钮设置功能. 无边框窗体的移动: 将下面代码直接复制粘贴,将窗体的鼠标按下事件的方法改成下面方法的名字就可以直接使用 1 //窗体移动API 2 [Dl ...

  7. 在用户控件中用户登录后台脚本判断

    在用户控件中用户登录后台脚本判断写法  if (!IsPostBack)         {                         imagelogin.Attributes.Add(&qu ...

  8. 使用观察者模式在 Silverlight 中切换用户控件

    有一篇技巧,见 http://tech.sina.com.cn/s/2008-07-03/1528718607.shtml 或 http://kb.cnblogs.com/page/42897/?pa ...

  9. WPF获取当前用户控件的父级窗体

    方式一.通过当前控件名获取父级窗体Window targetWindow = Window.GetWindow(button);方式二.通过当前控件获取父级窗体Window parentWindow ...

最新文章

  1. QT的QScriptEngine类的使用
  2. manjaro双系统 windows_Win10和Manjaro双系统安装记录
  3. 听说做开发的工资随随便便就上10k?
  4. 利用ros3djs接收pointcloud2在web端显示
  5. python为运行为何出现乱码_我的python写入文件正常,打开后却是乱码格式为什么?...
  6. set up BU Printer on ubuntu
  7. 摊牌了!2021年3D视觉算法岗求职群
  8. TFS2010物理迁移workspace恢复
  9. html 做成ppt样式,HTML开发网页样式.ppt
  10. dnf修改服务器时间限制,DNF历史性革新,团本刷新时间改为周六,为黑鸦让路
  11. springboot如何接收Vue 的post提交请求
  12. [唐诗]杳杳寒山道-寒山
  13. Notepad++下载安装介绍教程
  14. java通过qq邮箱发送_java实现发送QQ邮箱
  15. 外键 ‘FK__ICBCCard__CardID__3E1D39E1‘ 引用了位于被引用表 ‘StudentCard‘ 中的无效列 ‘CardID‘。
  16. [渝粤教育] 西南科技大学 国际经济法 在线考试复习资料
  17. FTP-----局域网内部远程桌面
  18. 树莓派 Raspberry Pi 安装视频播放软件-omxplayer 并配置全屏播放
  19. php tp5微信支付,tp5微信支付踩坑
  20. unable to find java_SQL Developer报错:Unable to find a Java Virtual Machine解决办法

热门文章

  1. php提前终止,由于最大执行时间致命错误,PHP cron作业提前终止
  2. android中seekbar 常用属性列表,随笔–android中修改SeekBar控件默认显示-Fun言
  3. 输入法快捷键_[秒杀必备]搜狗输入法自定义短语快捷键设置
  4. e-006 matlab,基于MATLAB进行潮流计算
  5. axis1 c# 接口 调用_java调用c#的Webservice接口数据报错
  6. python单行注释的标记符_【转】Pyhton 单行、多行注释符号使用方法及规范
  7. java开启一个线程_【jdk源码分析】java多线程开启的三种方式
  8. 数据结构c语言版第二版第三章课后答案,数据结构(C语言版)习题集答案第三章.doc...
  9. 不能连接到 mysql_怎么无法连接到数据库?
  10. mysql远程连接 host_MySQL远程连接:Host 'x' is not allowed to connect to this MySQL server