系列目录 【已更新最新开发文章,点击查看详细】
WPF(Windows Presentation Foundation)是微软推出的基于Windows 的用户界面框架,属于.NET Framework 3.0的一部分。它提供了统一的编程模型、语言和框架,真正做到了分离界面设计人员与开发人员的工作;同时它提供了全新的多媒体交互用户图形界面。
微软提供的WPF控件的功能很强大,但是样式不漂亮,需要专业的美工设计样式或皮肤。圈子里总有无私奉献的大牛们分享既漂亮又好用的WPF组件库,下面收集了几款非常优秀的WPF开源组件。
开源项目是众多组织与个人分享的组件或项目,作者付出的心血我们是无法体会的,所以首先大家要心存感激、尊重。请严格遵守每个项目的开源协议后再使用。尊重知识产权,共建和谐开源社区。
1、MaterialDesignInXAML
MaterialDesignInXAML完全开源,是WPF最流行的GUI库之一,该库还与MahApps和Dragablz兼容。通过XAML工具箱中的设计,可以使用现代流行的设计语言轻松地将漂亮的桌面应用程序带到生活中。
组件特征
- 支持大多数标准WPF控件的样式和变体
- 更多的附加控件,以支持材质设计的美观性和流动性
- 在设计和运行时轻松配置材质设计调色板
- 用于轻松构建GUI动画的转换API
- 独立工作,也与其他流行的WPF框架MahApps和Dragablz兼容
- 支持MVVM框架
示例效果
1、首页
布局简洁、清爽、效果直观
![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLicmbw5CMyEzN2ADOxITMtcDO3MTM3ADOwQTM3ATMyAjMtUzNyIDNx8CX3ATMyAjMvwVN3IjM0EzLcd2bsJ2Lc12bj5ycn9Gbi52YuAjMwIzZtl2Lc9CX6MHc0RHaiojIsJye.png)
2、支持主题风格切换
该控件库配有数十种颜色风格,满足大部分配色要求。也可以自定义皮肤。
3、按钮
多种形状的交互按钮,如圆形按钮、图标按钮、按钮进度、按钮文字提示等等,Web中常见的效果WPF中也可以简单地使用。
4、输入验证框
表单验证,常规做法是在ViewModel中写业务逻辑验证代码,或者在XAML中写验证表达式。该控件库实现了较多的验证器,可直接使用,代码使用简单,且界面提示很友好,类似手机端输入、错误提示。
5、标签
控件英文Chips,可用于标签,当列表显示数据较多时,可显示多个标签,用于点击过滤。
6、卡片
Cards,卡片式布局,列表、表格显示数据有时是很枯燥的,用卡片会给人耳目一新的感觉,很清爽,展示数据也一目了然,可图片+文字的形式展示,非常友好。
7、图标
Icon Pack,有成百上千钟矢量图标供选择,极大的方便了开发,可用于菜单图标、按钮图标等。
8、分组框
Group Boxes,组合框,类似卡片,组合框Header自定义很方便,可添加图片
9、进度条
各式各样的进度条,还在为调整进度条各个部分而烦恼吗?这个控件库写了几种样式,几乎满足了一般需求使用了,不满足在上面基础上修改也是十分方便的。
10、对话框
遮罩式对话框,支持整个窗体遮罩,也支持窗体部分用户控件对话框,非常实用
11、抽屉
Drawer,抽屉式控件,支持东、南、西、北四个方向打开抽屉。
12、提示信息
提示信息,这种方式不用弹框(免得用户点击关闭,即时加定时器自动关闭也不是很友好),可用于提示性的信息,看一眼即可这种。
更多功能请参考官网与开源项目。
官网:http://materialdesigninxaml.net
开源地址:https://github.com/MaterialDesignInXAML/MaterialDesignInXamlToolkit
MaterialDesignExtensions 扩展库:https://github.com/spiegelp/MaterialDesignExtensions
参考博客:https://blog.csdn.net/HenryMoore/article/details/109107498
2、MahApps.Metro
Metro是一个框架,允许开发人员用最小的努力为自己的WPF应用程序设计出Metro或现代UI。
- 增强默认控件
Metro重写了所有常见WPF控件的默认样式,并为它们提供了现代的外观。
- 样式与自定义控件
Metro还包括一些基于WindowsPhone、Windows8和Windows10(UWP)应用程序概念的自定义控件。
- 开源
MahApps.Metro的源代码托管在GitHub上,包含了自己构建它所需的一切,所以请访问并帮助我们改进它。
功能展示
官网:https://mahapps.com
教程:https://mahapps.com/docs
开源地址:https://github.com/MahApps/MahApps.Metro
3、AduSkin(功能强大,产品示例较多)
AduSkin是一款简单漂亮的WPF UI,融合多个开源框架组件,为个人定制的UI,可供学者参考和使用。
- 产品功能
控件库
动态修改皮肤
- 产品示例
- 【AduMusic Mini】
- 【AduShopping】
- 【AduChat】
- 【心理FM】
- 【SuperEvil】
- 【HttpTool】
- 特色控件组合案例
官网:https://github.com/aduskin
开源地址:https://github.com/aduskin/AduSkin
参考文献:
- https://www.cnblogs.com/lsq6/archive/2019/12/01/11966708.html
- https://dotnet9.com/9373.html
- https://www.cnblogs.com/aduskin/archive/2019/12/26/12101712.html
- https://www.cnblogs.com/lsq6/archive/2019/12/04/11980648.html
成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
个人作品
1、BIMFace.Community.SDK.NET开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
2、ZCN.NET.Common开源地址:https://gitee.com/NAlps/zcn.net.common
技术栈
1、Visual Studio、.C#/.NET、.NET Core、MVC、Web API、RESTful API、gRPC、SignalR、Python
2、jQuery、Vue.js、Bootstrap
3、数据库:SQLServer、MySQL、PostgreSQL、Oracle、SQLite、Redis、MongoDB、ElasticSearch、TiDB、达梦DM、人大金仓、 神通、南大通用 GBase、华为 GaussDB 、腾讯 TDSQL 、阿里 PolarDB、蚂蚁金服 OceanBase、东软 OpenBASE、浪潮云溪数据库 ZNBase
4、ORM:Dapper、Entity Framework、FreeSql、SqlSugar、分库分表、读写分离
5、架构:领域驱动设计 DDD、ABP
6、环境:跨平台、Windows、Linux(CentOS、麒麟、统信UOS、深度Linux)、maxOS、IIS、Nginx、Apach
7、移动App:Android、IOS、HarmonyOS、微信、小程序、快应用、Xamarin、uni-app、MUI、Flutter、Framework7、Cordova、Ionic、React Native、Taro、NutUI、Smobiler
云原生、微服务、Docker、CI/CD、DevOps、K8S;
Dapr、RabbitMQ、Kafka、分布式、大数据、高并发、负载均衡、中间件、RPC、ELK;
.NET + Docker + jenkins + Github + Harbor + K8S;
出处:www.cnblogs.com/SavionZhang
作者:张传宁 微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于微软.NET技术(.NET Core、Web、MVC、WinForm、WPF)、通用权限管理系统、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业快速化实现互联网技术全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件[email protected]联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!