前陣子一直期待.net core3.0正式版本的出來,以為這個版本出來,Winform程式又迎來一次新生了,不過9.23日出來的馬上下載更新VS,創建新的.net core Winform專案,發現并沒有Winform表單設計器,而微軟目前則是通過插件的方式,讓我們單獨下載Winform設計器,這個設計器還是預覽版本,很多功能還是沒有實作的,只能算是一個簡單的雛形,本博客案例介紹基于.net core3.0創建一個普通的WInform程式,讓大家了解下基于.net core3.0創建的程式的大概模樣,
1、開發環境的準備
要做基于.net core3.0的WInform開發,需要首先更新你的Visual Studio到16.3,這個版本是整合.net core3.0的,因此也是能夠開發.net core Winform程式的基礎,
其次是下載winforms-designer插件,這個是支持對Winform表單的設計器,讓我們可以通過拖動控制元件的方式進行界面的設計開發,
.NET Core Windows Forms 可視化設計器在將來一定是未來的Visual Studio 2019更新的一部分,但目前來說,想要可視化設計器,需要一個預發布的Visual Studio擴展,
完成這兩個步驟,其他開發就和我們普通創建VS專案一樣的,

創建專案后,我們可以打開對應的Winform表單,并可以在工具箱里面看到一些Winform界面控制元件,好的是控制元件的大概和以前差不多,不好的事情是少了很多常規Winform控制元件,這個也是目前WInform 設計器處于開發預覽版的原因所在吧,

2、創建一個WInform程式
為了創建一個簡單測驗的WInform程式,我們可以往里面添加一些WInform的界面控制元件,不過使用程序中,發現很多界面所需元素沒有提供界面控制元件的支持,包括工具列、屬性里面都還不完善,如ImageList物件和Image物件的屬性支持等,我們只能通過代碼的方式進行使用,
我創建一個簡單的WInform界面,拖動了一些常規的控制元件,但是一些控制元件需要使用圖片的,如ListView、PictureBox等這些,需要通過代碼設定(無法通過屬性加入的方式指定圖片)

最后界面展示效果如下所示,

表單原始碼如下所示,
public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { MessageBox.Show("你好,這是一個.net core的Winform程式", "提示資訊", MessageBoxButtons.OK, MessageBoxIcon.Information | MessageBoxIcon.Asterisk); } private ImageList imageList = new ImageList(); private void Form1_Load(object sender, EventArgs e) { var image = Image.FromFile(Path.Combine(Application.StartupPath, "SplashScreen.png")); if(image != null) { this.pictureBox1.Image = image; } imageList.Images.Clear(); var iconPath = Path.Combine(Application.StartupPath, "icons"); var fileNames = Directory.GetFiles(iconPath, "*.ico"); foreach(string file in fileNames) { imageList.Images.Add(file, Image.FromFile(file)); } this.treeView1.ImageList = imageList; foreach(TreeNode node in this.treeView1.Nodes) { SetNodeImage(node); } this.button1.Image = imageList.Images[2]; } private void SetNodeImage(TreeNode node) { foreach (TreeNode subNode in node.Nodes) { subNode.ImageIndex = subNode.Level; subNode.SelectedImageIndex = subNode.Level; SetNodeImage(subNode); } }
從中我們可以看到,.net core下的WInform程式,它的表單元素或者相關物件,沒有發生不一致命名的情況,用起來還是非常方便一致的,不過就是對應很多界面的功能,目前只能通過后臺代碼的方式進行補充,才能實作一個比較完整的效果,和.net Framework框架下已經完善的非常好的Winform開發,真的是差距不是一點半點,看來.net core winform開發的路還是很漫長,需要在工具層面更多的支持才行,
界面方案里面,我們看到命名空間也比以前少了很多了了,主要還是基于.net core 提供的WInform包,

我們再來看看程式目錄下的檔案如下所示,

由于目前我們還沒有考慮第三方的.net core 層面的類別庫,因此這里沒有使用第三方的DLL,以后整合的話,第三方相關的參考也是一個非常頭大的問題,如果大多數常用的類別庫都有基于.net standard 的類別庫支持,那倒是好,否則可能會面臨兩難的抉擇,不過.net core的Winform開發我覺得還是很值得期待的,畢竟引入一個整體的.net core開發路線,對企業或者個人來說,都是一個非常不錯的開發場景,
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/112710.html
標籤:.NET Core
