Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Aplicativos WPF são executados no .NET, mas usam a plataforma XAML do Windows Presentation Foundation. WinUI 3 é a substituição moderna. O principal desafio para a migração de IA é que WPF usa namespaces System.Windows.* enquanto o WinUI 3 usa Microsoft.UI.Xaml.*, e muitos controles e APIs de janela precisam de substituições direcionadas em vez de pesquisa e substituição simples.
Instalar o recurso de migração do WPF
gh copilot plugin install winui@awesome-copilot
Tabela de substituição de API
Namespaces
| WPF | WinUI 3 |
|---|---|
System.Windows.* |
Microsoft.UI.Xaml.* |
System.Windows.Controls.* |
Microsoft.UI.Xaml.Controls.* |
System.Windows.Media.* |
Microsoft.UI.Xaml.Media.* |
System.Windows.Data.* |
Microsoft.UI.Xaml.Data.* |
System.Windows.Input.* |
Microsoft.UI.Input.* |
Controles
| WPF | WinUI 3 | Notes |
|---|---|---|
Window |
Microsoft.UI.Xaml.Window |
Superfície de API diferente |
Grid, StackPanel, Canvas |
Inalterado | Mesmos nomes |
TextBox, Button, CheckBox |
Inalterado | Mesmos nomes, estilo WinUI |
ListBox / ListView |
ListView |
Usar ItemsView para novo código |
DataGrid |
DataGrid (CommunityToolkit) |
Adicionar CommunityToolkit.WinUI.Controls.DataGrid |
TabControl |
TabView |
API diferente |
Menu / MenuItem |
MenuBar / MenuBarItem |
|
ToolBar |
CommandBar |
|
RichTextBox |
RichEditBox |
|
WebBrowser |
WebView2 |
API diferente, assíncrona |
Threading
| WPF | WinUI 3 |
|---|---|
Dispatcher.Invoke(...) |
DispatcherQueue.TryEnqueue(...) |
Dispatcher.BeginInvoke(...) |
DispatcherQueue.TryEnqueue(DispatcherQueuePriority.Low, ...) |
Application.Current.Dispatcher |
this.DispatcherQueue |
Janelas e DPI
| WPF | WinUI 3 |
|---|---|
Window.WindowState |
AppWindow.Presenter (usar OverlappedPresenter) |
SystemParameters.WorkArea |
DisplayArea.GetFromWindowId(...) |
PresentationSource.FromVisual() |
WinRT.Interop.WindowNative.GetWindowHandle(window) |
Vinculação de dados
| WPF | WinUI 3 |
|---|---|
INotifyPropertyChanged |
Inalterado |
ObservableCollection<T> |
Inalterado |
{Binding} |
{x:Bind} preferencial (tempo de compilação) |
DependencyProperty |
Inalterado |
IValueConverter |
Inalterado |
Recursos e estilos
| WPF | WinUI 3 |
|---|---|
ResourceDictionary |
Inalterado |
StaticResource |
Inalterado |
DynamicResource |
{ThemeResource} para cores do sistema |
SystemColors.WindowBrush |
{ThemeResource SystemFillColorSolidNeutralBrush} |
Prompt de início
I'm migrating a WPF app to WinUI 3 using the Windows App SDK.
Apply these substitutions:
- System.Windows.* → Microsoft.UI.Xaml.*
- Dispatcher.Invoke / BeginInvoke → DispatcherQueue.TryEnqueue
- Window.WindowState → AppWindow with OverlappedPresenter
- PresentationSource → WinRT.Interop.WindowNative.GetWindowHandle
- DynamicResource for system colors → ThemeResource
- {Binding} → {x:Bind} where possible (compile-time binding)
- ListBox → ListView or ItemsView
- TabControl → TabView
- WebBrowser → WebView2
- DataGrid → CommunityToolkit.WinUI.Controls.DataGrid
Do not use any System.Windows.* namespaces in new code.
Do not use Dispatcher.Invoke — use DispatcherQueue.TryEnqueue.
Flag APIs without a direct WinUI 3 equivalent rather than guessing.
Alterações no arquivo do projeto
<!-- Before (WPF) -->
<TargetFramework>net10.0-windows</TargetFramework>
<UseWPF>true</UseWPF>
<!-- After (WinUI 3) -->
<TargetFramework>net10.0-windows10.0.19041.0</TargetFramework>
<WindowsSdkPackageVersion>10.0.19041.31</WindowsSdkPackageVersion>
dotnet add package Microsoft.WindowsAppSDK
APIs que não migram diretamente
Diga ao agente para sinalizar isso em vez de adivinhar:
- camada WPF
Adorner— não tem equivalente no WinUI 3 - WPF
FlowDocument/DocumentViewer— useRichEditBoxpara conteúdo editável; nenhum visualizador equivalente - WPF
Viewport3D— use a interoperabilidade com Win2D ou DirectX - Hospedagem de espaço no ar/HWND – padrões de interoperabilidade de uso
SwapChainPanelou Win32
Conteúdo relacionado
- Migrar de UWP
- Migrar do iOS
- Plug-in do agente WinUI
- guia de migração SDK do Aplicativo Windows
Windows developer