在 WPF 啟動界面中心加載 GIF 動圖

在 WPF 啟動界面中心加載 GIF 動圖

在 WPF 啟動界面中心加載 GIF 動圖可以通過多種方式實現。下面我將提供一個完整的解決方案,包括使用第三方庫和純 WPF 實現兩種方法。

方法一:使用 WpfAnimatedGif 庫(推薦)

這是最簡單可靠的方法,使用專門處理 GIF 動畫的庫。

實現步驟:

  1. 安裝 NuGet 包

    Install-Package WpfAnimatedGif
    
  2. 創建啟動窗口 (SplashScreen.xaml)

<Window x:Class="YourNamespace.SplashScreen"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:gif="http://wpfanimatedgif.codeplex.com"WindowStyle="None" AllowsTransparency="True"Background="Transparent"WindowStartupLocation="CenterScreen"Width="400" Height="400"><Grid><!-- 背景 --><Border CornerRadius="20" Background="#1E1E1E" Opacity="0.9"BorderBrush="#3F3F46" BorderThickness="1"><!-- 陰影效果 --><Border.Effect><DropShadowEffect BlurRadius="20" ShadowDepth="0" Color="#000000" Opacity="0.5"/></Border.Effect></Border><!-- 中心 GIF 動畫 --><Image x:Name="LoadingGif" gif:ImageBehavior.AnimatedSource="/Assets/loading.gif"gif:ImageBehavior.AutoStart="True"Width="200" Height="200"HorizontalAlignment="Center" VerticalAlignment="Center"/><!-- 狀態文本 --><TextBlock x:Name="StatusText" Text="正在加載..." Foreground="#E0E0E0" FontSize="16"HorizontalAlignment="Center" VerticalAlignment="Bottom"Margin="0,0,0,30"/></Grid>
</Window>
  1. 在代碼中更新狀態文本 (SplashScreen.xaml.cs)
using System.Windows;namespace YourNamespace
{public partial class SplashScreen : Window{public SplashScreen(){InitializeComponent();}// 更新狀態文本的方法public void UpdateStatus(string message){StatusText.Text = message;}}
}
  1. 在 App.xaml.cs 中使用啟動窗口
using System;
using System.Threading.Tasks;
using System.Windows;namespace YourNamespace
{public partial class App : Application{private SplashScreen _splashScreen;protected override void OnStartup(StartupEventArgs e){base.OnStartup(e);// 創建并顯示啟動窗口_splashScreen = new SplashScreen();_splashScreen.Show();// 異步初始化應用Task.Run(() => InitializeApplication()).ContinueWith(t => {// 初始化完成后切換到主界面Dispatcher.Invoke(() => SwitchToMainWindow());}, TaskScheduler.FromCurrentSynchronizationContext());}private void InitializeApplication(){// 更新狀態信息UpdateSplashStatus("正在加載配置...");Task.Delay(800).Wait();UpdateSplashStatus("正在初始化數據庫...");Task.Delay(1200).Wait();UpdateSplashStatus("正在準備界面...");Task.Delay(600).Wait();}private void UpdateSplashStatus(string message){Dispatcher.Invoke(() => {if (_splashScreen != null){_splashScreen.UpdateStatus(message);}});}private void SwitchToMainWindow(){// 創建主窗口var mainWindow = new MainWindow();// 關閉啟動窗口_splashScreen.Close();_splashScreen = null;// 顯示主窗口mainWindow.Show();}}
}
  1. 修改 App.xaml
<Application x:Class="YourNamespace.App"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Startup="Application_Startup"ShutdownMode="OnExplicitShutdown">
</Application>

優化建議

1. 添加淡入淡出效果

在切換窗口時添加平滑的動畫效果:

private void SwitchToMainWindow()
{// 創建主窗口但不立即顯示var mainWindow = new MainWindow();mainWindow.Opacity = 0;// 啟動窗口淡出var fadeOut = new DoubleAnimation(0, TimeSpan.FromSeconds(0.5));fadeOut.Completed += (s, e) => {_splashScreen.Close();_splashScreen = null;// 主窗口淡入mainWindow.Show();var fadeIn = new DoubleAnimation(1, TimeSpan.FromSeconds(0.5));mainWindow.BeginAnimation(Window.OpacityProperty, fadeIn);};_splashScreen.BeginAnimation(Window.OpacityProperty, fadeOut);
}

2. 處理 GIF 資源加載問題

確保 GIF 文件設置為資源:

  1. 在項目資源管理器中右鍵點擊 GIF 文件
  2. 選擇"屬性"
  3. 設置"生成操作"為"Resource"

3. 添加加載進度指示器

<Grid><!-- ... 其他元素 ... --><!-- 圓形進度條 --><ProgressBar x:Name="LoadingProgress" Value="0" Minimum="0" Maximum="100"Height="6" Width="300"HorizontalAlignment="Center" VerticalAlignment="Bottom"Margin="0,0,0,60"Foreground="#0EA5E9"><ProgressBar.Template><ControlTemplate TargetType="ProgressBar"><Grid><Border CornerRadius="3" Background="#3F3F46" BorderThickness="0" Height="6"/><Border CornerRadius="3" Background="#0EA5E9" BorderThickness="0" Height="6"HorizontalAlignment="Left"Width="{TemplateBinding Value}"/></Grid></ControlTemplate></ProgressBar.Template></ProgressBar>
</Grid>

在代碼中更新進度:

// 在 SplashScreen 中添加
public void UpdateProgress(int value)
{LoadingProgress.Value = value;
}// 在 App.xaml.cs 中
private void InitializeApplication()
{UpdateProgress(10);UpdateSplashStatus("正在加載配置...");Task.Delay(800).Wait();UpdateProgress(40);UpdateSplashStatus("正在初始化數據庫...");Task.Delay(1200).Wait();UpdateProgress(80);UpdateSplashStatus("正在準備界面...");Task.Delay(600).Wait();UpdateProgress(100);
}private void UpdateProgress(int value)
{Dispatcher.Invoke(() => {if (_splashScreen != null){_splashScreen.UpdateProgress(value);}});
}

常見問題解決方案

1. GIF 不顯示或不動

  • 確保 GIF 文件路徑正確
  • 檢查 GIF 文件屬性設置為"Resource"
  • 嘗試使用完整資源路徑:pack://application:,,,/YourAppName;component/Assets/loading.gif
  • 確保 GIF 不是單幀圖像

2. 啟動界面位置不居中

  • 設置 WindowStartupLocation="CenterScreen"
  • 確保啟動窗口沒有設置 LeftTop 屬性

3. 背景不透明

  • 確保 AllowsTransparency="True"
  • 設置 Background="Transparent"
  • 移除窗口邊框:WindowStyle="None"

4. 內存泄漏

  • 在關閉窗口時停止動畫:
    protected override void OnClosed(EventArgs e)
    {base.OnClosed(e);// 停止 GIF 動畫if (gifBehavior != null){ImageBehavior.SetAnimatedSource(LoadingGif, null);}// 清除資源LoadingGif.Source = null;LoadingGif = null;
    }
    

5. 多顯示器支持

public SplashScreen()
{InitializeComponent();// 在屏幕中心顯示var screen = System.Windows.Forms.Screen.PrimaryScreen;var screenWidth = screen.Bounds.Width;var screenHeight = screen.Bounds.Height;Left = (screenWidth - Width) / 2;Top = (screenHeight - Height) / 2;
}

總結

在 WPF 啟動界面中心加載 GIF 動畫可以通過以下步驟實現:

  1. 使用 WpfAnimatedGif 庫(推薦)或創建自定義 GIF 控件
  2. 設計透明無邊框的啟動窗口
  3. 將 GIF 放置在窗口中心
  4. 添加狀態文本和進度指示器
  5. 在 App 類中管理啟動窗口的生命周期
  6. 添加動畫效果提升用戶體驗

對于大多數項目,推薦使用 WpfAnimatedGif 庫,因為它簡單可靠且支持完整的 GIF 功能。如果你有特殊需求或不想添加外部依賴,可以使用自定義控件方法。

無論選擇哪種方法,都要注意資源管理和內存釋放,確保啟動窗口關閉后不會留下任何資源占用。

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

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

相關文章

Vue前端路由從入門到精通

目錄 第1章:路由的本質與Vue Router的魅力 1.1 什么是前端路由? 1.2 為什么選擇Vue Router? 1.3 快速上手:安裝與基本配置 1.4 一個小實踐:動態歡迎頁 第2章:路由配置的進階玩法 2.1 命名路由:給路由取個名字 2.2 動態路由的深度挖掘 2.3 嵌套路由:頁面中的頁面…

【Python】SQLAlchemy實現upsert

文章目錄? 通用思路1. 使用 merge() 方法&#xff08;適用于簡單場景&#xff09;2. 使用數據庫特定的 UPSERT 功能&#xff08;推薦用于性能和并發安全&#xff09;&#x1f7e2; PostgreSQL: 使用 on_conflict_do_update&#x1f7e1; MySQL: 使用 ON DUPLICATE KEY UPDATE&…

快速入門SwiftUI

SwiftUI的入門難度稍微有點高&#xff0c;但對于比較熟悉Swift的UIKit老手來說陣痛期大概1周以內&#xff0c;兩周內能達到UIkit的開發效率&#xff0c;個人總結快速入門路徑如下&#xff1a; 第一步 周期&#xff1a;1天 操作&#xff1a;閱讀蘋果官方demo 目的&#xff1a;…

【n8n教程筆記——工作流Workflow】文本課程(第一階段)——1、導航編輯器界面(Navigating the editor UI)介紹

https://docs.n8n.io/courses/ 文章目錄Navigating the Editor UIGetting startedEditor UI settingsLeft-side panelTop barCanvasNodesFinding nodesAdding nodesNode buttonsSummaryNavigating the Editor UI In this lesson you will learn how to navigate the Editor UI…

【Altium Designer2025】電子設計自動化(EDA)軟件——Altium Designer25版保姆級下載安裝詳細圖文教程(附安裝包)

今天給大家帶來精心編寫的Altium Designer2025版下載安裝全流程圖文指南&#xff0c;涵蓋從系統準備到安裝使用的完整過程。 教程嚴格遵循零廣告、純工具向原則&#xff0c;手把手教你如何正確安裝并配置好這款強大的軟件&#xff0c;讓你快速進入電路設計的世界&#xff01; …

智象科技賦能金融、證券行業 IT 運維

一、金融、證券行業 IT 運維現狀剖析 金融、證券行業 IT 系統架構極其復雜&#xff0c;業務對時效性和連續性的要求近乎苛刻&#xff0c;同時安全監管嚴格&#xff0c;這些特點共同催生了諸多運維痛點。 系統架構復雜 &#xff1a;IT 系統包含多個業務系統、數據平臺和網絡架構…

微信小程序服務端快速對接指南(java版)

背景說明 本文檔旨在描述服務端在開發微信小程序時需要對接的小程序接口,以簡要的方式描述對接流程、接口文檔、使用場景。有些接口需要前后端配合,本文主要描述后端接口,對于前端僅輕輕點過。開發語言為Java,但是對接的思路跟語言沒有關系,應該不盡相同; 小程序上手路線…

微信小程序入門實例_____從零開始 開發一個“旅行清單 ”微信小程序

前面的博文中。我們陸續學習與開發了記賬等一些實用實用小程序的開發過程&#xff0c;今天來打造一個適合出行場景的工具 ——“旅行清單小程序”。無論是短途游玩還是長途旅行&#xff0c;它都能幫你梳理需要攜帶的物品&#xff0c;避免遺漏。下面就跟著步驟&#xff0c;一步步…

MySQL主從同步集群(Docker搭建)

以下筆記都是基于黑馬程序員的面試題寫的&#xff1a; Mysql定位慢查詢-CSDN博客 Mysql索引-CSDN博客 MySQL事物相關-CSDN博客 MySQL主從同步集群&#xff08;Docker搭建&#xff09;-CSDN博客 MySQL相關面試問題總結-CSDN博客 主從同步&#xff08;Master-Slave Replicat…

NISP-PTE基礎實操——XSS

pteXSS模擬1 <script> var img document.createElement("img");img.src"http://xxxxx.ceye.io/log?"escape(document.coo kie);document.body.appendChild(img); </script> 重放加Cookie頭 pteXSS模擬2 <script type"text/javasc…

基于網絡爬蟲的在線醫療咨詢數據爬取與醫療服務分析系統,技術采用django+樸素貝葉斯算法+boostrap+echart可視化

摘要 為了發揮互聯網醫療問詢服務平臺在客觀衡量醫療服務質量、進一步分析和挖掘網民評論數據方面的作用&#xff0c;本文完成了互聯網醫療問詢數據抓取與醫療服務質量服務分析平臺的主要模塊應用&#xff0c;如用戶登錄注冊、醫療服務質量數據分析與信息可視化以及用戶情緒識別…

【備忘錄】Ubuntu 配置 NFS

安裝 NFSsudo apt-get install nfs-kernel-server rpcbind啟動 NFSsudo systemctl start nfs-server查看 NFSsudo service nfs-server status

【coze扣子】第1篇:coze快速入門

文章目錄coze扣子Coze優點Coze智能體快速入門1、登錄進入到個人主頁2、創建智能體3、智能體組成部分4、智能體的發布人設與回復邏輯LLM模型配置模型設置生成多樣性(抽象程度)Top P&#xff08;話癆程度&#xff09;重復語句懲罰攜帶上下文輪數最大回復長度技能插件觸發器定時觸…

PyCharm 入門指南:起步學習、開發環境一體

PyCharm 入門指南一、前置準備&#xff1a;為什么選擇 PyCharm&#xff1f; 對于 Python 初學者&#xff0c;PyCharm 是最友好的集成開發環境&#xff08;IDE&#xff09;之一。它通過智能代碼提示、自動糾錯、調試工具、版本控制集成等功能&#xff0c;大幅降低開發門檻。本文…

【Java企業級開發】(六)Java框架技術-Maven和MyBatis

一、Maven 1.1 非Maven項目的缺點 問題一&#xff1a; 項目中的jar包資源需要我們自己從網上下載后&#xff0c;手動導入到項目中使用&#xff0c;不好管理 問題二&#xff1a; jar包版本控制麻煩 1.2 Maven介紹 Maven是使用Java語言編寫的基于項目對象模型&#xff08;POM&am…

學習秒殺系統-頁面優化技術

文章目錄前言頁面緩存URL緩存對象緩存頁面緩存取緩存手動渲染URL緩存對象緩存頁面靜態化&#xff0c;前后端分離&#xff08;常用&#xff09;GET POST區別如何解決超賣&#xff1f;重復賣&#xff1f;&#xff08;簡單版&#xff09;靜態資源優化多個JS/CSS組合&#xff0c;減…

QCC系列顯示交互層的自研技術突破與實踐

在音頻設備智能化進程中&#xff0c;顯示交互的流暢度與兼容性已成為用戶體驗的核心指標。傳統方案中&#xff0c;TFT 彩屏與多語言適配常面臨硬件驅動沖突、功耗失控、字符顯示錯亂等問題。作為高通平臺十年級方案商&#xff0c;騰泰技術在 QCC 系列中聚焦顯示交互層的自研技術…

JMeter 實現 Protobuf 加密解密

一、 .proto文件編譯成.jar文件 相關依賴下載詳見&#xff1a;將 message.proto 編譯成 .jar文件 1.依賴于java編譯環境 2.依賴protoc編譯jar包 編譯目錄 1.創建一個根目錄&#xff1a;protobuf 2.在protobuf下創建build、output、lib、src目錄 lib&#xff1a;放 protobu…

發票識別在費控系統應用剖析

一、發票識別與費控系統的融合價值1.1 解決傳統費控痛點效率瓶頸突破&#xff1a;將人工處理每張發票的5-8分鐘縮短至秒級自動識別準確性飛躍&#xff1a;關鍵字段識別準確率從人工的95%提升至99%以上合規性強化&#xff1a;自動對接稅務系統驗真&#xff0c;虛假發票識別率提升…

Rust實戰:決策樹與隨機森林實現

基于 Rust 實現決策樹(Decision Tree)和隨機森林(Random Forest)的實例 Linfa的基本定義 Linfa是意大利語中“淋巴”(lymph)的意思,在醫學領域指淋巴系統相關的結構或功能。淋巴系統由淋巴管、淋巴結、脾臟等組成,負責免疫防御和體液平衡。 Linfa在生物學中的作用 …