News

.NET 6 Desktop Dev Options: WPF, WinForms, UWP, .NET MAUI, Blazor ...

Welcome to the emerging new world of Microsoft-centric software development. Want to code a desktop app? Take your tooling pick from WPF, WinForms, UWP, .NET MAUI, Win UI, Blazor, Project Reunion ... and who knows what's next.

While the choices are many, they're all coming together in the November debut of .NET 6, a major long-term support (LTS) milestone release that's expected to complete the all-things-.NET unification effort that was planned for .NET 5 but was delayed by the pandemic and other issues.

.NET 5
[Click on image for larger view.] .NET 5 (source: Microsoft).

While the old Windows-only .NET Framework offered Windows Presentation Foundation (WPF) and Windows Forms (WinForms) as the main UI options, the cross-platform .NET Core/.NET 5-6 initiative is much trickier.

WPF and WinForms options still exist, though not quite the same because of various issues, but they are joined by all those other alternatives.

One of the latest desktop options is .NET MAUI, (standing for .NET Multi-platform App UI). It's an evolution of the Xamarin.Forms mobile dev component, now being elevated to first-class citizenship status with an SDK unification effort.

MAUI Goals
[Click on image for larger view.] MAUI Goals (source: Microsoft).

"Xamarin has always been a part of .NET, but now it ships as a core workload, shares the same base class library as other workloads like Blazor, and adopts the modern SDK Style project system for consistent tooling experiences," said David Ortinau, principal program manager, mobile dev tools. "No longer is Xamarin some other thing that is like .NET or has some dependency on .NET, but it IS .NET. This will be made clear as you see the naming aligned in our documentation and product pages as we approach release."

.NET MAUI, while keeping its iOS and Android mobile support, also can be used for desktop development for the macOS and Windows platforms (but not Linux).

That desktop support was a focus point of a recent blog post by Ortinau that outlined the current state of and future plans for .NET MAUI.

"In .NET MAUI we are bringing stronger desktop-focused support with WinUI 3 Desktop, the very latest way to build great apps from our Windows team partners," Ortinau said. "When it comes to UWP and WinUI as it relates to .NET MAUI, the main question we are asked is what 'flavor' of XAML will be used in .NET MAUI. Because .NET MAUI controls are multi-platform abstractions rather than Windows-only controls, and because we have a massive catalog of Xamarin.Forms customers with knowledge and projects to bring forward, we are continuing forward with the same 'flavor' you have in .NET MAUI."

On the Mac side of things, developers can now use ".NET for macOS," functionality, extended from the current "Xamarin.Mac" tooling in Xamarin.Forms. That is a .NET binding to Apple's desktop platform, AppKit.

For Apple's future desktop direction, however. .NET will support Mac Catalyst.

Ortinau described that new offering "a solution from Apple that brings your iOS app built with UIKit to desktop, and augments it with additional AppKit and platform APIs as needed. You can explore several of Apple's first-party apps to experience this yourself. .NET MAUI will use this approach in .NET 6."

And beyond that, Ortinau teased Blazor desktop development, something that developers have been playing around with mostly in experiments and proofs of concept.

"We are also working hand-in-hand with the Blazor team to enable Blazor Desktop in .NET 6," Ortinau said. Blazor, of course, is Microsoft's red-hot project to enable web development with C# as the primary programming language, instead of traditional mainstay JavaScript.

There isn't much official documentation for "Blazor Desktop" right now, but Blazor gurus like the main man himself, Steve Sanderson, have been toying with the idea almost since Blazor was envisioned.

This is possible because the default renderer for Blazor -- the client-side component of which is based on WebAssembly -- can be swapped out to target other projects besides web. That resulted in the experimental Blazor Mobile Bindings project for mobile development, recently updated with more UI sharing.

Sanderson even put Blazor to use for for Flutter development.

But Sanderson's desktop endeavors that have also sparked interest among many developers, such as his WebWindow project, which was introduced in 2019 but hasn't been updated much recently.

What are in active development, however, are several .NET 6 initiatives as outlined in the the "Themes of .NET" site where Microsoft tracks .NET development progress using GitHub issues, project boards and milestones.

Some of those themes proposed or committed for .NET 6 relating to desktop include:

  • Epic: Blazor developers can target and deploy their applications to desktop platforms, allowing them to run natively #27217
  • Epic: Desktop developers can package, distribute, release, and update their applications to multiple desktop platforms and architectures #5462
  • Create installable artifacts for Blazor hybrid desktop apps for Windows and macOS #27234
  • User Story: .NET 6 desktop application developers need to manage their build pipelines, versions, telemetry, and channels for their releases #5461
  • Build, run, debug Blazor hybrid desktop apps using the development platform #27233

And, besides all of the above, there are multiple niche offshoots of .NET-based desktop development, including WebView2, which lets developers host web content in their desktop .NET applications.

Another one is Project Reunion, which Microsoft says "provides a unified set of APIs and tools that can be used in a consistent way by any app on a broad set of target Windows 10 OS versions."

The disparate ecosystem for just one target -- desktop -- speaks to the difficulty Microsoft faces in its effort to unify development.

A Visual Studio Magazine reader complained about that very issue in a comment to an article last year: "We need a cross-platform Desktop UI Lib, without that: it makes no sense to make .NET as cross-platform. I hope Blazor will continue and can solve this problem."

And then there's the bigger, overall picture, wherein Microsoft seeks to unify desktop, web, cloud, mobile, gaming, IoT and AI with one framework. That obviously still has a lot of moving parts that need more coalescing. Or, as Matthew MacDonald put it, "No matter what the shape, the implementation gap between different application types -- mobile, desktop, and web -- remains one of .NET's unconquered challenges."

About the Author

David Ramel is an editor and writer at Converge 360.

comments powered by Disqus

Featured

  • Compare New GitHub Copilot Free Plan for Visual Studio/VS Code to Paid Plans

    The free plan restricts the number of completions, chat requests and access to AI models, being suitable for occasional users and small projects.

  • Diving Deep into .NET MAUI

    Ever since someone figured out that fiddling bits results in source code, developers have sought one codebase for all types of apps on all platforms, with Microsoft's latest attempt to further that effort being .NET MAUI.

  • Copilot AI Boosts Abound in New VS Code v1.96

    Microsoft improved on its new "Copilot Edit" functionality in the latest release of Visual Studio Code, v1.96, its open-source based code editor that has become the most popular in the world according to many surveys.

  • AdaBoost Regression Using C#

    Dr. James McCaffrey from Microsoft Research presents a complete end-to-end demonstration of the AdaBoost.R2 algorithm for regression problems (where the goal is to predict a single numeric value). The implementation follows the original source research paper closely, so you can use it as a guide for customization for specific scenarios.

  • Versioning and Documenting ASP.NET Core Services

    Building an API with ASP.NET Core is only half the job. If your API is going to live more than one release cycle, you're going to need to version it. If you have other people building clients for it, you're going to need to document it.

Subscribe on YouTube