在.NET Conf 2021大会上,微软展示了基于.NET6 跨平台应用程序, 具有 ASP.NET Core、Blazor、.NET MAUI、微服务等功能。
浏览由 ASP.NET Core 和 Blazor 提供支持的 .NET Podcasts 应用的实时运行版本:https://dotnetpodcasts.azurewebsites.net/
单个代码库的跨平台项目解决方案, 适用于Android、iOS、macOS以及Windows 的原生.NET应用程序, 解决方案如下:
global using Microsoft.Maui;
switch (Settings.Theme) { default: case OSAppTheme.Light: App.Current.UserAppTheme = OSAppTheme.Light; break; case OSAppTheme.Dark: App.Current.UserAppTheme = OSAppTheme.Dark; break; }
//订阅 MessagingCenter.Instance.Subscribe<string>("","",async (sender) => { //... }); //取消订阅 MessagingCenter.Instance.Unsubscribe<string>("", ""); //发布 MessagingCenter.Instance.Send<string>("", "");
//注册服务 public static MauiAppBuilder ConfigureServices(this MauiAppBuilder builder) { builder.Services.TryAddSingleton<PlayerService>(); } //调用平台的容器服务 public static class ServicesProvider { public static TService GetService<TService>() => Current.GetService<TService>(); public static IServiceProvider Current => #if WINDOWS10_0_17763_0_OR_GREATER MauiWinUIApplication.Current.Services; #elif ANDROID MauiApplication.Current.Services; #elif IOS || MACCATALYST MauiUIApplicationDelegate.Current.Services; #else null; #endif }
MAUI中统一了资源的管理以及访问,例如: 字体、图标、样式、本地资源文件等。
访问字体
<Setter Property="FontFamily" Value="SegoeUiSemibold" />
访问图片资源
<Image Source="xxx.png" />
本地化资源
xmlns:res="clr-namespace:Microsoft.NetConf2021.Maui.Resources.Strings" <Label Text="{x:Static res:AppResource.Categories}" />
在XAML以及代码中, 你可以通过平台化处理不同的UI以及业务逻辑, 可以通过OnPlatform以及OnIdiom来区分平台及类型。
不同平台下的字体设置
<Label FontSize="{OnPlatform UWP=24, macOS=24, Android=14,iOS=14}" />
不同设备的设置
<GridItemsLayout Span="{OnIdiom Phone=2, Tablet=3, Desktop=3}" />
内置的Essentials提供访问本机网络WIFI、蓝牙等等。
//验证是否联网 var current = Connectivity.NetworkAccess; if (current != NetworkAccess.Internet) { //... } //验证是否存在WIFI连接 var profiles = Connectivity.ConnectionProfiles; var hasWifi = profiles.Contains(ConnectionProfile.WiFi); if (hasWifi) { //... }
在XAML当中, 使用BlazorWebView
xmlns:b="clr-namespace:Microsoft.AspNetCore.Components.WebView.Maui;assembly=Microsoft.AspNetCore.Components.WebView.Maui" <b:BlazorWebView x:Name="MyWebView" Margin="10,0" HostPage="wwwroot/index.html" BackgroundColor="{AppThemeBinding Light={StaticResource Grey1}, Dark={StaticResource Grey9}}"> <b:BlazorWebView.RootComponents> <b:RootComponent Selector="app" ComponentType="{x:Type pages:ListenTogetherComponent}" /> </b:BlazorWebView.RootComponents> </b:BlazorWebView>
项目已在Github发布, https://github.com/microsoft/dotnet-podcasts, 更多特性探索源代码。