• WPF程序给按钮增加不同状态的图片


    首先我们在资源里添加几个图片,Up,Over和Down状态。
    然后我们创建一个Style。默认我们的背景设置成Up

    然后在Triggers里添加代码,当Property:IsMouseOver为True的时候更换成Over;当Property:IsPressed为True的时候更换成Down;

    这样就可以了。代码如下:

    <Window.Resources>
        
        <ImageBrush  x:Key="btnCloseUp" ImageSource="/source/guanbi.png"></ImageBrush>
        <ImageBrush  x:Key="btnCloseOver" ImageSource="/source/guanbi1.png"></ImageBrush>
        <ImageBrush  x:Key="btnCloseDown" ImageSource="/source/guanbi1 1.png"></ImageBrush>
        
        <Style x:Key="btnCloseStyle" TargetType="{x:Type Button}">
            <Setter Property="Background" Value="{StaticResource btnCloseUp}"/>
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="{x:Type Button}">
                        <Border x:Name="button"
                        BorderThickness="0"
                        Background="{TemplateBinding Background}"
                                
                        SnapsToDevicePixels="True" IsEnabled="False">
                        </Border>
                        <ControlTemplate.Triggers>
                            <Trigger Property="IsMouseOver" Value="True">
                                <Setter Property="Background" TargetName="button" Value="{StaticResource btnCloseOver}"></Setter>
                            </Trigger>
    
                            <Trigger Property="IsPressed"  Value="True">
                                <Setter Property="Background" TargetName="button" Value="{StaticResource btnCloseDown}"></Setter>
                            </Trigger>
    
                        </ControlTemplate.Triggers>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
        
    
    </Window.Resources>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    当然如果需要不可用的时候显示成灰色,可以添加其他的状态:

    <Trigger Property="IsEnabled"  Value="False">
        <Setter Property="Background" TargetName="button" Value="{StaticResource btnUpdateImgDisable}"></Setter>
    </Trigger>
    
    • 1
    • 2
    • 3

    效果如图:
    请添加图片描述

  • 相关阅读:
    解决dockerfile创建镜像时pip install报错的bug
    【mmdetection代码解读 3.x版本】FPN层的解读
    DarkGate恶意软件通过消息服务传播
    jmeter,性能测试,Locust
    【Java】基于SpringBoot创建Web页面并热更新
    深入探究Python多进程编程:Multiprocessing模块基础与实战【第98篇—Multiprocessing模块】
    Spring Boot中添加Thymeleaf模板
    Vertica常用的sql
    Vue页面结构
    WSL和双系统Ubuntu的CPU性能差异
  • 原文地址:https://blog.csdn.net/thinbug/article/details/134414519