在 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在生物学中的作用 …