WPF|如何在 WPF 中設計漂亮的社交媒體信息儀表板

1. 效果展示

先來直接欣賞效果:

a6fd40c19ce793c367bace28b0067a71.gif

2. 準備

創建一個WPF工程,比如站長使用 .NET 7[1] 創建名為 Dashboard3 的WPF項目,添加一些圖片資源,項目目錄如下:

9ef115b47c342151413e310cec8449bb.png

2.1 圖片資源

可在網站 iconfont[2] 下載 關閉、最小化 圖標,用于窗口右上角顯示:

8a81c506cccc38e5d8095d4c237f0d23.gif

有看到美女圖片沒?在百度圖片或者谷歌圖片下載,比如 泰勒·斯威夫特 ,用于界面展示一個人的頭像:

672861b2f0d121a9304dec0ad2474e46.gif

2.2 字體圖標Nuget包:FontAwesome.WPF,該包提供一些圖標字體:

<PackageReference?Include="FontAwesome.WPF"?Version="4.7.0.9"?/>
bbc159b7f3ce23e9263c9ab45762ea7e.gif

編譯時,此包有如下提示:

已使用“.NETFramework,Version=v4.6.1, .NETFramework,Version=v4.6.2, .NETFramework,Version=v4.7, .NETFramework,Version=v4.7.1, .NETFramework,Version=v4.7.2, .NETFramework,Version=v4.8”而不是項目目標框架“net7.0-windows7.0”還原包“FontAwesome.WPF 4.7.0.9”。此包可能與項目不完全兼容。

有.NET Core版本的字體圖標庫推薦嗎?可在下面留言,謝謝,這里不影響使用。

3. 簡單介紹

重點提及界面幾個地方:

8cefe60d2c66b0b486def87559d91f93.png

3.1 水平菜單

4b94fd9414493363467faa06201a7331.gif

如上圖,水平菜單是幾個TextBlox標簽,默認設置了字體的透明度為0.7,鼠標懸浮時設置為1:

<StackPanel?Orientation="Horizontal"?HorizontalAlignment="Left"><TextBlock?Text="分析"?Opacity="1"?Style="{StaticResource?menuTitle}"?/><TextBlock?Text="排行榜"?Style="{StaticResource?menuTitle}"?/><TextBlock?Text="實時"?Style="{StaticResource?menuTitle}"?/><TextBlock?Text="趨勢"?Style="{StaticResource?menuTitle}"?/><TextBlock?Text="最喜歡的"?Style="{StaticResource?menuTitle}"?/>
</StackPanel>
<Style?x:Key="menuTitle"?TargetType="TextBlock"><Setter?Property="Margin"?Value="0?0?25?0"?/><Setter?Property="FontSize"?Value="16"?/><Setter?Property="Opacity"?Value="0.7"?/><Setter?Property="Foreground"?Value="#FFFFFF"?/><Style.Triggers><Trigger?Property="IsMouseOver"?Value="True"><Setter?Property="Opacity"?Value="1"?/></Trigger></Style.Triggers>
</Style>

3.2 豎直菜單

c63db8c8f5e1406dee3b6f69fc8ae6f1.gif

如上圖,豎直菜單是幾個按鈕,按鈕內容填充了字體圖標和文字,設置一些效果樣式:

<Button?Style="{StaticResource?menuButton}"?Margin="0?10?0?0"?Background="#AC0F0F"?Foreground="#FFFFFF"><StackPanel><fa:ImageAwesome?Icon="Home"?Style="{StaticResource?menuButtonIcon}"?/><TextBlock?Text="儀表盤"?Style="{StaticResource?menuButtonText}"?/></StackPanel>
</Button>
<Style?x:Key="menuButton"?TargetType="{x:Type?Button}"><Setter?Property="Margin"?Value="0?7?0?0"?/><Setter?Property="FontSize"?Value="14"?/><Setter?Property="Width"?Value="100"?/><Setter?Property="Height"?Value="90"?/><Setter?Property="Background"?Value="Transparent"?/><Setter?Property="Foreground"?Value="#a9a9a9"?/><Setter?Property="FocusVisualStyle"?Value="{x:Null}"?/><Setter?Property="Template"><Setter.Value><ControlTemplate?TargetType="{x:Type?Button}"><Border?Background="{TemplateBinding?Background}"?CornerRadius="15"?Padding="15"><ContentPresenter?HorizontalAlignment="Center"?VerticalAlignment="Center"?/></Border></ControlTemplate></Setter.Value></Setter><Style.Triggers><Trigger?Property="IsMouseOver"?Value="True"><Setter?Property="Background"?Value="#AC0F0F"?/><Setter?Property="Foreground"?Value="#FFFFFF"?/></Trigger><Trigger?Property="IsMouseCaptured"?Value="True"><Setter?Property="Background"?Value="#921C1B"?/><Setter?Property="Foreground"?Value="#FFFFFF"?/></Trigger></Style.Triggers>
</Style><Style?x:Key="menuButtonIcon"?TargetType="fa:ImageAwesome"><Setter?Property="Foreground"?Value="{Binding?Path=Foreground,?RelativeSource={RelativeSource?FindAncestor,?AncestorType={x:Type?Button}}}"?/><Setter?Property="Width"?Value="20"?/><Setter?Property="Height"?Value="20"?/>
</Style><Style?x:Key="menuButtonText"?TargetType="TextBlock"><Setter?Property="Margin"?Value="0?7?0?0"?/>
</Style>

3.3 部分圖片和字體圖標

這個就不多說了,上面的代碼也有字體圖標的使用。

4. 結尾

這個面板的效果個人感覺很漂亮,由基本的TextBlockButton、字體圖標、圖片等組合、排版布局就能做到很多效果,有興趣可以看看作者視頻(非常推薦),以及下方給出的源碼倉庫鏈接:

參考:

  • 油管視頻作者:C# WPF UI Academy[3]

  • 油管視頻:C# WPF UI | How to Design Beautiful Social Media Info Dashboard in WPF[4]

  • 參考代碼:WPF-Social-Media-Info-Dashboard[5]

本文代碼:Dashboard3[6]

參考資料

[1]

.NET 7: https://dotnet.microsoft.com/zh-cn/

[2]

iconfont: https://www.iconfont.cn/

[3]

C# WPF UI Academy: https://www.youtube.com/channel/UCtVawNW7C2t6AX1vex6a_vw

[4]

C# WPF UI | How to Design Beautiful Social Media Info Dashboard in WPF: https://www.youtube.com/watch?v=ZqEj7BcXE9M

[5]

WPF-Social-Media-Info-Dashboard: https://github.com/sajjad-z/WPF-Social-Media-Info-Dashboard

[6]

Dashboard3: https://github.com/dotnet9/TerminalMACS.ManagerForWPF/tree/master/src/WPFDesignDemos/Dashboard3

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/287574.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/287574.shtml
英文地址,請注明出處:http://en.pswp.cn/news/287574.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CentOS 設置服務開機啟動的方法

為什么80%的碼農都做不了架構師&#xff1f;>>> CentOS設置服務開機啟動的兩種方法 1、利用 chkconfig 來配置啟動級別 在CentOS或者RedHat其他系統下&#xff0c;如果是后面安裝的服務&#xff0c;如httpd、mysqld、postfix等&#xff0c;安裝后系統默認不會自動啟…

【ArcGIS風暴】水文分析模塊實驗:山脊線和山谷線提取

實驗平臺:ArcGIS 9.3實驗目的:學習和掌握山脊線和山谷線提取的原理及方法實驗要求:利用ArcGIS水文分析模塊提取樣區的山脊線和山谷線實驗數據:Ex1實驗步驟:1.正負地形的提取 (1)打開Arcmap,加載數據EX1,如圖 (2)平滑處理(均值濾波)。加載Spatial Analyst模塊,單擊…

[python opencv 計算機視覺零基礎到實戰] 五、對象追蹤

一、學習目標 了解為什么色彩空間的轉換那么重要了解opencv中進行對象跟蹤的方法 目錄 [python opencv 計算機視覺零基礎到實戰] 一、opencv的helloworld [【python opencv 計算機視覺零基礎到實戰】二、 opencv文件格式與攝像頭讀取] 一、opencv的helloworld [[python op…

Android之用glide加載gif圖片靜態展示

1 問題 圖片是gif動圖&#xff0c;我們需要獲取第一幀的靜態圖片并且展示。 2 解決辦法 public void changeGifToPicture(NonNull Context context, NonNull String url, NonNull ImageView imageView) {Glide.with(context).asBitmap().load(url).into(new BitmapImageViewTa…

flex java框架_fleXive——JavaEE框架

fleXive——JavaEE框架fleXive是一個開源的JavaEE框架&#xff0c;基于LGPL許可證&#xff0c;最新版本3.0RC1&#xff0c;它基于EJB3&#xff0c;并帶有補充的JSF組件庫&#xff0c;具有靈活性和可擴展性。它主要致力于企業級(Enterprise-scale)內容建模、存儲和檢索&#xff…

【ArcGIS風暴】在ArcGIS中實現將一個圓16等分

本文實現在ArcGIS中畫一個圓,然后將其16等分。 步驟一:生成圓(多邊形圖層) (1)創建一個點圖層(圖名Center),如果需要精確定位該點,建議通過輸入坐標點的方式來創建,這一步比較簡單,不再詳述; (2)利用Buffer命令創建緩沖區(圖名Circle_2km),因為要處理的對象…

iOS UIViewContentMode 使用詳解

iOS在處理圖片的時候,會出現拉伸變形的情況,可以根據UIViewContentMode的屬性,來控制圖片 UIViewContentMode包含以下枚舉值 UIViewContentModeScaleToFill :拉伸自適應填滿整個視圖 UIViewContentModeScaleAspectFit :自適應打下比例顯示 UIViewContentModeScaleA…

二進制安裝mariadb-10.2.8

centos7.3上二進制安裝mariadb-10.2.8-linux-x86_641、查看是否安裝mariadbrpm -qa mariadb*如果已經安裝就卸載。2、下載mariadb最新版本yum info mariadb官網地址&#xff1a;http://mariadb.org 下載&#xff1a;mariadb-10.2.8-linux-x86_64.tar.gz3、創建mysql用戶rpm 安…

MiniAPI:.NET7 Preview4之MiniAPI更新總覽

一覺醒來&#xff0c;發現微軟帶來了.NET7 Preview4的更新&#xff0c;本次更新關于MiniAPI的還不少&#xff0c;難以掩飾的喜悅心情&#xff0c;促使我盡快把這個消息分享給大家&#xff0c;那下來我們看一下一共帶來了哪些關于MiniAPI的更新&#xff1a;返回值帶來了TypedRes…

[python opencv 計算機視覺零基礎到實戰] 六、圖像運算

一、學習目標 了解opencv中圖像運算的方法了解opencv中圖像運算的運用 如有錯誤歡迎指出~ 二、了解OpenCV中圖像運算的運用 目錄 [python opencv 計算機視覺零基礎到實戰] 一、opencv的helloworld [【python opencv 計算機視覺零基礎到實戰】二、 opencv文件格式與攝像頭…

Android之SubsamplingScaleImageView加載長圖不能放縮問題

1 問題 第三方開源框架用了這個第三方開源框架&#xff08;SubsamplingScaleImageView&#xff09;加載長圖&#xff0c;但是源代碼在有些手機上面不能進行放縮。 private void displayLongPic(Uri uri, SubsamplingScaleImageView longImg) {longImg.setQuickScaleEnabled(tr…

java barrier_Java并發類CyclicBarrier方法詳解

Cyclic是周期的意思&#xff0c;Barrier是關卡的意思。CyclicBarrier不僅有CountDownLatch的功能&#xff0c;還可以實現屏障等待&#xff0c;即階段性同步。因此適用于&#xff0c;需要循環地實現線程一起做任務的目標。CyclicBarrier允許一組線程相互等待&#xff0c;直到到達…

【ArcGIS風暴】實驗:公路建設成本的計算

實驗平臺:ArcGIS 9.3實驗目的:學習和掌握公路建設成本的計算方法實驗要求:熟練掌握如何生成通行成本層、計算成本距離,并學會計算最佳路徑,且對成本距離與直線距離進行比較。實驗數據:ArcEx7實驗步驟:生成通行成本層1.打開Arcmap,加載數據ArcEX7,如圖 2.執行spatial …

[leetcode]347. Top K Frequent Elements

Given a non-empty array of integers, return the k most frequent elements. For example,Given [1,1,1,2,2,3] and k 2, return [1,2]. Note: You may assume k is always valid, 1 ≤ k ≤ number of unique elements.Your algorithms time complexity must be better th…

合并Spark社區代碼的正確姿勢

原創文章&#xff0c;轉載請保留出處 最近剛剛忙完Spark 2.2.0的性能測試及Bug修復&#xff0c;社區又要發布2.1.2了&#xff0c;國慶期間剛好有空&#xff0c;過了一遍2.1.2的相關JIRA&#xff0c;發現有不少重要修復2.2.0也能用上&#xff0c;接下來需要將有用的PR合到我們內…

.NET 中 GC 的模式與風格

垃圾回收&#xff08;GC&#xff09;是托管語言必備的技術之一。GC 的性能是影響托管語言性能的關鍵。我們的 .NET 既能寫桌面程序 (WINFROM , WPF) 又能寫 web 程序 (ASP.NET CORE)&#xff0c;甚至還能寫移動端程序。。。不同使用場景的程序對 GC 的風格也有不同的要求&#…

(轉)java中的 | ^ 分別是什么?

|是按位或 ^是按位抑或 &是按位與比如有兩個數 int x 5;int y 11;System.out.println(x|y);System.out.println(x&y);System.out.println(x^y);結果是15&#xff0c; 1 &#xff0c;14 過程 x5 (0101二進制) y11(1011二進制) x|y 1111 15 x&y 0001 1 x…

[python opencv 計算機視覺零基礎到實戰] 七、邏輯運算與應用

一、學習目標 了解opencv中圖像的邏輯運算了解opencv中邏輯運算的應用 目錄 [python opencv 計算機視覺零基礎到實戰] 一、opencv的helloworld [【python opencv 計算機視覺零基礎到實戰】二、 opencv文件格式與攝像頭讀取] 一、opencv的helloworld [[python opencv 計算機…

Android之如何判斷當前是阿拉伯布局的方法

1 問題 判斷當前是不是阿拉伯布局的方法 2 幾種判斷方法 @SuppressLint("NewApi")public static boolean isLayoutRtl(View view, Resources res) {if (res == null || view == null) return false;Locale curLocale = res.getConfiguration().locale;//如果當前語言…

【ArcGIS風暴】數字化實驗:數據采集與編輯完整操作流程

一.實驗平臺:ArcGIS 9.3 二.實驗目的:對甘肅省的十四個地級市進行圖像配準、數據采集。 三.實驗要求:掌握地理數據采集方法,圖像配準及坐標投影,選擇主要的點、線、面進行投影。 四.實驗數據:甘肅省統計數據,甘肅省行政區劃圖。 (一).影像配準 第一步:加載…