支持使用基于Windows窗体应用程序的.NET Core 3.0(预览)的Windows窗体设计器

介绍

截至撰写本文时,Microsoft和社区目前正在测试.NET Core 3.0。如果您在.NET Core 3.0的一般可用性之后阅读本文,请跳过本文。否则,继续。

Windows Forms一直是维护企业/企业桌面应用程序的巅峰之作。尽管有着开发桌面应用程序的古老机制,但微软能够认识到经过实战测试的工具包的优势,并决定将其转移到现代.NET Core平台(以前称为.NET Framework)。

到目前为止,他们设法通过Windows窗体转换很好地将事物整合在一起,但是缺少早期采用者的一些关键组件,其中一个恰好是Windows窗体设计器; Microsoft Visual Studio内置的工具,旨在简化用户界面开发。要确认.NET Core 3.0预览中的Windows窗体设计器限制,请尝试打开并设计任何表单/用户控制文件(通常是新创建的项目中的Form1.cs。)因此,文章的结果存在。本文将指导您如何克服.NET Core 3.0预览版Windows窗体设计器的限制,而无需等待其一般可用性。

软件要求

要继续阅读本文,您必须在系统上安装以下组件:

  1. Microsoft Visual Studio 2019 - 至少版本16.2.0
  2. .NET Core 3.0预览版7(截至编写本文时,将使用预览版7)

克服限制

证明问题

  1. 创建一个新的Windows窗体应用程序(.NET Core)。如果您看不到左侧的条目,请使用方便的“ 搜索模板”搜索框并键入“ Windows Forms App(.NET Core) ”。

  2. 对于这个项目,我们将命名它DotNetCore.WinForms,但你可以任意命名,确保理解这个概念,你会很高兴。
  3. 如果没有进行任何更改,请尝试打开Form1.cs 文件,您应该看到类似的内容。请不要惊慌,这是正常行为,因为我们正在运行.NET Core 3.0的预览版本。我们稍后会解决这个问题。

此时,您开始感觉到在.NET Core 3.0预览下无法进行任何类型的用户界面设计。

解决方案

为了解决这个限制,我们可以使用一种方法,通过基于功能齐全的.NET Framework创建一个额外的Windows Forms项目,我们可以间接地利用.NET Core项目的设计。请继续直到最后。

  1. 右键单击解决方案名称,然后创建一个名为_TemporaryFixup的新解决方案文件夹。

  2. _TemporaryFixup解决方案文件夹下,创建一个新的Windows窗体应用程序(.NET Framework)项目。如果您看不到左侧的条目,请使用方便的“ 搜索模板 ”搜索框并键入“ Windows Forms App(.NET Framework) ”。

  3. 对于这个项目,我们将命名为DotNetFramework.WinForms,但您可以将其命名为任何您喜欢的名称。
  4. 删除Form1.cs 文件。
  5. 右键单击该DotNetFramework.WinForms项目,然后单击“ 属性”
  6. 将默认命名空间更改为与.NET Core项目相同; 在我们的例子中,我们将其设置为DotNetCore.WinForms(将在几个中解释)
  7. 创建一个新表单并将其命名为您喜欢的任何名称。

现在,让我们使用以下命令修改项目中的Program.cs文件DotNetFramework.WinForms

 using System;
using System.IO;
using System.Linq; namespace DotNetFramework.WinForms
{
static class Program
{
private static string SourceProjectDir =
@"C:\Users\ahmad\source\repos\DotNetCore.WinForms\DotNetFramework.WinForms";
private static string TargetProjectDir =
@"C:\Users\ahmad\source\repos\DotNetCore.WinForms\DotNetCore.WinForms"; [STAThread]
static void Main()
{
var directory = new DirectoryInfo(SourceProjectDir); var srcFiles = directory.GetFiles("*.Designer.cs", SearchOption.AllDirectories); foreach (var srcFile in srcFiles)
{
// Get the relative directory
var relativeDirectory = $"{srcFile.DirectoryName.Substring
(SourceProjectDir.Length,
srcFile.DirectoryName.Length - SourceProjectDir.Length)}"; // Append the determined relative directory to the corresponding designer
// & C# source files related to the form.
var designerFileName = $@"{relativeDirectory}\{srcFile.Name}";
var noDesignerFileName =
$@"{relativeDirectory}\{srcFile.Name.Replace(".Designer", "")}"; var srcDesignerFile = $"{SourceProjectDir}{designerFileName}";
var srcNoDesignerFile = $"{SourceProjectDir}{noDesignerFileName}"; var dstDesignerFile = $"{TargetProjectDir}{designerFileName}";
var dstNoDesignerFile = $"{TargetProjectDir}{noDesignerFileName}"; // Create an array based on the relative location.
var dirs = relativeDirectory.Split('\\').ToList(); // Keep track of where were we when we created a directory.
var currentDir = TargetProjectDir; // Start creating the missing directories in our target project.
foreach (var dir in dirs)
{
currentDir = Path.Combine(currentDir, dir);
Directory.CreateDirectory(currentDir);
} // Overwrite the file to the targeted project.
File.Copy(srcDesignerFile, dstDesignerFile, true); // If our UI logic is unavailable, that means we've created
// a new form from the source project.
// so we copy the form's UI logic code to the target project.
if (!File.Exists(dstNoDesignerFile) && File.Exists(srcNoDesignerFile))
{
File.Copy(srcNoDesignerFile, dstNoDesignerFile, false);
}
}
}
}
}

由于我们专注于在.NET Core平台上开发我们的应用程序,因此我们不需要显示.NET Framework对应的任何对话框。我们宁愿*只将.NET Framework项目的用户界面设计部分反映到.NET Core项目中。这几乎可以解释为什么我们之前将默认命名空间更改为.NET Framework项目,还记得吗?

确保修改SourceProjectDir变量以保存.NET Framework项目目录,并使用TargetProjectDir变量保存.NET Core项目目录。

接下来,我们想要在每次构建和运行.NET Core项目时调出.NET Framework可执行文件。在我们继续前进之前,首先构建整个解决方案。其次,右键单击.NET Framework项目并单击Properties,然后从左侧的选项卡中选择Build Events。在“ 预构建事件命令行 ”字段中,粘贴以下内容:

 $(TargetPath)

最后,您可以从.NET Framework项目开始设计用户界面元素,并通过按Ctrl + Shift + B自动反映您对.NET Core项目的更改,然后运行!

使用代码

上面提供的代码本质上是一个反射器。它仅反映.NET Framework项目的.NET Framework项目的表单文件。您可以无限制地修改代码,使其按照您的意图执行操作。

兴趣点

Windows窗体设计器的便利性已被带回。无论您是计划在.NET Core下使用Windows Forms重新开始,还是迁移现有的基于.NET Framework的传统项目,您现在都可以轻松地继续这样做,而无需等待.NET Core 3.0的一般可用性。

在.NET Core 3.0 Preview上使用Windows窗体设计器的更多相关文章

  1. [翻译]用于.NET Core的Windows窗体设计器发布

    本文由微信公众号<开发者精选资讯>翻译首发,转载请注明来源 今天我们很高兴地宣布,.NET Core项目的Windows窗体设计器现在可以在 Visual Studio 2019 16.6 ...

  2. 用VS Code体验调试.NET Core 2.0 Preview (传统三层架构)

    准备工作 VS Code下载地址:https://vscode.cdn.azure.cn/stable/379d2efb5539b09112c793d3d9a413017d736f89/VSCodeS ...

  3. 【译】.NET Core 3.0 Preview 3中关于ASP.NET Core的更新内容

      .NET Core 3.0 Preview 3已经推出,它包含了一系列关于ASP.NET Core的新的更新. 下面是该预览版的更新列表: Razor组件改进: 单项目模板 新的Razer扩展 E ...

  4. .NET Core 2.0 Preview 1发布下载和文档

    .NET Core 2.0.0 Preview 1 发布于 2017 5.10. 你可以通过 Visual Studio 2017 Preview 15.3, Visual Studio for Ma ...

  5. asp.net core 1.1 项目升级至 asp.net core 2.0 preview 2 与正式版

    这两天把一个 asp.net core 1.1 的项目迁移到了 asp.net core 2.0 preview 2 ,在这篇随笔中记录一下. 如果项目在有 global.json 文件,需要删除或修 ...

  6. ASP.NET Core 2.0 Preview 1 中贴心的新特性

    西雅图时间5月10日,微软在 Build 2017 大会上发布了 ASP.NET Core 2.0 Preview 1 ( 详见 Announcing ASP.NET 2.0.0-Preview1 a ...

  7. .NET Core 3.0 Preview 5 亮点之一:发布单文件可执行程序

    在阅读 Announcing .NET Core 3.0 Preview 5 时发现了 .NET Core 3.0 Preview 5 的一个新特性 —— Publishing Single EXEs ...

  8. 【译】宣告推出.NET Core 3.0 Preview 7(英雄的黎明)

    今天,我们宣布推出.NET Core 3.0 Preview 7.我们已经从创建新特性阶段过渡到了完善版本阶段.对于其余的预览版,我们将把重点放在质量(改进)上. 在Windows,macOS和Lin ...

  9. [翻译] .NET Core 3.0 Preview 7 发布

    原文: Announcing .NET Core 3.0 Preview 7 今天,我们宣布推出 .NET Core 3.0 Preview 7 .我们的工作已经从创建新功能过渡到打磨版本.预计剩余的 ...

随机推荐

  1. Java生鲜电商平台-SpringCloud微服务架构中网络请求性能优化与源码解析

    Java生鲜电商平台-SpringCloud微服务架构中网络请求性能优化与源码解析 说明:Java生鲜电商平台中,由于服务进行了拆分,很多的业务服务导致了请求的网络延迟与性能消耗,对应的这些问题,我们 ...

  2. Python【day 17】面向对象-成员

    类的变量分成2种: 1.成员变量 概念:在构造方法中的变量,前面带有self 作用:可以在类中不同的方法间使用 2.类变量-静态变量 概念:在类中,构造方法和普通方法之外,定义的变量 作用: 1.调用 ...

  3. JS基础语法---break关键字

    break关键字: 如果在循环中使用,遇到了break,则立刻跳出当前所在的循环       for (var i = 0; i < 10; i++) {         while (true ...

  4. vueInitVux中引入bootstrap、jquery步骤

    1.先从github上下载 vueInitVux 2.将 build下webpack.base.conf.js 文件 替换成 Html5IQ下的文件 3.npm i 4.npm i jquery -- ...

  5. Python “ValueError: incomplete format” upon print(“stuff %” % “thingy”) 解决方法

    直接贴代码 这里我是想匹配length i  的值并且要打印出data里面%23也就是#的url编码,但是发现这样报错了,这时候我们在%23前面多加一个%号就能够成功执行我这里测试的2.7环境,3.x ...

  6. SAP MM 特殊库存之T库存初探

    SAP MM 特殊库存之T库存初探 笔者所在的A项目里,销售业务广泛启用了POD功能.VL02N对交货单做了发货过账后物权并没有转移,而是将自有E库存转为一个叫做在途库存的特殊库存里.等到货物到了客户 ...

  7. 安卓开发笔记(三十四):Material Design框架实现优美的左侧侧滑栏

    首先我们先上图:  下面是主页面的代码,activity_main.xml: <?xml version="1.0" encoding="utf-8"?& ...

  8. 仓库管理移动应用解决方案——C#开发的移动应用开源解决方案

    产品简介 SmoWMS是一款仓库管理移动解决方案,通过Smobiler平台开发,包含了仓库管理中基础的入库.出库.订单管理.调拨.盘点.报表等功能.支持扫码条码扫描.RFID扫描等仓库中常见的场景. ...

  9. Ubuntu 镜像制作 官方教程

    rufus工具下载:下载链接 官方教程:官方教程链接 软件界面预览: 资源来源自网络,如果对您有帮助,请点击推荐~. 我尝试了这个方法可以用.电脑重启时,选择从U盘启动,就能安装系统. 参考链接: h ...

  10. caffe初体验

    caffe是一个深度学习的框架, 具体我也不太清楚, 可以自行百度吧, 我也是刚刚知道有这么一个框架, 才疏学浅啊. 在安装完caffe, 我的第一个想法就是, 别管他是个啥东西, 总得先让我运行一些 ...