Winform 好看控制項庫推薦:MaterialSkin.2

来源:https://www.cnblogs.com/BoiledYakult/archive/2023/06/28/17512479.html
-Advertisement-
Play Games

> [MaterialSkin.2](https://www.nuget.org/packages/MaterialSkin.2 "MaterialSkin.2") 控制項包是在 [MaterialSkin](https://github.com/IgnaceMaes/MaterialSkin "Ma ...


MaterialSkin.2 控制項包是在 MaterialSkin 及基礎上二次開發而來的,在原控制項基礎上修複了一些Bug,豐富了主題以及動畫效果,效果非常好。

  • MaterialSkin.2 現在處於不活躍狀態
  • 文中用 MaterialSkin 代替 MaterialSkin.2

Preview

先貼幾張演示Demo中的效果圖:

......

Install

NuGet 中搜索 MaterialSkin 就能找到控制項包,直接安裝就行:
image

註意版本框架

工具箱可能不會顯示 MaterialSkin 的控制項,需要我們手動添加下:

工具箱 -> 右擊:添加選項卡 -> 把 NuGet 安裝包里的 DLL 文件拖到選項卡裡
image

簡單嘗鮮

  • 切換使用MaterialForm
    添加引用:using MaterialSkin.Controls;
    窗體繼承換成:public partial class Form1 : MaterialForm
    這個時候切換到設計器就可以看到Material效果的窗體了:
    image

切換主題以及配色方案

在後臺代碼中添加一個只讀的MaterialSkinManager變數,通過這個變數來控制主題和配色,把ReadMe.md給出的常式調整一下方便後續調整:

public partial class Form1 : MaterialForm
{
  private readonly MaterialSkinManager materialSkinManager;   
  public Form1()
  {
    InitializeComponent();

    materialSkinManager = MaterialSkinManager.Instance;	// 初始化 MaterialSkinManager 實例
    materialSkinManager.AddFormToManage(this);	// 將要應用 Material Design 的窗體添加到管理列表中
    materialSkinManager.Theme = MaterialSkinManager.Themes.LIGHT;	// Theme 屬性用來設置整體的主題
    materialSkinManager.ColorScheme = new ColorScheme(Primary.BlueGrey800, Primary.BlueGrey900, Primary.BlueGrey500, Accent.LightBlue200, TextShade.WHITE);	// ColorScheme 屬性來設置配色方案
  }
}

上面代碼寫完運行程式就會是我們配置的配色及主題:

image-20230628161255842

MaterialSkinManager主要是通過Themes以及ColorScheme來控制頁面的顯示效果,前者控制主題,後者控制配色:

  • Themes主要是用來切換深色和淺色主題的,對應LIGHTDARK

  • ColorScheme主要是用來調整頁面的配色方案的,它的構造函數提供了兩種不同的重載形式,用於創建顏色方案:

    • public ColorScheme(Primary primary, Primary darkPrimary, Primary lightPrimary, Accent accent, TextShade textShade)
      

      這個構造函數接受 PrimaryAccent 枚舉類型作為參數,用於指定主顏色和強調色。Primary 枚舉包含一系列預定義的主顏色,而 Accent 枚舉包含一系列預定義的強調色。此構造函數還接受 TextShade 枚舉類型的參數,用於指定文本的明暗色調。通過使用這個構造函數,你可以輕鬆地選擇 顏色方案的不同變體。[常式中使用的就是這個重載]

    • public ColorScheme(Color primary, Color darkPrimary, Color lightPrimary, Color accent, TextShade textShade)
      

      這個構造函數接受 Color 類型的參數,用於直接指定自定義的顏色。你可以傳入具體的顏色對象作為參數,以定義主顏色、深色主顏色、淺色主顏色、強調色以及文本明暗色調。

    先看主題,創建一個改變主題的MaterialButton實現深色和淺色主題的切換了:

private void btn_ChangeTheme_Click(object sender, EventArgs e)
{
    materialSkinManager.Theme = materialSkinManager.Theme == MaterialSkinManager.Themes.DARK ? MaterialSkinManager.Themes.LIGHT : MaterialSkinManager.Themes.DARK;
}

再看配色方案,在此之前我們先在頁面上隨便加一些控制項便於顯示配色效果:

image-20230628193311837

更改配色方案:

private int colorSchemeIndex;   // 通過更換次數,方便迴圈更換顏色

private void btn_SwitchColor_Click(object sender, EventArgs e)
{
    colorSchemeIndex++;
    if (colorSchemeIndex == 6)
    {
        colorSchemeIndex = 0;
    }
    SwitchColor(colorSchemeIndex);
}

private void SwitchColor(int colorSchemeIndex)
{
    switch (colorSchemeIndex)
    {
        case 0:
            materialSkinManager.ColorScheme = new ColorScheme(
                materialSkinManager.Theme == MaterialSkinManager.Themes.DARK ? Primary.Teal500 : Primary.Indigo500,
                materialSkinManager.Theme == MaterialSkinManager.Themes.DARK ? Primary.Teal700 : Primary.Indigo700,
                materialSkinManager.Theme == MaterialSkinManager.Themes.DARK ? Primary.Teal200 : Primary.Indigo100,
                Accent.Pink200,
                TextShade.WHITE);
            break;
        case 1:
            materialSkinManager.ColorScheme = new ColorScheme(
                Primary.Green600,
                Primary.Green700,
                Primary.Green200,
                Accent.Red100,
                TextShade.WHITE);
            break;
        case 2:
            materialSkinManager.ColorScheme = new ColorScheme(
                Primary.BlueGrey800,
                Primary.BlueGrey900,
                Primary.BlueGrey500,
                Accent.LightBlue200,
                TextShade.WHITE);
            break;
        case 3:
            materialSkinManager.ColorScheme = new ColorScheme(
                Primary.Red800,
                Primary.Red900,
                Primary.Red500,
                Accent.Green200,
                TextShade.WHITE);
            break;
        case 4:
            materialSkinManager.ColorScheme = new ColorScheme(
                Primary.Yellow800,
                Primary.Yellow900,
                Primary.Yellow500,
                Accent.DeepOrange200,
                TextShade.WHITE);
            break;
        case 5:
            materialSkinManager.ColorScheme = new ColorScheme(
                Primary.DeepOrange800,
                Primary.DeepOrange900,
                Primary.DeepOrange500,
                Accent.Yellow200,
                TextShade.WHITE);
            break;
        case 6:
            materialSkinManager.ColorScheme = new ColorScheme(
                Primary.Lime800,
                Primary.Lime900,
                Primary.Lime500,
                Accent.Green200,
                TextShade.WHITE);
            break;
    }
    Invalidate(); // 重繪控制項
}

配色是GithubExample以及用戶issue里的配色方案,大家如果要用的話,可以參考:Material Skin 指南 中文翻譯文檔

看看效果:

show

MaterialSkin實現了很豐富的動畫效果,But...

預設的藍粉配色就已經很好看了,大家如果有什麼酷炫帥氣的配色方案,歡迎在評論區留言交流!

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ## Thinkphp6 連接達夢資料庫 這裡使用 IDEA phpEnv PHP7.3 Thinkphp6 桌面操作系統:Windows11 虛擬機:VMware 伺服器操作系統:銀河麒麟 在虛擬機操作與windows無異 [參考資料](https://blog.csdn.net/chenxuan ...
  • ## ThinkPHP6.0 鏈式SQL語句 #### 查詢單個數據 ```php $user = Db::query('select * from `user`'); $user=Db::table('user')->where('UserID',1001)->find();//查詢結果為空 返回 ...
  • 1. sort函數 sort函數為python內置的列表排序高階函數,所謂高階函數,也就是參數為函數或返回值為函數。 先看個簡單的例子: # 數字列表的排序示例nums = [5, 2, 9, 1, 7] nums.sort()print(nums) # 輸出:[1, 2, 5, 7, 9] 可以發 ...
  • 我們開源了組件的源代碼,希望更多人能更便捷的使用開源組件,最好的辦法當然是把組件的JAR包上傳到Maven中央倉庫,這樣可直接通過Maven/Gradle等方式快速引用和使用。但是要把JAR包上傳到Maven中央倉庫的門檻比較高,本文介紹一種非常簡單的使用GitHub/Gitee作為Maven倉庫的... ...
  • # 1. JVM快速入門 從面試開始: 1. 請談談你對JVM 的理解?java8 的虛擬機有什麼更新? 2. 什麼是OOM ?什麼是StackOverflowError?有哪些方法分析? 3. JVM 的常用參數調優你知道哪些? 4. 記憶體快照抓取和MAT分析DUMP文件知道嗎? 5. 談談JVM ...
  • 繼上篇:Taurus .Net Core 微服務開源框架:Admin 插件【4-2】 - 配置管理-Mvc【含請求日誌列印】,本篇繼續介紹下一個內容:系統配置節點:Mvc - Plugin - MicroService 配置界面:註冊中心 ...
  • [TOC] # 原理簡介 本文參考[C#/WPF/WinForm/程式實現軟體開機自動啟動的兩種常用方法](https://blog.csdn.net/weixin_42288432/article/details/120059296),將裡面中的第一種方法做了封裝成**AutoStart**類,使 ...
  • CodeBuilder是一款強大的代碼生成工具,目前發佈了 3.0,大家可以前去下載體驗 [官方主頁](http://fireasy.cn/codebuilder)。 ###1、多種數據源 * `基於 ADO.NET 的數據驅動` 基於 Fireasy 3,支持從 SqlServer、MySql、O ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...