-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Upgrading .NET MAUI from .NET 7 to .NET 8
David Ortinau edited this page Nov 2, 2023
·
5 revisions
To upgrade from .NET 7 to 8:
- Install .NET 8 and the .NET MAUI workload with Visual Studio 17.8+, or with the standalone installer and
dotnet workload install mauicommand. - Change your target framework references from
net7.0-*tonet8.0-*
We recommend also adding explicit package references to .NET MAUI NuGet packages:
<ItemGroup>
<PackageReference Include="Microsoft.Maui.Controls" Version="$(MauiVersion)" />
<PackageReference Include="Microsoft.Maui.Controls.Compatibility" Version="$(MauiVersion)" />
</ItemGroup>The $(MauiVersion) variable is referenced from the version of .NET MAUI you have installed. You may override this by adding <MauiVersion></MauiVersion> to the csproj like this:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFrameworks>net8.0-android;net8.0-ios</TargetFrameworks>
<UseMaui>True</UseMaui>
<MauiVersion>8.0.0-preview.6.23329.7</MauiVersion>
...This is useful when using ad-hoc builds from the Nightly Feed or builds downloaded from pull requests.
The following behavior has changed from the previous release:
- Use of the xref:Microsoft.Maui.Controls.Maps.Map control from XAML now requires the following
xmlnsnamespace declaration:xmlns:maps="http://schemas.microsoft.com/dotnet/2021/maui/maps". - Image caching is disabled on Android when loading an image from a stream with the
ImageSource.FromStreammethod. This is due to the lack of data from which to create a reasonable cache key. - On iOS, pages automatically scroll when the soft input keyboard would cover a text entry field, so that the field is above the soft input keyboard. The
KeyboardAutoManagerScroll.Disconnectmethod, in theMicrosoft.Maui.Platformnamespace, can be called to disable this default behavior. TheKeyboardAutoManagerScroll.Connectmethod can be called to re-enable the behavior after it's been disabled. - How the color of a tab is set in a Shell app has changed on some platforms. For more information, see Tab appearance.
- It's not required to specify a value for the
$(ApplicationIdGuid)build property in your app's project file. This is because .NET MAUI Windows apps no longer require a GUID as an app ID, and instead use the value of the$(ApplicationId)build property as the app ID. Therefore, the same reverse domain format app ID is now used across all platforms, such as com.mycompany.myapp. - .NET MAUI Mac Catalyst apps are no longer limited to 50 menu items on the menu bar.
- The
PlatformImage.FromStreammethod, in theMicrosoft.Maui.Graphicsnamespace, can now be used to load images on Windows instead of having to use theW2DImageLoadingServiceclass.