You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In this article, you'll learn the limitations of Windows Forms Designer on HDPI monitors and [how to run Visual Studio as a DPI-unaware process](#resolve-hdpi-display-problems).
16
+
In this article, you'll learn about the limitations of Windows Forms Designer on HDPI monitors and [how to run Visual Studio as a DPI-unaware process](#resolve-hdpi-display-problems).
17
17
18
-
Visual Studio is a dots per inch (DPI) aware application, which means the display scales automatically. If an application states that it's not DPI-aware, the operating system scales the application as a bitmap. This behavior is also called DPI virtualization. The application still thinks that it's running at 100% scaling, or 96 dpi.
18
+
Visual Studio is a dots per inch (DPI) aware application, which means the display scales automatically. If an application states that it's not DPI-aware, the operating system scales the application as a bitmap. This behavior is also called DPI virtualization. The application still thinks that it's running at 100% scaling, or 96 DPI.
19
19
20
20
You can also:
21
21
+[Automatically scale in Windows Forms](/dotnet/framework/winforms/automatic-scaling-in-windows-forms)
@@ -27,81 +27,69 @@ Since the **Windows Forms Designer** in Visual Studio doesn't have scaling suppo
27
27
28
28

29
29
30
-
If you aren't working in the designer and don't need to adjust the layout of your form, you can ignore the informational bar and continue working in the code editor or in other types of designers. (You can also [disable notifications](#disable-notifications) so that the informational bar doesn't continue to appear.) Only the **Windows Forms Designer** is affected.
30
+
### Use the information bar
31
31
32
-
When you open a form in the **Windows Forms Designer** on an HDPI monitor, Visual Studio displays an informational bar.
33
-
34
-
:::image type="content" source="media/scaling-gold-bar-message-1.png" alt-text="Screenshot of the informational bar in Visual Studio to restart in DPI-unaware mode.":::
32
+
When you open a form in the **Windows Forms Designer** on an HDPI monitor, Visual Studio displays an information bar.
35
33
34
+
:::image type="content" source="media/scaling-gold-bar-message-1.png" alt-text="Screenshot of the information bar in Visual Studio to restart in DPI-unaware mode.":::
36
35
36
+
If you aren't working in the designer and don't need to adjust the layout of your form, you can ignore the information bar and continue working in the code editor or in other types of designers. (You can also [disable notifications](#disable-notifications) so that the information bar doesn't continue to appear.) Only the **Windows Forms Designer** is affected.
37
37
38
38
> [!TIP]
39
-
> If you've closed the informational bar at the top of the designer, but you still want to replicate the behavior of the link that says **Restart Visual Studio with 100% scaling**, you still can. Select **Tools** > **Command Line** > **Developer Command Prompt** from the Visual Studio menu bar. Then, enter `devenv /noScale`.
39
+
> If you've closed the information bar but you still want restart Visual Studio with 100% scaling, you can. [Use the DevEnv.exe tool](#use-the-devenvexe-tool) to do so.
40
40
41
41
## Resolve HDPI display problems
42
42
43
-
There are three options to resolve the display problem:
43
+
There are several options to resolve the display problem:
44
44
45
45
-[Restart Visual Studio as a DPI-unaware process](#restart-visual-studio-as-a-dpi-unaware-process)
46
-
-[Add a registry entry](#add-a-registry-entry)
46
+
<!-- - [Add a registry entry](#add-a-registry-entry)-->
47
47
-[Set your display scaling setting to 100%](#set-your-display-scaling-setting-to-100)
48
-
49
-
> [!TIP]
50
-
> If you prefer to manage settings from the command line, [`devenv.exe`](../ide/reference/devenv-command-line-switches.md) takes `/noscale` as a command-line parameter to run in 100% scaling mode.
48
+
-[Use the DevEnv.exe tool](#use-the-devenvexe-tool)
51
49
52
50
### Restart Visual Studio as a DPI-unaware process
53
51
54
-
The preferred solution to this issue is to restart Visual Studio as a DPI-unaware process. Do so by selecting the option on the yellow informational bar.
52
+
The preferred solution to this issue is to restart Visual Studio as a DPI-unaware process. Do so by selecting the option on the yellow information bar.
55
53
56
-
When Visual Studio runs as a DPI-unaware process, the designer layout issues are resolved, but fonts may appear blurry and you may see issues in other designers such as the **XAML Designer**.. Visual Studio displays a different yellow informational message when it runs as a DPI-unaware process that says **Visual Studio is running as a DPI-unaware process. WPF and XAML designers might not display correctly.** The informational bar also provides an option to **Restart Visual Studio as a DPI-aware process**.
54
+
When Visual Studio runs as a DPI-unaware process, the designer layout issues are resolved, but fonts may appear blurry and you may see issues in other designers such as the **XAML Designer**. Visual Studio displays a different yellow informational message when it runs as a DPI-unaware process that says **Visual Studio is running as a DPI-unaware process. WPF and XAML designers might not display correctly.** The informational bar also provides an option to **Restart Visual Studio as a DPI-aware process**.
57
55
58
56
::: moniker range="<=vs-2019"
59
57
60
58
> [!NOTE]
61
-
> - If you have undocked tool windows in Visual Studio when you select the option to restart as a DPI-unaware process, the position of the tool windows might change.
59
+
> - If you have undocked [tool windows](../ide/customizing-window-layouts-in-visual-studio.md#tool-and-document-windows) in Visual Studio when you select the option to restart as a DPI-unaware process, the position of the tool windows might change.
62
60
> - If you use the default Visual Basic profile, or if you have the **Save new projects when created** option deselected in **Tools** > **Options** > **Projects and Solutions**, Visual Studio cannot reopen your project when it restarts as a DPI-unaware process. However, you can open the project by selecting it under **File** > **Recent Projects and Solutions**.
63
61
64
62
::: moniker-end
65
63
66
64
::: moniker range=">=vs-2022"
67
65
68
66
> [!NOTE]
69
-
> - If you have undocked tool windows in Visual Studio when you select the option to restart as a DPI-unaware process, the position of the tool windows might change.
67
+
> - If you have undocked [tool windows](../ide/customizing-window-layouts-in-visual-studio.md#tool-and-document-windows) in Visual Studio when you select the option to restart as a DPI-unaware process, the position of the tool windows might change.
70
68
> - If you use the default Visual Basic profile, Visual Studio cannot reopen your project when it restarts as a DPI-unaware process. However, you can open the project by selecting it under **File** > **Recent Projects and Solutions**.
71
69
72
70
::: moniker-end
73
71
74
72
It's important to restart Visual Studio as a DPI-aware process when you're finished working in the **Windows Forms Designer**. If you close and reopen Visual Studio when it's running in DPI-unaware mode, it becomes DPI-aware again. You can also select the **Restart Visual Studio as a DPI-aware process** option in the informational bar.
75
73
76
-
### Add a registry entry
77
-
78
-
As option two, you can mark Visual Studio as DPI-unaware by modifying the registry. Open **Registry Editor** and add an entry to the **HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows NT\CurrentVersion\AppCompatFlags\Layers** subkey:
79
-
80
-
**Entry**: Depending on whether you're using Visual Studio 2017, 2019, or 2022, use one of these values:
> If you're using the Professional or Enterprise edition of Visual Studio, replace **Community** with **Professional** or **Enterprise** in the entry. Also replace the drive letter as necessary.
74
+
### Set your display scaling setting to 100%
88
75
89
-
**Type**: REG_SZ <br>
90
-
**Value**: DPIUNAWARE
76
+
A third option to resolving the issue is to set your display scaling setting to 100% in Windows 10, type **display settings** in the task bar search box, and then select **Change display settings**. In the **Settings** window, set **Change the size of text, apps, and other items** to **100%**. However, setting your display scaling to 100% may be undesirable since it can make the user interface too small to be usable.
91
77
92
-
Visual Studio remains in DPI-unaware mode until you remove the registry entry.
78
+
### Use the DevEnv.exe tool
93
79
94
-
### Set your display scaling setting to 100%
80
+
If you prefer to manage settings from the command line, [`devenv.exe`](../ide/reference/devenv-command-line-switches.md) takes `/noscale` as a command-line parameter to run in 100% scaling mode. Here's how:
95
81
96
-
A third option to resolving the issue is to set your display scaling setting to 100% in Windows 10, type **display settings** in the task bar search box, and then select **Change display settings**. In the **Settings** window, set **Change the size of text, apps, and other items** to **100%**. However, setting your display scaling to 100% may be undesirable since it can make the user interface too small to be usable.
82
+
1. Select **Tools** > **Command Line** > **Developer Command Prompt** from the Visual Studio menu bar.
83
+
1. Then, enter `devenv /noScale`.
97
84
98
85
## Disable notifications
99
86
100
87
You can choose not to be notified of DPI scaling issues in Visual Studio. You might want to disable notifications if you aren't working in the designer, for example.
101
88
102
89
To disable notifications:
90
+
103
91
1. Choose **Tools** > **Options** to open the **Options** dialog.
104
-
2. In the **Options** dialog, choose **Windows Forms Designer** > **General**, and set **DPI Scaling Notifications** to **False**.
92
+
1. In the **Options** dialog, choose **Windows Forms Designer** > **General**, and set **DPI Scaling Notifications** to **False**.
105
93
106
94
If you want to later reenable scaling notifications, set the property to **True**.
title: Find MSBuild and use its API | Microsoft Docs
3
+
description: Learn how to ensure that programmatic builds from your application match builds done within Visual Studio or MSBuild.exe, and learn how to locate and use a consistent version on MSBuild when developing a programmatic build application on different machines.
4
+
ms.custom: SEO-VS-2020
5
+
ms.date: 10/25/2022
6
+
ms.topic: conceptual
7
+
author: ghogen
8
+
ms.author: ghogen
9
+
manager: jmartens
10
+
ms.technology: msbuild
11
+
ms.workload:
12
+
- multiple
13
+
---
14
+
# Find and use a version of MSBuild
15
+
16
+
To ensure that programmatic builds from your application match builds done within Visual Studio or *MSBuild.exe*, you might need to load the same version of the MSBuild assemblies that were installed with a specific version of Visual Studio and use the same SDKs that are available within that version of Visual Studio. Or, when you're creating a build application that will be run on machines that might have various installed versions of MSBuild, .NET, and Visual Studio, you might also want to find and use a consistent version of MSBuild. The Microsoft.Build.Locator NuGet package streamlines this process.
17
+
18
+
## Use Microsoft.Build.Locator
19
+
20
+
The Microsoft.Build.Locator package is relevant to situations where your application runs on client machines, virtual machines, or within containers, either where Visual Studio is installed or in environments where only the Visual Studio Build Tools, or just the .NET SDK is installed, such as when builds are requested with the `dotnet build` command line. In any case, your application needs to find the desired version of MSBuild. That could be the version that matches Visual Studio, MSBuild.exe, or `dotnet build`, or a particular consistent version regardless of the varying machine configurations in environments where your application might be used.
21
+
22
+
If you redistribute *Microsoft.Build.Locator.dll* with your application, you won't need to distribute other MSBuild assemblies.
23
+
24
+
Using the locator API requires a few changes in your project, described below. To see an example of the changes required to update a project, see [the commits made to an example project in the MSBuildLocator repository](https://github.com/Microsoft/MSBuildLocator/commits/example-updating-to-msbuild-15).
25
+
26
+
## Change MSBuild references
27
+
28
+
To make sure that MSBuild loads from a central location, you must not distribute its assemblies with your application.
29
+
30
+
The mechanism for changing your project to avoid loading MSBuild from a central location depends on how you reference MSBuild.
31
+
32
+
### Use NuGet packages (preferred)
33
+
34
+
These instructions assume that you're using [PackageReference-style NuGet references](/nuget/consume-packages/package-references-in-project-files).
35
+
36
+
Change your project file(s) to reference MSBuild assemblies from their NuGet packages. Specify `ExcludeAssets=runtime` to tell NuGet that the assemblies are needed only at build time, and shouldn't be copied to the output directory.
37
+
38
+
The major and minor version of the MSBuild packages must be less than or equal to the minimum version of Visual Studio you wish to support. For example, if you wish to support Visual Studio 2017 and later versions, reference package version `15.1.548`.
If you can't use NuGet packages, you can reference MSBuild assemblies that are distributed with Visual Studio. If you reference MSBuild directly, ensure that it won't be copied to your output directory by setting `Copy Local` to `False`. In the project file, this setting will look like the following code:
> If you're updating from a version of MSBuild prior to 15, MSBuild requires binding redirects for certain assemblies (Microsoft.Build assemblies), but if you reference the Microsoft.Build.Locator package, you ensure that your application automatically uses the required binding redirects to version 15.1.0.0. Binding redirects to this version support MSBuild 15.x, 16.x, and 17.x.
61
+
62
+
## Ensure output is clean
63
+
64
+
Build your project and inspect the output directory to make sure that it doesn't contain any *Microsoft.Build.\*.dll* assemblies other than *Microsoft.Build.Locator.dll*, added in the next step.
65
+
66
+
## Add package reference for Microsoft.Build.Locator
67
+
68
+
Add a NuGet package reference for [Microsoft.Build.Locator](https://www.nuget.org/packages/Microsoft.Build.Locator/).
Do not specify `ExcludeAssets=runtime` for the Microsoft.Build.Locator package.
77
+
78
+
## Register instance before calling MSBuild
79
+
80
+
When you're creating a build application for general use, you don't know what versions of Visual Studio, .NET, and MSBuild might be installed on a machine your application is being executed on. The purpose of MSBuildLocator is to find an appropriate installation of MSBuild to use on machines with diverse installation environments. MSBuildLocator allows you to specify some logic to determine which MSBuild to use, but you as the developer of your application need to determine what MSBuild version it requires or can accept, or else provide a way for your users to specify a version, and include logic to translate that choice into appropriate calls to the MSBuildLocator API.
81
+
82
+
The simplest way to add the call to the Locator API is to add a call to `MSBuildLocator.RegisterInstance`
83
+
in your application startup code. One example is to pick the latest version, as shown here, but your application might have it own requirements.
84
+
85
+
You cannot reference any MSBuild types (from the `Microsoft.Build` namespace) in the method that calls MSBuildLocator. For example, you cannot do this:
Projectp=newProject(SomePath); // Could be any MSBuild type
94
+
// Code that uses the MSBuild type
95
+
}
96
+
```
97
+
98
+
Instead, you must do this:
99
+
100
+
```csharp
101
+
voidMethodThatDoesNotDirectlyCallMSBuild()
102
+
{
103
+
varinstance=... // select which of the installed instances to use
104
+
105
+
// Register a specific instance of MSBuild
106
+
MSBuildLocator.RegisterInstance(instance);
107
+
MethodThatCallsMSBuild();
108
+
}
109
+
110
+
voidMethodThatCallsMSBuild()
111
+
{
112
+
Projectp=newProject(SomePath);
113
+
// Code that uses the MSBuild type
114
+
}
115
+
```
116
+
117
+
To specify an MSBuild instance, you can select a result of `MSBuildLocator.QueryVisualStudioInstances` to pass to `MSBuildLocator.RegisterInstance` using the custom logic you need.
118
+
119
+
## Next steps
120
+
121
+
Learn about MSBuild APIs by consulting the MSBuild API Reference:
0 commit comments