トグル状態に応じて、WPF ToggleButton に「はい」または「いいえ」を表示させる簡単なテンプレートを手伝ってくれる人はいますか?
ただし、ボタンのように見せたくありません。はいまたはいいえとして表示されるテキストの一部です。
既存のすべてのトグル コントロールにスタイルとして追加できるテンプレートとして使用したいと考えています。
Blend を試してみましたが、テンプレート作成は初めてで、その方法がわかりませんでした。
トグル状態に応じて、WPF ToggleButton に「はい」または「いいえ」を表示させる簡単なテンプレートを手伝ってくれる人はいますか?
ただし、ボタンのように見せたくありません。はいまたはいいえとして表示されるテキストの一部です。
既存のすべてのトグル コントロールにスタイルとして追加できるテンプレートとして使用したいと考えています。
Blend を試してみましたが、テンプレート作成は初めてで、その方法がわかりませんでした。
@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>
基本的に、ボタンのテンプレートは、それが保持するコンテンツになるように設定します。
これは、次のスタイルで簡単に実行できます。
<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>