arrow left
Back to Developer Education

WPF vs WinForms

WPF vs WinForms

Windows Presentation Foundation (WPF) and Windows Forms Applications (WinForms) are graphical user interfaces that developers can use to build Windows desktop programs. <!--more--> In this tutorial, we will create applications using WPF and WinForms to understand their similarities and differences.

Prerequisites

To follow along with this tutorial, you need:

Table of contents

What is WinForms?

In February 2002, Microsoft announced WinForms as a GUI-based alternative to the .NET Framework.

WinForms enables a developer to drag and drop controls onto a Windows Form and modify these components using code written in C#, VB.NET, or any other .NET language.

Since WinForms is a wrapper for a collection of C++ classes, each WinForms control is an instance of that class.

Developers can quickly drag and drop controls from a toolbox in Microsoft's Visual Studio IDE. This makes working with WinForms simple.

Therefore, WinForms is a graphical library in the .NET framework that lets the developer build rich client applications with event-driven design.

Creating a WinForms application

Assuming we have installed Visual Studio, we can create a new project in the solution explorer by choosing the WinForms application from the list.

You can change the name of the form as you desire. In our case, it will remain as Form1.cs.

After creating the project, you will notice that Visual Studio created the Form1.cs file and generated the Program.cs file:

Visual Studio Window

From our toolbox window, we can drag and drop a textbox, label, and button:

window-after buttons

By double-clicking the add button, let's include the following code:

private void button1_Click(object sender, EventArgs e)
{
    var y = Convert.ToInt32(textBox1.Text);
    var x = Convert.ToInt32(textBox2.Text);
    var z = y + x;
    textBox3.Text = z.ToString();
}

From the code above, we have declared two variables that take two inputs, adds them, and then display the results in a textbox.

When taking inputs, we have to convert the string to an integer.

When we run the application, it prompts for two numbers and after clicking the add button, it displays the results:

Results after adding two numbers

Controls are readily employed in Windows Forms which makes them easy to use. However, when designing, Windows forms should not be utilized.

This is because the code for each event and procedure in WinForms is firmly tied to the UI element.

Even if you utilized the visual designer in WinForms, the designer extension component of your form had layout code generated in the language of your choice. For example, C#, VB.NET, or C++.

Without that code, you wouldn't be able to construct the form individually. This means that to create the UI, you have to be familiar with the selected language.

What is WPF?

Microsoft introduced Windows Presentation Foundation (WPF) in 2007, which replaced Windows Form. Since then, the creation of desktop applications has changed considerably.

WPF allows developers to create event-driven rich client applications for usage on the Windows operating system.

WPF can be used to develop and design both Windows applications and web applications while WinForms can only be used to develop and design Windows applications.

XAML (Extensible Application Markup Language) is used by WPF to define the user interface of a WPF application. XAML is a declarative language that describes the UI of a WPF application.

In WPF, the user interface and the code can be created and organized separately. The UI in WPF is based on XAML, which is extensible and allows you to design a specific interface without knowing whether it will be written in C# or VB.NET.

As a result, the full UI design can (but is not required) be completed by someone unfamiliar with the programming language to be used.

WPF comes with support for a wide range of video formats, records, 3D material, and a lot of built-in animation while WinForms does not offer much rich, interactive, animated, hardware accelerated, vector 2D, and 3D capabilities as compared to WPF.

Creating a WPF application

Let's start by creating a new project in the solution explorer. Here, we shall choose WPF from the list.

Visual Studio creates two XAML files (App.xaml and MainWindow.xaml) and two corresponding C# files (App.xaml.cs and MainWindow.xaml.cs) for you:

creating wpf project

The layout of a WPF application is shown above, with the XAML file beside the designer.

There is a distinction between WPF and WinForms. WPF utilizes XAML to define a WPF application's user interface while WinForms provides access to the native windows library of common controls.

Note that we can manually add a textbox, label, and button to the associated XAML file. For example, we can add a button in WPF using the following code in the MainWindow.xaml file:

<Window x:Class="addingTwoNumbers.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:addingTwoNumbers"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid HorizontalAlignment="Left" Width="815">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="0*"/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>
        <Button x:Name = "add_click" Content="Add" HorizontalAlignment="Left" Margin="254,217,0,0" VerticalAlignment="Top" Height="35" Width="92" Grid.ColumnSpan="2"/>
    </Grid>
</Window>

In reality, we can also drag and drop controls into the designer window. The relevant XAML file will be updated as well. Let's add a textbox, label, and button to the XAML file:

<Window x:Class="addingTwoNumbers.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:addingTwoNumbers"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid HorizontalAlignment="Left" Width="815">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="0*"/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>
        <TextBox x:Name = "firstnumber" HorizontalAlignment="Left" Margin="200,113,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="200" Height="34" Grid.ColumnSpan="2"/>
        <TextBox x:Name = "secondnumber" HorizontalAlignment="Left" Margin="200,168,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="200" Height="34" Grid.ColumnSpan="2"/>
        <Button x:Name = "add_click" Content="Add" HorizontalAlignment="Left" Margin="254,217,0,0" VerticalAlignment="Top" Height="35" Width="92" Grid.ColumnSpan="2"/>
        <Label Content="First number" HorizontalAlignment="Left" Margin="104,121,0,0" VerticalAlignment="Top" Grid.ColumnSpan="2"/>
        <Label Content="Second Number" HorizontalAlignment="Left" Margin="104,168,0,0" VerticalAlignment="Top" RenderTransformOrigin="0.492,2.809" Grid.ColumnSpan="2"/>
        <TextBox x:Name = "result" HorizontalAlignment="Left" Margin="200,293,0,0" Text="Results" TextWrapping="Wrap" VerticalAlignment="Top" Width="200" Height="34" Grid.ColumnSpan="2"/>
    </Grid>
</Window>

In WPF, XAML makes it easy to create and edit your GUI. It also allows work to be split between a designer (XAML) and a program (C#) unlike in WinForms where the design and the program are not separated.

In WPF, we have to add a click event handler to the button while in WinForms, it is not required.

When the user selects the add button, the sum of the values supplied by the user in the top two TextBox controls should be shown in the third TextBox control.

Add the following code to the button event handler:

using System.Windows;
namespace addingTwoNumbers
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }
        private void add_click(object sender, RoutedEventArgs e)
        {
            int results = Int32.Parse(firstnumber.Text) + Int32.Parse(secondnumber.Text);
            result.Text = results.ToString();
        }
    }
}

After adding two numbers in wpf

Unlike WinForms, WPF is primarily used to create an application's user interface (UI) and has numerous security features.

Conclusion

In this tutorial, we have learned the major differences between WinForms and WPF by creating a simple application in both instances.

The following are some of the key advantages of WPF over Winforms:

  • Improved graphical user interfaces
  • Better animation
  • 2D and 3D visualization capabilities
  • Web application compatibility
  • Faster acceleration
  • Cross-platform support

WPF is the most common development platform for native Windows programs. You can, therefore, use it to create quality applications.

Happy coding!


Peer Review Contributions by: Geoffrey Mungai

Published on: Jan 20, 2022
Updated on: Jul 15, 2024
CTA

Cloudzilla is FREE for React and Node.js projects

Deploy GitHub projects across every major cloud in under 3 minutes. No credit card required.
Get Started for Free