UWP更改標題欄顏色

来源:http://www.cnblogs.com/wwh8797/archive/2017/11/23/7883328.html
-Advertisement-
Play Games

你是否因為UWP標題欄太醜而想過改變?那麼這篇文章或許可以幫助你美化UWP界面,讓你的UWP的標題欄也變好看 這裡的代碼,都要在MainPage的構造函數中。如果你在App類中更改了首頁,則在該首頁的構造函數中敲以下教程所需代碼 首先,是要獲取標題欄的對象 獲取對象後,就可以操作標題欄啦 以下為更改 ...


你是否因為UWP標題欄太醜而想過改變?那麼這篇文章或許可以幫助你美化UWP界面,讓你的UWP的標題欄也變好看

 

這裡的代碼,都要在MainPage的構造函數中。如果你在App類中更改了首頁,則在該首頁的構造函數中敲以下教程所需代碼

首先,是要獲取標題欄的對象

var titleBar = ApplicationView.GetForCurrentView().TitleBar;

獲取對象後,就可以操作標題欄啦

以下為更改標題欄顏色

titleBar.BackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);

(0xFF, 0xFF, 0xFF, 0xD0)為設置ARGB值,此處為米黃色(可參考UWP應用“初心日記”)。不懂的可以專門搜索學習這方面。以下遇到不再說明。

如果你覺得標題欄上的字也不好看,想隱藏也可以。但是經筆者測試,如果設置前景色為透明,文字仍然為黑色。因此需要設置相同顏色

titleBar.ForegroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);

設置完如圖

整體看來比之前更簡潔了

當然,如果想在應用程式處於非活動狀態時也是這個顏色,也是可以設置的。此處顏色相同

titleBar.InactiveBackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);
titleBar.InactiveForegroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);

 

這時,標題欄中“三大金剛”(最小化,最大化,關閉)按鈕會顯得更醜,因為他們還是原來的顏色。這時需再更改他們的顏色。

和標題欄類似,但其有四種狀態需單獨設置:正常、滑鼠經過、滑鼠單擊(或觸摸點擊)、非活動狀態

 

這個示例和“初心日記”的標題欄設置相同

正常狀態和非活動狀態,背景色相同:

titleBar.ButtonBackgroundColor = titleBar.ButtonInactiveBackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);

滑鼠經過時:

titleBar.ButtonHoverBackgroundColor = Color.FromArgb(0xFF, 0xEF, 0xEF, 0xB0);

滑鼠按下(或觸摸點擊)時:

titleBar.ButtonPressedBackgroundColor = Color.FromArgb(0xFF, 0xDF, 0xDF, 0x90);

 

這時按鈕上的文字顏色仍然是白色,和米黃色分不清,我們把四種狀態下的文字都變成黑色:

titleBar.ButtonForegroundColor = titleBar.ButtonHoverForegroundColor = titleBar.ButtonInactiveForegroundColor = titleBar.ButtonPressedForegroundColor = Colors.Black;

做完這些,標題欄就可以和app主題色融為一體了。來一張“初心日記”的截圖參考一下

 

 

看起來是不是很簡潔,比預設的主題色好看多了

 

另外附上“初心日記”設置標題欄的全部代碼:

        public MainPage()
        {
            this.InitializeComponent();

            var titleBar = ApplicationView.GetForCurrentView().TitleBar;
            titleBar.BackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);
            titleBar.ForegroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);
            titleBar.InactiveBackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);
            titleBar.InactiveForegroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);

            titleBar.ButtonBackgroundColor = titleBar.ButtonInactiveBackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xD0);
            titleBar.ButtonHoverBackgroundColor = Color.FromArgb(0xFF, 0xEF, 0xEF, 0xB0);
            titleBar.ButtonPressedBackgroundColor = Color.FromArgb(0xFF, 0xDF, 0xDF, 0x90);

            titleBar.ButtonForegroundColor = titleBar.ButtonHoverForegroundColor = titleBar.ButtonInactiveForegroundColor = titleBar.ButtonPressedForegroundColor = Colors.Black;
        }

代碼可根據需要,更改顏色以適合app的主題顏色

註意:必須在首頁的構造函數中設置,否則不起作用

 

-----------------------------------------手動分界線------------------------------------------------

 

如果你的應用只面向桌面,到此就算完成了

 

但是如果你的應用還面向手機端,這裡就會有個小問題:手機的狀態欄部分,是全白色,別的什麼都沒有,非常影響美觀。

筆者也是找了很久也沒有消除辦法(也許有,但UWP的教程太少了),但是筆者想到了一個好方法,既然不能消除,就讓它作為襯托

 

那麼下麵就把系統的任務欄顯示在最上層,並讓背景透明。然後筆者發現這樣比原來沒有白條時,更好看了

以下也可作為設置手機狀態欄透明的教程

 

首先,右鍵單擊“解決方案資源管理器”中的“引用”,點擊“添加引用”。在“Universal Windows”中的“擴展”中,找到如下圖所示兩個引用

整體如圖

添加完成後,打開App.xaml.cs,找到OnLaunched這個函數,在該函數的開始位置加入如下代碼:

if (Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.UI.ViewManagement.StatusBar"))
            {
                StatusBar statusBar = StatusBar.GetForCurrentView();
                statusBar.BackgroundColor = Color.FromArgb(0xFF, 0xFF, 0xFF, 0xC0);
                statusBar.ForegroundColor = Colors.Black;
                statusBar.BackgroundOpacity = 1;
            }

其中(0xFF, 0xFF, 0xFF, 0xC0)為手機狀態欄的背景,此處為米黃色,為了和“初心日記”主題色搭配

另外,需要添加引用。也可以利用visual studio強大的提示功能添加

using Windows.UI.ViewManagement;

 

至此,手機狀態欄也美化成功:系統狀態欄可一直顯示,背景色為app主題色

 

此教程根據“初心日記”,讀者可嘗試使用。關於該軟體介紹,可參考 http://bbs.wfun.com/forum.php?mod=viewthread&tid=1002379&page=4#pid17167369

 

如果還有疑問,歡迎提問。個人郵箱[email protected]


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

-Advertisement-
Play Games
更多相關文章
  • 第1章 Zabbix簡介及組成 1.1 zabbix簡介 zabbix是一個基於web界面,提供分散式系統監視以及網路監視功能的企業級的開源解決方案。它可以監視各種網路參數,保證伺服器自動的安全運營,並提供靈活的通知機制以讓系統管理員快速定位/解決存在的各種問題 1.1 zabbix組成 zabbi ...
  • 0 操作成功完成.1 功能錯誤.2 系統找不到指定的文件.3 系統找不到指定的路徑.4 系統無法打開文件.5 拒絕訪問.6 句柄無效.7 存儲控制塊被損壞.8 存儲空間不足, 無法處理此命令.9 存儲控制塊地址無效.10 環境錯誤.11 試圖載入格式錯誤的程式.12 訪問碼無效.13 數據無效.14 ...
  • ...
  • 一、安裝mutt 二、配置mutt vim /etc/Muttrc 在裡面找到下麵幾行,並將內容修改為你自己的內容(下麵幾行分佈在不同位置,請耐心查找,記得去掉它行首的#號) 三、下載並解壓msmtp 根據系統情況,需要安裝wget和bzip2 1 yum install wget bzip2 -y ...
  • 我們知道運維工程師(Operations)最基本的職責就是負責服務的穩定性並確保整個服務的高可用性,同時不斷優化系統架構、提升部署效率、優化資源利用率,確保服務可以7 24H不間斷地為用戶提供服務。 如果你想從事Linux運維相關工作,那麼你可以來實驗樓,因為實驗上有: "【Linux運維技術路徑】 ...
  • 要使用Linux系統很重要的一個操作就是使Linux系統能夠訪問互聯網,只有Linux系統能夠訪問互聯網才能夠去下載很多自己所需要的資源,如果不能訪問互聯網那麼使用Linux系統往往會卡在這一步,假設你裝的是一個minimal版本的CentOS,那麼很多Linux系統下麵的工具都是沒有被安裝的,這個 ...
  • http://www.c-sharpcorner.com/UploadFile/0c1bb2/sorting-paging-searching-in-Asp-Net-mvc-5/ https://dzone.com/articles/table-sorting-pagination Index.cs ...
  • 關於協變逆變,SolidMango的解釋是比較可取的。有了協變,比如,在需要返回IEnumerable<object>類型的時候,可以使用IEnmerable<string>來替代;有了逆變,比如,在需要接收IComparable<string>類型形參方法中,可以使用IComparable<obj ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...