c# - WPF 复选框样式更改

标签 c# wpf checkbox wpf-controls

我刚开始使用 WPF,需要复选框的特定功能:

  1. 我想将形状从方框更改为椭圆形。
  2. 此外,应该有颜色变化(绿色 = true,红色 = false)而不是交叉。

背景:我有不同的传感器,想通过这些复选框启用/禁用它们。我也想过用按钮代替复选框,但我认为功能更多的是复选框。

我希望我的描述是可以理解的。是否可以定义这样的样式模板?

亲切的问候

亚历克斯

最佳答案

好的,我终于做到了!在附件中,您可以看到我的解决方案,我对结果感到满意。如果有人有任何意见,请不要犹豫,发表评论。非常感谢您的帮助

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <Style TargetType="CheckBox" x:Key="CircleCheckbox">
        <Setter Property="Cursor" Value="Hand"></Setter>   
        <Setter Property="Content" Value=""></Setter>
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type CheckBox}">                   
                    <Grid>                     
                        <Ellipse x:Name="outerEllipse">
                            <Ellipse.Fill>
                                <RadialGradientBrush>
                                    <GradientStop Offset="0" Color="Red"/>
                                    <GradientStop Offset="0.88" Color="LightCoral"/>
                                    <GradientStop Offset="1" Color="DarkRed"/>
                                </RadialGradientBrush>
                            </Ellipse.Fill>
                        </Ellipse>
                        <Ellipse Margin="10" x:Name="highlightCircle" >
                            <Ellipse.Fill >
                                <LinearGradientBrush >
                                    <GradientStop Offset="0" Color="Green"/>
                                    <GradientStop Offset="0.5" Color="LightGreen"/>
                                    <GradientStop Offset="1" Color="DarkGreen"/>
                                </LinearGradientBrush>
                            </Ellipse.Fill>
                        </Ellipse>
                        <ContentPresenter x:Name="content" HorizontalAlignment="Center" VerticalAlignment="Center"/>
                    </Grid>
                    <ControlTemplate.Triggers>
                        <Trigger Property="IsChecked" Value="True">
                            <Setter TargetName="highlightCircle" Property="Fill">
                                <Setter.Value>
                                    <LinearGradientBrush StartPoint="0.3,0" EndPoint="0.7,1">
                                        <GradientStop Offset="0" Color="Green"/>
                                        <GradientStop Offset="0.5" Color="LightGreen"/>
                                        <GradientStop Offset="1" Color="DarkGreen"/>
                                    </LinearGradientBrush>
                                </Setter.Value>
                            </Setter>
                            <Setter TargetName="outerEllipse" Property="Fill">
                                <Setter.Value>
                                    <RadialGradientBrush>
                                        <GradientStop Offset="0" Color="Green"/>
                                        <GradientStop Offset="0.88" Color="LightGreen"/>
                                        <GradientStop Offset="1" Color="DarkGreen"/>
                                    </RadialGradientBrush>
                                </Setter.Value>
                            </Setter>
                        </Trigger>
                        <Trigger Property="IsChecked" Value="False">
                            <Setter TargetName="highlightCircle" Property="Fill">
                                <Setter.Value>
                                    <LinearGradientBrush StartPoint="0.3,0" EndPoint="0.7,1">
                                        <GradientStop Offset="0" Color="Red"/>
                                        <GradientStop Offset="0.5" Color="LightCoral"/>
                                        <GradientStop Offset="1" Color="DarkRed"/>
                                    </LinearGradientBrush>
                                </Setter.Value>
                            </Setter>
                        </Trigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>    
</ResourceDictionary>

关于c# - WPF 复选框样式更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13684355/

相关文章:

javascript - 如何使用 JavaScript 中的全选框制作内容相关的复选框?

javascript - 如何在选中复选框时使用纯 JavaScript 禁用文本框并清除值

c# - 获取动画 GIF 的帧持续时间?

wpf - 为什么按钮的背景会改变?

c# - 使用 .NET SslStream 的 FTPS 服务器

c# - 静态实例基类/派生类

c# - CheckComboBox ValueMemberPath 不起作用

android - 在android中生成ID

c# - Windows 8.1 中 Pivot Control 的替代方案是什么?

c# - 反正有没有使用 WPF 为 android 开发应用程序?