基于vs和C#的WPF应用之动画5---变大矩形

1.添加Blend包

 

2.标签引入
xmlns:ed="http://schemas.microsoft.com/expression/2010/drawing"
 3.设计矩形样式
 <Style x:Key="rec" TargetType="Rectangle">
    <Setter Property="Width" Value="10"/>
    <Setter Property="Height" Value="30"/>
    <Setter Property="Fill" Value="#f1404b"/>
 </Style>
4.设置动画故事板
 <Storyboard x:Key="fifth_sb" RepeatBehavior="Forever" Storyboard.TargetProperty="Height">
                <DoubleAnimation Storyboard.TargetName="rec1" To="50" BeginTime="0:0:0.0" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec2" To="50" BeginTime="0:0:0.2" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec3" To="50" BeginTime="0:0:0.4" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec4" To="50" BeginTime="0:0:0.6" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec5" To="50" BeginTime="0:0:0.8" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
            </Storyboard>
            
5.设置缓动函数
<PowerEase x:Key="powerEase" Power="3" EasingMode="EaseInOut"/>
6.设置触发器启动动画
<Grid.Triggers>
  <EventTrigger RoutedEvent="Loaded">
  <BeginStoryboard Storyboard="{StaticResource fifth_sb}"/>
  </EventTrigger>
</Grid.Triggers>

7.整体

<Window x:Class="Animate2.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid Background="White" HorizontalAlignment="Center">
        <Grid.Resources>
            <Style x:Key="rec" TargetType="Rectangle">
                <Setter Property="Width" Value="10"/>
                <Setter Property="Height" Value="30"/>
                <Setter Property="Fill" Value="#f1404b"/>
            </Style>
            <PowerEase x:Key="powerEase" Power="3" EasingMode="EaseInOut"/>
            <Storyboard x:Key="fifth_sb" RepeatBehavior="Forever" Storyboard.TargetProperty="Height">
                <DoubleAnimation Storyboard.TargetName="rec1" To="50" BeginTime="0:0:0.0" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec2" To="50" BeginTime="0:0:0.2" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec3" To="50" BeginTime="0:0:0.4" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec4" To="50" BeginTime="0:0:0.6" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
                <DoubleAnimation Storyboard.TargetName="rec5" To="50" BeginTime="0:0:0.8" Duration="0:0:0.5" EasingFunction="{StaticResource powerEase}" AutoReverse="True"/>
            </Storyboard>
            
        </Grid.Resources>
        <Grid.Triggers>
            <EventTrigger RoutedEvent="Loaded">
                <BeginStoryboard Storyboard="{StaticResource fifth_sb}"/>
            </EventTrigger>
        </Grid.Triggers>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="15"/>
            <ColumnDefinition Width="15"/>
            <ColumnDefinition Width="15"/>
            <ColumnDefinition Width="15"/>
            <ColumnDefinition Width="15"/>
        </Grid.ColumnDefinitions>
        <Label Content="Loading"
           FontSize="18"
           FontFamily="Times New Roman"
           Foreground="#252c41"
           FontWeight="Bold"
           Grid.ColumnSpan="5"
           VerticalContentAlignment="Center"
           HorizontalContentAlignment="Center"
           Margin="0,100,0,0"/>
        <Rectangle Name="rec1" Grid.Column="0" Style="{StaticResource rec}"/>
        <Rectangle Name="rec2" Grid.Column="1" Style="{StaticResource rec}"/>
        <Rectangle Name="rec3" Grid.Column="2" Style="{StaticResource rec}"/>
        <Rectangle Name="rec4" Grid.Column="3" Style="{StaticResource rec}"/>
        <Rectangle Name="rec5" Grid.Column="4" Style="{StaticResource rec}"/>
    </Grid>

</Window>

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编写基于WPF的桌面应用——Todo,是一个非常有趣且具有挑战性的任务。WPF是一种用于创建桌面应用程序的技术,它提供了丰富的用户界面元素和MVVM(模型-视图-视图模型)模式,使开发人员能够创建美观且响应式的应用程序。 首先,在WPF中创建Todo应用的用户界面会更加直观和灵活。可以使用各种控件和布局,如列表框、按钮、文本框等,来设计Todo列表的显示和编辑界面。还可以添加复选框来标记已完成的任务,使用滚动视图以处理较长的任务列表,并设计一致的样式和颜色方案以提升用户体验。 其次,在WPF中实现Todo应用的功能也相对简单。可以创建一个Todo类来表示单个任务,包含任务标题、描述、截止日期等属性,并在界面中创建一个列表来显示所有的任务。用户可以通过输入框和按钮,添加、修改或删除任务。可以使用数据绑定机制将任务数据与界面元素实时同步,并借助WPF的命令系统实现任务操作的逻辑。此外,还可以使用数据验证机制对任务的属性进行验证,以确保输入的合法性。 另外,WPF还提供了强大的样式和模板功能,使开发人员能够轻松地对界面进行自定义。可以根据个人喜好和应用的特点,设计各种不同的主题和样式,使Todo应用拥有独特而美观的外观。 总之,编写基于WPF的桌面应用Todo是一项有趣且具有挑战性的任务。借助WPF丰富的用户界面元素和强大的功能,我们可以创造出一个美观、功能完善的Todo应用,提升用户体验并提高工作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值