WPF入门教学十八 动画入门

news/2024/9/29 2:33:55/

WPF(Windows Presentation Foundation)是微软推出的一种用于创建Windows客户端应用程序的用户界面框架。WPF 提供了丰富的动画支持,可以通过XAML或者代码来实现各种动画效果。以下是一个简单的WPF动画入门教学,我们将使用XAML来创建一个简单的淡入淡出动画。

1. 创建一个新的WPF项目

首先,打开Visual Studio并创建一个新的WPF应用程序项目。

2. 添加动画到XAML

在MainWindow.xaml文件中,我们可以添加一个Button和一个TextBlock,并为TextBlock设置一个淡入淡出的动画效果。

 
<Window x:Class="WpfApp1.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"Title="WPF Animation Example" Height="350" Width="525"><Grid><Button Content="Animate" HorizontalAlignment="Center" VerticalAlignment="Top" Margin="0,50,0,0" Click="Button_Click"/><TextBlock x:Name="AnimatedText" Text="Hello, WPF Animation!" FontSize="24" HorizontalAlignment="Center" VerticalAlignment="Center"/></Grid>
</Window>

3. 编写动画代码

在MainWindow.xaml.cs文件中,我们需要编写代码来启动动画。

 
using System.Windows;
using System.Windows.Media.Animation;namespace WpfApp1
{public partial class MainWindow : Window{public MainWindow(){InitializeComponent();}private void Button_Click(object sender, RoutedEventArgs e){DoubleAnimation fadeOut = new DoubleAnimation(1.0, 0.0, new Duration(TimeSpan.FromSeconds(1)));DoubleAnimation fadeIn = new DoubleAnimation(0.0, 1.0, new Duration(TimeSpan.FromSeconds(1)));Storyboard sb = new Storyboard();sb.Children.Add(fadeOut);sb.Children.Add(fadeIn);Storyboard.SetTarget(fadeOut, AnimatedText);Storyboard.SetTarget(fadeIn, AnimatedText);Storyboard.SetTargetProperty(fadeOut, new PropertyPath(Brush.OpacityProperty));Storyboard.SetTargetProperty(fadeIn, new PropertyPath(Brush.OpacityProperty));fadeOut.Completed += (s, _) => sb.BeginAnimation(Brush.OpacityProperty, fadeIn);sb.Begin();}}
}

4. 运行程序

现在,当你运行程序并点击"Animate"按钮时,TextBlock应该会执行一个淡入淡出的动画效果。

解释

  • DoubleAnimation 是WPF中用于创建数值变化的动画类。
  • Storyboard 是用来管理一组动画的容器。
  • Target 和 TargetProperty 用于指定动画作用的对象和属性。
  • Completed 事件用于在动画完成时触发后续动作。

这个例子展示了如何在WPF中使用XAML和C#代码来创建简单的动画效果。WPF的动画系统非常强大,可以创建复杂的交互式用户界面。你可以进一步探索WPF的StoryboardAnimation类和其他相关功能来创建更加丰富和动态的用户体验。


http://www.ppmy.cn/news/1531736.html

相关文章

ubuntu 安裝 Poetry 示例

ubuntu 安裝 Poetry 示例 一、前言 poetry 是一个命令行工具&#xff0c;安装之后就可以使用 poetry 指令。可以将其安装全局环境或者是虚拟环境&#xff0c;我推荐安装在全局环境&#xff0c;这样在后面使用时不需要单独激活虚拟环境。 &#xff08;1&#xff09;安装 Poet…

[单master节点k8s部署]23.构建EFK日志收集平台(二)

部署elasticsearch集群 已经完成的工作&#xff1a;创建存储。首先配置了nfs存储提供商&#xff08;nfs-deployment.yaml&#xff09;&#xff0c;然后通过创建存储类&#xff08;storageclass.yaml&#xff09;来将nfs服务器与存储类绑定&#xff1a; [rootmaster 31efk]# c…

CorePress Pro 网站加载慢 WordPress

一般来说是你用了「CorePress天气模块」 解决方案&#xff1a;这个插件从你右侧边栏里删掉就可以了&#xff08;上方的图中已经是删掉后的效果了&#xff09; 寻找加载时间长的原因&#xff1a; 谷歌浏览器F12->网络->打开录制->ShiftF5 得出结论&#xff1a;和风天气…

【Linux】初始进程

目录 基本概念 PCB task_struct task_struct内容分类 组织进程 查看进程 查看正在运行的进程信息 获取pid和ppid 创建子进程 基本概念 一个已经加载到内存中的程序&#xff0c;叫做进程&#xff0c;正在运行的程序&#xff0c;叫做进程&#xff0c;进程是担当分配系统…

C++学习笔记(35)

四十三、希尔排序 示例&#xff1a; #include <iostream> using namespace std; // 对希尔排序中的单个组进行排序。 // arr-待排序的数组&#xff0c;len-数组总的长度&#xff0c;num-小组的编号&#xff08;从 0 开始&#xff09;&#xff0c;step-分组的步长&#xf…

【Redis 源码】1下载与源码编译

1 下载地址 GitHub - redis/redis-hashes: Redis tarball SHA1 hashes 本次下载的是6.2.5 版本 2 编译 在 redis目录下执行make make CFLAGS"-g -O0"“-O0” 参数表示告诉编译器不要优化代码&#xff0c;防止你在 Debug 的时候&#xff0c; IDE 里面的 Redis 源码…

R包:ggheatmap热图

加载R包 # devtools::install_github("XiaoLuo-boy/ggheatmap")library(ggheatmap) library(tidyr)数据 set.seed(123) df <- matrix(runif(225,0,10),ncol 15) colnames(df) <- paste("sample",1:15,sep "") rownames(df) <- sapp…

给Ubuntu虚拟机设置静态IP地址(固定IP)

查看 为Ubuntu虚拟机配置静态IP地址&#xff08;固定IP&#xff09;的方法经过亲自测试&#xff0c;已被证实有效。 这里你记得网关就可以了&#xff0c;等下要用 查看配置前的网络信息 ifconfig 查看网关 route -n 配置 配置网络文件 cd /etc/netplan/ ls 查看自己的文件的名…