Compartilhar via


Novidades no Windows Forms para .NET 7

Este artigo descreve alguns dos novos recursos e aprimoramentos do Windows Forms no .NET 7.

Há algumas alterações significativas que você deve estar ciente ao migrar do .NET Framework para o .NET 7. Para obter mais informações, consulte Alterações significativas no Windows Forms.

Melhorias elevadas do PPP

A renderização de DPI alta com PerMonitorV2 foi aprimorada:

  • Dimensione corretamente os controles aninhados. Por exemplo, um botão que está em um painel colocado em uma aba.

  • Dimensionar Form.MaximumSize e Form.MinimumSize propriedades com base nas configurações de DPI do monitor atual para aplicativos que são executados com ApplicationHighDpiMode definido para PerMonitorV2.

    No .NET 7, esse recurso é desabilitado por padrão e você deve optar por receber essa alteração. A partir do .NET 8, esse recurso é habilitado por padrão e você precisa desativá-lo para voltar ao comportamento anterior.

    Para habilitar o recurso, configure a configProperties definição em runtimeconfig.json:

    {
      "runtimeOptions": {
        "tfm": "net7.0",
        "frameworks": [
            ...
        ],
        "configProperties": {
          "System.Windows.Forms.ScaleTopLevelFormMinMaxSizeForDpi": true,
        }
      }
    }
    

Melhorias e correções de acessibilidade

Esta versão adiciona melhorias adicionais à acessibilidade, incluindo, mas não se limitando aos seguintes itens:

  • Muitos problemas relacionados a anúncios observados nos leitores de tela foram resolvidos, garantindo que as informações sobre controles estão corretas. Por exemplo, ListView agora anuncia corretamente quando um grupo é expandido ou recolhido.

  • Agora, mais controles fornecem suporte à Automação da Interface do Usuário:

  • Os vazamentos de memória relacionados à execução de um aplicativo do Windows Forms em ferramentas adaptativas, como o Narrador, foram corrigidos.

  • As ferramentas assistivas agora desenham com precisão indicadores de foco e relatam retângulos delimitadores corretos para formulários aninhados e alguns elementos de controles compostos, como DataGridView, ListView, e TabControl.

  • O padrão de controle ExpandCollapse da interface de usuário de automação foi implementado corretamente nos controles , ListView e TreeView, e só é ativado para itens expansíveis.

  • Várias correções de taxa de contraste de cores em controles.

  • Melhorias de visibilidade para ToolStripTextBox e ToolStripButton em temas de alto contraste.

Melhorias de associação de dados (versão prévia)

Embora o Windows Forms já tenha um mecanismo de associação avançado, uma forma mais moderna de associação de dados, semelhante à associação de dados fornecida pelo WPF, está sendo introduzida.

Os novos recursos de associação de dados permitem que você adote totalmente o padrão MVVM e o uso de mapeadores relacionais de objeto do ViewModels nos Windows Forms mais fácil do que antes. Isso, por sua vez, possibilita reduzir o código nos arquivos code-behind e abre novas possibilidades de teste. Mais importante, ele permite o compartilhamento de código entre os Windows Forms e outras estruturas de GUI do .NET, como WPF, UWP/WinUI e .NET MAUI. E para esclarecer uma pergunta comumente feita, não há planos para introduzir o XAML nos Windows Forms.

Esses novos recursos de associação de dados estão em versão prévia do .NET 7 e mais trabalhos nesse recurso ocorrerão no .NET 8.

Para habilitar a nova associação, adicione a EnablePreviewFeatures configuração ao arquivo de projeto. Isso tem suporte no C# e no Visual Basic.

<Project Sdk="Microsoft.NET.Sdk">

  <!-- other settings -->

  <PropertyGroup>
    <EnablePreviewFeatures>true</EnablePreviewFeatures>
  </PropertyGroup>

</Project>

O snippet de código a seguir demonstra as novas propriedades, eventos e métodos adicionados às várias classes nos Windows Forms. Embora o exemplo de código a seguir esteja em C#, ele também se aplica ao Visual Basic.

public class Control  {
    [BindableAttribute(true)]
    public virtual object DataContext { get; set; }
    [BrowsableAttribute(true)]
    public event EventHandler DataContextChanged;
    protected virtual void OnDataContextChanged(EventArgs e);
    protected virtual void OnParentDataContextChanged(EventArgs e);
}

[RequiresPreviewFeaturesAttribute]
public abstract class BindableComponent : Component, IBindableComponent, IComponent, IDisposable {
    protected BindableComponent();
    public BindingContext? BindingContext { get; set; }
    public ControlBindingsCollection DataBindings { get; }
    public event EventHandler BindingContextChanged;
    protected virtual void OnBindingContextChanged(EventArgs e);
}

public abstract class ButtonBase : Control {
    [BindableAttribute(true)]
    [RequiresPreviewFeaturesAttribute]
    public ICommand? Command { get; set; }
    [BindableAttribute(true)]
    public object? CommandParameter { [RequiresPreviewFeaturesAttribute] get; [RequiresPreviewFeaturesAttribute] set; }
    [RequiresPreviewFeaturesAttribute]
    public event EventHandler? CommandCanExecuteChanged;
    [RequiresPreviewFeaturesAttribute]
    public event EventHandler? CommandChanged;
    [RequiresPreviewFeaturesAttribute]
    public event EventHandler? CommandParameterChanged;
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnCommandCanExecuteChanged(EventArgs e);
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnCommandChanged(EventArgs e);
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnCommandParameterChanged(EventArgs e);
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnRequestCommandExecute(EventArgs e);
}

public abstract class ToolStripItem : BindableComponent, IComponent, IDisposable, IDropTarget {
    [BindableAttribute(true)]
    [RequiresPreviewFeaturesAttribute]
    public ICommand Command { get; set; }
    [BindableAttribute(true)]
    public object CommandParameter { [RequiresPreviewFeaturesAttribute] get; [RequiresPreviewFeaturesAttribute] set; }
    [RequiresPreviewFeaturesAttribute]
    public event EventHandler CommandCanExecuteChanged;
    [RequiresPreviewFeaturesAttribute]
    public event EventHandler CommandChanged;
    [RequiresPreviewFeaturesAttribute]
    public event EventHandler CommandParameterChanged;
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnCommandCanExecuteChanged(EventArgs e);
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnCommandChanged(EventArgs e);
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnCommandParameterChanged(EventArgs e);
    [RequiresPreviewFeaturesAttribute]
    protected virtual void OnRequestCommandExecute(EventArgs e);
}

Melhorias diversas

Aqui estão algumas outras alterações notáveis:

  • A manipulação de arrastar e soltar corresponde à funcionalidade de arrastar e soltar do Windows com efeitos de exibição mais avançados, como ícones e rótulos de texto.
  • As caixas de diálogo pasta e arquivo permitem mais opções:
    • Adicionar ao recente
    • Verificar a permissão de gravação
    • Modo expandido
    • OK requer interação
    • Selecionar somente leitura
    • Mostrar arquivos ocultos
    • Mostrar locais fixados
    • Mostrar visualização
  • Agora, a propriedade de ErrorProvider é HasErrors.
  • O layout encaixável do formulário foi ajustado para o Windows 11.

Consulte também