是/否切换按钮的WPF模板

是/否切换按钮的WPF模板,wpf,wpf-controls,Wpf,Wpf Controls,有谁能帮我一个简单的模板,使WPF切换按钮显示“是”或“否”,这取决于它的切换状态 但我不想让它看起来像一个按钮,只是一段显示为是或否的文本 我想它作为一个模板,我可以添加作为一种风格,我现有的所有切换控件 我尝试使用Blend,但我对模板制作还不熟悉,不知道如何使用它。您可以使用以下样式轻松完成此操作: <Window x:Class="WpfTest.MainWindow" xmlns="http://schemas.microsoft.com/winf

有谁能帮我一个简单的模板,使WPF切换按钮显示“是”或“否”,这取决于它的切换状态

但我不想让它看起来像一个按钮,只是一段显示为是或否的文本

我想它作为一个模板,我可以添加作为一种风格,我现有的所有切换控件


我尝试使用Blend,但我对模板制作还不熟悉,不知道如何使用它。

您可以使用以下样式轻松完成此操作:

    <Window x:Class="WpfTest.MainWindow"
            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
            Title="MainWindow" Height="350" Width="525">
    <Window.Resources>
        <Style x:Key="OnOffToggleStyle" TargetType="ToggleButton">
            <Style.Triggers>
                <Trigger Property="IsChecked" Value="True">
                    <Setter Property="Content">
                        <Setter.Value>
                            <TextBlock Text="Yes"/>
                        </Setter.Value>
                    </Setter>
                </Trigger>
                <Trigger Property="IsChecked" Value="False">
                    <Setter Property="Content">
                        <Setter.Value>
                            <TextBlock Text="No"/>
                        </Setter.Value>
                    </Setter>
                </Trigger>
            </Style.Triggers>
        </Style>
    </Window.Resources>
    <Grid>
        <ToggleButton Style="{StaticResource OnOffToggleStyle}"/>
    </Grid>
</Window>

基于@Batuu的回复,只需将内容保留为文本,只需将样式更新为

已更新

<Style x:Key="OnOffToggleStyle" TargetType="ToggleButton">
  <Setter Property="Content" Value="Off"/>
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="{x:Type ToggleButton}">
        <ContentPresenter />
      </ControlTemplate>
    </Setter.Value>
  </Setter>
  <Style.Triggers>
      <Trigger Property="IsChecked" Value="True">
          <Setter Property="Content" Value="On">
          </Setter>
      </Trigger>
  </Style.Triggers>
</Style>

与原始答复相比,此处增加的内容如下:

  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="{x:Type ToggleButton}">
        <ContentPresenter />
      </ControlTemplate>
    </Setter.Value>
  </Setter>


基本上,您可以将按钮的模板设置为它所包含的内容。

哇,当您看到它完成时,很容易!它看起来仍然像一个按钮,是不是很容易删除其余的按钮样式,所以我只剩下标签?完美,非常感谢!很容易看到,但是如何才能找到像这样的控件上可用的属性呢。我可以使用Blend获得此样式吗?所有ui控件在WPF中看起来都不太像,要通过Blend编辑任何控件的样式,只需右键单击设计器中的控件并选择“编辑模板”->“编辑副本”,然后按照对话框进行操作。(当你试着编辑一个简单的默认控件时,它看起来会有很多信息,最好的学习方法是删除所有你不想使用的东西,然后试着运行应用程序,慢慢地添加一些信息,看看到底是什么对应什么)啊……我似乎有一个问题。当窗口上只有一个控件具有此样式时,此样式可以正常工作。但是…当有多个控件使用这种样式时,它们似乎会相互干扰。例如,打开和关闭其中一个,然后打开和关闭另一个,文本将从第一个文本中消失!有什么想法吗?@Paul更新了样式以防止这个问题。在同一页面上使用多个控件进行了测试,结果表明这是正确的。让我知道你现在是否满意。我所做的更改是设置一个默认内容,让触发器只更改一个状态的值。谢谢Viv,这太完美了!为什么以前的解决方案不起作用?我只是想知道控件之间是如何相互干扰的?(我想知道出了什么问题!)