WPF修改控件颜色

5 篇文章 0 订阅

前言

刚接触WPF不久,其中在用到修改WPF控件颜色的时候,根据网上的好多方法都尝试了一遍,发现并没有起到什么效果,所以就试着直接绑定字符串类型的属性,内容是颜色代码?反而起到了很好的效果,下边是我的代码展示。

前端代码

<Grid>
    <Button Content="btn_1" FontSize="60" Foreground="{Binding ForeColor}" Background="{Binding BackColor}" Click="Button_Click"></Button>
</Grid>

后台代码

这里因为要实现前后台绑定动态更新,所以实现了INotifyPropertyChanged接口,并声明了Set()方法。

public partial class MainWindow : Window, INotifyPropertyChanged
{
    private string foreColor;
    private string backColor;

    public string ForeColor
    {
        get { return foreColor; }
        set { foreColor = value;Set(); }
    }
    public string BackColor
    {
        get { return backColor; }
        set { backColor = value;Set(); }
    }

    public MainWindow()
    {
        InitializeComponent();
        this.DataContext = this;
    }

    public event PropertyChangedEventHandler? PropertyChanged;

    private void Button_Click(object sender, RoutedEventArgs e)
    {
        ForeColor = "#FFFFFF";
        BackColor = "#00FF00";
    }

    private void Set([CallerMemberName]string obj="")
    {
        if(PropertyChanged!=null)
            PropertyChanged(this, new PropertyChangedEventArgs(obj));
    }
}

结果显示

结果显示

后言

这样做可能不是很合适,如果大佬们有其他的想法,请在评论区给我些指导

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF 中,可以通过修改控件的 Style 来自定义控件的禁用样式。以下是一个简单的示例: ```xml <Window.Resources> <SolidColorBrush x:Key="DisabledBackgroundBrush" Color="#EEE" /> <SolidColorBrush x:Key="DisabledForegroundBrush" Color="#888" /> <Style x:Key="CustomButtonStyle" TargetType="Button"> <Setter Property="Background" Value="Blue" /> <Setter Property="Foreground" Value="White" /> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="Button"> <Border Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Padding="{TemplateBinding Padding}"> <ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" /> </Border> <ControlTemplate.Triggers> <Trigger Property="IsEnabled" Value="False"> <Setter Property="Background" Value="{StaticResource DisabledBackgroundBrush}" /> <Setter Property="Foreground" Value="{StaticResource DisabledForegroundBrush}" /> </Trigger> </ControlTemplate.Triggers> </ControlTemplate> </Setter.Value> </Setter> </Style> </Window.Resources> <Grid> <Button Content="Click me" Style="{StaticResource CustomButtonStyle}" /> </Grid> ``` 在此示例中,我们创建了一个名为 `CustomButtonStyle` 的样式,并为其设置了默认的背景和前景颜色。然后,在控件模板中,我们使用一个 Border 来包装按钮的内容,并设置了一些绑定属性。在触发器中,我们检查控件的 `IsEnabled` 属性是否为 False,并使用自定义颜色来设置背景和前景。注意,我们使用了一个静态资源来定义禁用时的颜色,这样我们就可以在应用程序中的任何地方重复使用这些颜色。 希望这个例子可以帮助到你!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值