WPF 自定义窗口关闭按钮

关闭图标设计主要涉及主要知识点:

1、Path,通过Path来画线。当然一般水平、竖直也是可以用Rectangle/Border之类的替代

     一些简单的线条图标用Path来做,还是很方便的。

2、简单的动画,Animation用法

Button样式如下:

    <Button x:Name="BtnClose" Click="BtnClose_OnClick">
        <Button.Template>
            <ControlTemplate TargetType="Button">
                <Grid>
                    <Grid x:Name="Uc_Grid" VerticalAlignment="Center" Height="25" Width="25">
                        <Path x:Name="Uc_Path1" Stroke="DodgerBlue" StrokeThickness="4" Data="M0,0 L20,20" VerticalAlignment="Center" HorizontalAlignment="Center"></Path>
                        <Path x:Name="Uc_Path2" Stroke="DodgerBlue" StrokeThickness="4" Data="M20,0 L0,20" VerticalAlignment="Center" HorizontalAlignment="Center"></Path>
                        <Grid.RenderTransform>
                            <RotateTransform x:Name="Uc_Transform" Angle="0" CenterY="12.5" CenterX="12.5"></RotateTransform>
                        </Grid.RenderTransform>
                    </Grid>
                    <ContentPresenter Content="{TemplateBinding Content}" HorizontalAlignment="{TemplateBinding HorizontalAlignment}"></ContentPresenter>
                </Grid>
                <ControlTemplate.Triggers>
                    <Trigger Property="IsMouseOver" Value="True">
                        <Setter TargetName="Uc_Path1" Property="Data" Value="M0,0 L22,22"></Setter>
                        <Setter TargetName="Uc_Path2" Property="Data" Value="M22,0 L0,22"></Setter>
                    </Trigger>
                    <Trigger Property="IsPressed" Value="True">
                        <Setter TargetName="Uc_Path1" Property="Data" Value="M0,0 L24,24"></Setter>
                        <Setter TargetName="Uc_Path2" Property="Data" Value="M24,0 L0,24"></Setter>
                    </Trigger>
                    <EventTrigger RoutedEvent="MouseEnter">
                        <BeginStoryboard HandoffBehavior="SnapshotAndReplace">
                            <Storyboard TargetName="Uc_Transform" TargetProperty="Angle">
                                <DoubleAnimation From="0" To="90" Duration="0:0:0.1"></DoubleAnimation>
                            </Storyboard>
                        </BeginStoryboard>
                    </EventTrigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Button.Template>
    </Button>
View Code

 

转载于:https://www.cnblogs.com/kybs0/p/5855023.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF (Windows Presentation Foundation) 的 DatePicker 控件可以通过自定义样式来改变其外观和行为。要自定义 DatePicker 的样式,可以按照以下步骤进行操作: 1. 创建一个新的 WPF 项目,并在 XAML 文件中添加一个 DatePicker 控件。 2. 打开 DatePicker 控件的样式模板,可以通过在 XAML 中使用 `<DatePicker.Style>` 标签来指定样式。 3. 在样式模板中,可以自定义 DatePicker 的外观元素,比如边框、背景、按钮样式等。可以使用 XAML 标签来控制这些元素的属性和样式。 4. 若要自定义 DatePicker 的日期选择器弹出窗口的样式,可以在样式模板中添加 `<DatePicker.CalendarStyle>` 标签,并在其中定义日期选择器的样式。 5. 可以通过修改样式模板中的触发器和视觉状态来改变 DatePicker 在不同状态下的外观和行为。例如,可以自定义 DatePicker 在鼠标悬停或获取焦点时的效果。 6. 可以通过在样式模板中添加触发器或行为来定义 DatePicker 的交互行为。例如,可以添加一个触发器来在选择日期后自动关闭日期选择器弹出窗口。 7. 调整样式模板和元素的属性来满足个性化需求。可以更改颜色、字体、大小等属性,以及添加自定义绑定和动画效果。 自定义 DatePicker 的样式需要了解一些基本的 WPF 样式模板和控件元素的知识,以便能够正确地修改和调整样式。可以参考 MSDN 或其他 WPF 相关的教程、博客和文档来获取更多关于自定义样式的详细信息和示例代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值