概述

      今天要带大家了解的是一款WPF的开源控件库MahApps.Metro。MahApps.Metro是用于创建现代WPF应用程序的工具包,它许多开箱即用的好东西。目前支持的NET Framework 4.6.2及更高版本、.NET Core 3.1, .NET 5 and .NET 6 (on Windows)。官网学习文档地址:https://mahapps.com/docs/

Dotnet讲堂

这里是Dotnet编程的乐园,如果你对C# Winfom感兴趣,你想学习wpf编写酷炫的界面通过mvvm模式实现前后端解耦,你热衷于智能制造、工控上位机,资深高工带你入坑。

25篇原创内容

公众号

风格赏析

  • Theme有两款,深色和浅色:下面只展示浅色主题
  • 介绍一款最受欢迎的.NET 开源UI库_microsoft

  • Progress进度条:这里提供了好几款,样式很优雅
  • 介绍一款最受欢迎的.NET 开源UI库_microsoft_02

  • datagrid:表格控件
  • 介绍一款最受欢迎的.NET 开源UI库_microsoft_03

  • hamburger
  • 介绍一款最受欢迎的.NET 开源UI库_ui_04


  • 介绍一款最受欢迎的.NET 开源UI库_ui_05

  • Dialogs:消息弹框
  • 介绍一款最受欢迎的.NET 开源UI库_xml_06

用法介绍

     看了上面的控件风格,想必有很多小伙伴已经迫不及待想知道这套控件库如何在自己项目中使用了,接下来小编就带你正式体验MahApps.Metro.

     首先,创建项目,然后在github上搜索引用:如果要体验预先发型版,可以勾选图片中红框部分

介绍一款最受欢迎的.NET 开源UI库_microsoft_07

  1. MahApps内置风格和主题:
 <Application.Resources>    <ResourceDictionary>      <ResourceDictionary.MergedDictionaries>        <!-- MahApps.Metro resource dictionaries. Make sure that all file names are Case Sensitive! -->        <ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Controls.xaml" />        <ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Fonts.xaml" />        <!-- Theme setting -->        <ResourceDictionary Source="pack://application:,,,/MahApps.Metro;component/Styles/Themes/Light.Blue.xaml" />      </ResourceDictionary.MergedDictionaries>    </ResourceDictionary>  </Application.Resources>
  1. 使用MetroWindows:要开始全面的MahApps造型和全面的窗口支持,您需要将您的普通窗口更改为我们的MetroWindows。
    打开你的主窗口,通常命名为MainWindow.xaml,在打开窗口标记中添加名称空间属性
xmlns:mah="clr-namespace:MahApps.Metro.Controls;assembly=MahApps.Metro"或者xmlns:mah="http://metro.mahapps.com/winfx/xaml/controls"
  1. 前台xmal全部代码如下:
<mah:MetroWindow x:Class="WpfApp8.StartView"        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:mah="clr-namespace:MahApps.Metro.Controls;assembly=MahApps.Metro"         xmlns:cal="http://www.caliburnproject.org"         xmlns:local="clr-namespace:WpfApp8"        mc:Ignorable="d"        GlowBrush="{DynamicResource MahApps.Brushes.Accent}"        ResizeMode="CanResizeWithGrip"        Title="StartView" Height="300" Width="600" WindowStartupLocation="CenterScreen">    <StackPanel>        <TextBox Name="TextContent"/>        <Button x:Name="testBtn" Content="testBtn"   Background="LightCyan"/>        <ListBox Name="ListBoxItems"  MinHeight="230" Background="LightGray"                 cal:Message.Attach="[Event SelectionChanged] = [Action ListBoxItems_SelectionChanged($source,$eventArgs)];                                     [Event MouseUp]=[ListBoxItems_MouseUp($source,$eventArgs)]" />    </StackPanel></mah:MetroWindow>
  1. 您还需要修改窗口文件的代码,以便基类与XAML文件的MetroWindow类匹配:
using MahApps.Metro.Controls;
namespace WpfApp8{ /// <summary> /// StartView.xaml 的交互逻辑 /// </summary> public partial class StartView : MetroWindow { public StartView() { InitializeComponent(); }
}}

这样保存后重新编译运行,就会看到窗体的样式已经发生改变,完全变成了Metro风格。

运行结果

  1. 介绍一款最受欢迎的.NET 开源UI库_xml_08

源码下载

百度网盘链接:https://pan.baidu.com/s/1dD8HaoVDz6G8xeipRWaQ-Q

提取码:6666