解决vs2019中暂时无法为.net core WinForms使用 Designer 的临时方法

以下方法来自于微软github开源项目WinForms:

dotnet/winforms - Using the Classic WinForms Designer in WinForms Core, 请放心使用 .

目前.net core下的 Windows Forms的可视化设计器(Designer)尚不可用,后续的Visual Studio 2019 Update才会支持该部分的功能。不过目前我们想在vs2019中使用 Designer,有一种临时解决方法。

可以使用Visual Studio来处理链接文件(Link files)的功能,并将其WinForms Designer用于Classic Framework (即.net Framework的Win Forms项目)。

具体的解决方法是在同一个 Solution下创建两个项目:

  • 用于设计WinForms应用程序的.NET Framework应用程序(.net core项目)
  • 用于运行WinForms应用程序的.NET Core应用程序(.net Framework 项目)

而两个应用程序(.net core项目和相应.net Framework 项目)都将引用相同的文件。

在该方法中,只要添加新的Win Form或新的UserControl,就需要在Classic Framework WinForms项目(.net Framework的Win Forms项目)中重新设置Form文件的嵌套层级关系,推荐使用Mad Kristensen的文件嵌套扩展来完成这件事,而不是使用文本编辑器来修补项目文件(.csproj文件),建议事先安装好该vs插件。

完整步骤:

安装 vs 2019 professional/enterprise版本#

先安装 vs 2019 professional/enterprise版本,安装好.net core 3.0 SDK,此时试着创建一个.net core下的 win forms 应用,

4624570-fff277cb5c7c02ff.png
img

设置好相关项目名和存放路径后,会弹出:

4624570-42dc6ba2ca6f9875.png
img2-BravoYeung

在vs的设置里,勾选.NET core下的"Use preview SDK"#

4624570-64445f6ef4669d04.jpg
img3

设置完,重启vs才能生效。

使用vs自带的模板,选择其中的 .net core forms 创建Project, 取名为"CoreHelloForm"#

4624570-2fc78a9a59fa0228.png
1555742184205-BravoYeung
4624570-18bf0f236454d7aa.png
1555742223738

此时的文件目录为:

4624570-c5318f8d8f8008a9.png
1555742304164

在刚创建的Solution中使用vs自带的模板,选择其中的.net framework forms添加新的project,取名为"CoreHelloForm.Designer"#

4624570-74b2eb2ff73f23eb.png
1555742345380
4624570-6ff07d8dcde2dc44.png
image
4624570-d6743ca9f02e80de.png
1555742418769

此时Solution中的文件目录为:

4624570-5c8c2cee9eae6e87.png
1555742466296

将.net core form下的Form1 重命名为 MainForm#

4624570-8255bfb2b9e371ac.gif
Rename1
4624570-65bfeceb992245ae.gif
rename2-BravoYeung

此时,选中 .net core form项目,右键选择 “Set as start up project”,按F5运行项目,可看到窗体:

4624570-d91f8006d793e0c8.png
1555743593850

然后点窗体右上角的x关闭按钮,停止运行.

测试从命令行是否能正常 build .net core项目#

右键 .net core form项目,点击"Open Folder in File Explorer",

4624570-c5f0544fb3efa4d4.png
1555743805105
4624570-d8e26026aa248cdc.png
1555743877296

删除此处的bin 文件夹

在上方地址栏输入cmd 进入命令行:

4624570-608a2b94c7dfa26f.png
cmd-enter

输入dotnet --version,看是否能看到具体.net core版本,如果没问题,继续下面的步骤。

输入dotnet build

4624570-27f2e82c4ba125c4.png
1555744288015

此时,回到文件目录D:\Coding\csProj\CoreHelloForm\CoreHelloForm\bin\Debug\netcoreapp3.0,双击其中的exe文件,窗体能正常打开。

4624570-20a68ebd7931dcba.png
1555744416951

删除项目CoreHelloForm.Designer中所有Form1相关的文件#

接着选中.net framework项目CoreHelloForm.Designer下的Form1,右键点击"Delete",

4624570-4acefbd886da29f5.png
1555744591913

会出现下面这个警告框,点OK

在项目`CoreHelloForm.Designer中以"As Link"的方式引用.net core form项目下的MainForm相关文件#

选中项目CoreHelloForm.Designer,右键Add,选"Existing Item"

4624570-7232b59a825540f9.png
1555744760875

打开文件选择框之后,选择.net core项目CoreHelloForm下的下图中高亮的3个文件.

4624570-d2bcc2a2fcf7c485.png
Add As Link

点击Add As Link

从Extension market下载并安装扩展 File Nesting#

下载地址: File Nesting for VS
下载到的文件是File_Nesting_v2.6.85.vsix, 关闭vs,双击,勾选上相应版本的vs安装即可~

4624570-8add27b442f45a12.png
file-nesting

使用 File Nesting来修改 Link 的 MainForm相关文件的层次关系.#

先选中文件MainForm.Designer.csMainForm.resx,然后右键点击 "File Nesting" -> "Auto-nest selected items"

4624570-8a214632ef803e1a.png
1555745085481

再右键点击 "File Nesting" -> "Nest item",选择 MainForm

4624570-b685544202dd0982.png
1555745243570

OK继续.

再进行一次重命名#

.Designer项目下的Program.cs中的Form1改为MainForm.

4624570-45fa770fe0248889.gif
Rename3

重设启动项项目#

选中项目CoreHelloForm.Designer,右键 Rebuild, 选中.net framework项目CoreHelloForm.Designer,右键选择 “Set as start up project”.

关闭 Solution中 项目CoreHelloForm.Designer中MainForm的干扰文件#

此时,如果试着双击项目CoreHelloForm.Designer中的MainForm.cs,会弹出如下警告。

4624570-f75458571874a049.png
1555746088721

那是因为项目CoreHelloForm.Designer中的MainForm.cs 所Link 的与MainForm相关的文件已经在 项目CoreHelloForm 中 打开。

我们将已打开的文件中与项目CoreHelloForm.Designer中Form相关的文件都关闭掉,比如:

4624570-1c6b272ba8fcea6c.png
1555745903085

试用 Designer#

现在,再双击项目CoreHelloForm.Designer中的MainForm.cs,就能看到 Designer 了。

4624570-8cacaf472d6ba8b8.png
1555745954211

此时,可以进行可视化编辑了。

比如,我做了如下几处修改:

  • 改掉 Form的 Title
4624570-d917e90b4487aed1.png
1555746855153
  • 改掉文本框的内容.
4624570-cda88a9cab9cf704.png
1555746929894
  • 改掉窗体的图标(icon)
4624570-cc4a1860a5c49ae4.png
1555746969076

F5,运行的效果图为:

4624570-e300df0d48c79a86.png
1555746682182

项目代码已推到github,欢迎Forkstar.
传送门: .netCore-WinForms_Designer , 如果觉得自己配置起来麻烦,也可以 clone 下来自己体验一把喔~

解决vs2019中暂时无法为.net core WinForms使用 Designer 的临时方法#

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值