Create Setup and Deployment of WPF Application Step by Step

No.of Views1698
Bookmarked0 times
Downloads 
Votes0
By  dpatra   On  18 Apr 2010 11:04:54
Tag : WPF , Applications
In this article we will see how we can create a Setup and Deployment of WPF Application. I would guide you step by step so that you don’t miss anything
emailbookmarkadd commentsprint

Images in this article missing? We recently lost them in a site migration. We're working to restore these as you read this. Should you need an image in an emergency, please contact us at info@codegain.com

 

Introduction

In this article we will see how we can create a Setup and Deployment of WPF Application. I would guide you step by step so that you don’t miss anything.

Creating WPF Application Project

Fire up Visual Studio 2008 and Create a WPF Application and name the project as MyApplication.
 

Image Loading

We would add another WPF User Control Library so that you get the complexity of more than one project and their dependencies. So add a New Project to the Solution and name it as WPFHelper. 

Image Loading

Let’s make this simple. When you add a WPF User Control Library it comes with a UserControl1.xaml, delete the file and add a class and name it as Employee.cs
 

Image Loading

Have the following structure for simplicity.

namespace WPFHelper
{
    public class Employee
    {
        public string Name { get; set; }
    }
}

Now your Solution structure would look like as follows: 

Image Loading

Now add reference of this WPFHelper to MyApplication. 

Image Loading

Now go back to our main application “MyApplication ” and and some controls so that it would have dependecies on the Assembly of WPFHelper project.
Now I have added a ComboBox that would contain the Employee names.
 

Image Loading

Write the below code to bind to some sample data.

XAML

<Window x:Class="MyApplication.Window1"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="clr-namespace:WPFHelper;assembly=WPFHelper"
    Title="Window1" Height="300" Width="300">
    <Grid>
        <ComboBox x:Name="cmbEmployeeNames" Height="23" Margin="21,29,98,0" VerticalAlignment="Top" ItemsSource="{Binding}">
            <ComboBox.ItemTemplate>
                <DataTemplate>
                    <TextBlock Text="{Binding Name}"/>
                </DataTemplate>
            </ComboBox.ItemTemplate>
        </ComboBox>
    </Grid>
</Window>


C#

public partial class Window1 : Window
    {
        public Window1()
        {
            InitializeComponent();
            List<Employee> myList = new List<Employee> 
            {
                new Employee{ Name="Some 1"},
                new Employee{ Name="Some 2"},
                new Employee{ Name="Some 3"},
                new Employee{ Name="Some 4"},
                new Employee{ Name="Some 5"}
            };

            cmbEmployeeNames.ItemsSource = myList;
        }
    }

Now run the application to test the application.

Image Loading

 Yes, we are going good. Now comes the most important part where we would go step by step.

Step 1
 

Add a Setup and Deployment project to the Solution and name it as MyApplicationSetup. 

Image Loading
 
 
As soon as you add the project it opens the File Explorer view.
 
Image Loading

The solution structure would be like as follows:  

Image Loading

In the left pane you see the System Folders and the right pane is for the content of the Folder.If you see above we have 3 System Folders. You can add other System Folders based on your requirement.The following list is shown when you right click on the root and select Add Special Folder.
 

Image Loading

Step 2


We would add Program File’s Folder to our Setup project. 

Image Loading

Here is the way how you should add contents to the folders.
1)    Application Folder
            a.    It should contain the Primary output and the dependencies.
2)    Program Files Folder
         a.    It should contain the Folder where your Primary output would be copied while installation and the necessary files [Resource file such as icons, config, etc..].
3)    User’s Desktop
         a.    It should contain the Shortcut of your application
4)    User’s Program Menu
         a.    It should contain the Shortcut of your application.

Step 3
 

Now we would add Primary output and other dependencies to Application Folder. 

Image Loading


Select as displayed above.
 

Image Loading

You would see the projects available in the solution to add. As MyApplication is the Startup Project select it and press OK. You would see the change in the folder as follows. 

Image Loading

Step 4

Now we would add A folder to the Program Files Folder. 

Image Loading

Step 5

Name the folder as My Application. 

Image Loading

Step 6

Now add the same as you did for the Application Folder. 

Image Loading

But you would see the dependecy DLL are not added. Here you can add required files for the Application to run such as Icons and all.

Step 7

Now we would add a Shortcut to User’s Desktop.


Here is the Trick go to your Application folder and Create a shortcut of your Primary output and rename it as required. And then move the file from there to User’s Desktop. The following screens would help you doing this. 

Image Loading

 

Image Loading

 

Image Loading

 

Image Loading

 

Image Loading

 

Image Loading

Step 8

Now do the same procedure as above for User’s Program Menu. As it requires the same.
We have to do a last round of work for all the folders and files we have added. That is a property called AlwaysCreate to True. By default it is False. 

Image Loading

Step 9

Change all folders and files setting as AlwaysCreate = True.

Changing the Default Location of Application Folder.
By default it is: [ProgramFilesFolder][Manufacturer]\[ProductName]


If you don’t want to change it’s fine. But if you give [Manufacture] in the attribute then it would create folder as Microsoft in Program Files and then your folder.I prefer to remove the attribute so that your application would be directly under Program Files.Change the Default Location to [ProgramFilesFolder] \[ProductName]
Now our Setup project is ready. Rebuild the Solution and then rebuild the Setup project.Go to the Debug directory of the Setup project. There you would find your setup files as .msi and .exe
 

Image Loading

The first one is for distribution.That’s it you have successfully created a Setup for your WPF application.Hope this article helps.
 

Sample Project Source

Download source files -422 kb

 

 
Sign Up to vote for this article
 
About Author
 
dpatra
Occupation-Not Provided
Company-Not Provided
Member Type-Expert
Location-Not Provided
Joined date-13 Jul 2009
Home Page-Not Provided
Blog Page-Not Provided
 
 
Other popularSectionarticles
Comments
There is no comments for this articles.
Leave a Reply
Title:
Display Name:
Email:
(not display in page for the security purphase)
Website:
Message:
Please refresh your screen using Ctrl+F5
If you can't read this number refresh your screen
Please input the anti-spam code that you can read in the image.
^ Scroll to Top