WPF стиль для textbox
Написал стиль для textbox чтобы создать ввод пользователя чтобы при вводе появлялась кнопка для подтверждения, только вот использовал тот же метод что и для textblock, а мне нужно чтобы он при нажатии на textbox показывалась только кнопка. Как это сделать я так и не могу додумать потому что нужно отслеживать фокусировку textbox, а когда я это хочу запихнуть в просто триггер и указать элемент у которого это должно произойти все ломается, поэтому хотел бы получить совет что делаю не так?(скорее всего не тот триггер использую или не там) Вот сам стиль:
<Style TargetType="TextBox" x:Key="enternickname">
<!--Создадим бордер где будет наш текстбокс-->
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="TextBox">
<Grid>
<Border
Background="#323437"
CornerRadius="10"
Width="190"
Height="40"
Padding="5">
<Grid>
<!--Добавим текст бокс-->
<TextBox
Text="{TemplateBinding Text}"
Background="Transparent"
BorderThickness="0"
Foreground="#deddd0"
FontSize="20"
Margin="1,0,0,0"
x:Name="NameBox"
MaxLength="15"/>
<!--добавим текст блок который будет исчезать при нажатии-->
<TextBlock
IsHitTestVisible="False"
Text="Никнейм"
Foreground="Gray"
FontSize="20"
VerticalAlignment="Center">
<TextBlock.Style>
<Style TargetType="{x:Type TextBlock}">
<Style.Triggers>
<DataTrigger Binding="{Binding Text, ElementName=NameBox}" Value="">
<Setter Property="Visibility" Value="Visible"/>
</DataTrigger>
</Style.Triggers>
<Setter Property="Visibility" Value="Hidden"/>
</Style>
</TextBlock.Style>
</TextBlock>
<!--Кнопка подтвеждения никнейма-->
<Button VerticalAlignment="Center"
HorizontalAlignment="Right"
Background="Transparent"
BorderThickness="0"
Cursor="Hand">
<Image Source="/images/check_mark.png" Width="25" Height="25"/>
<!--Добавил в стиль кнопки триггеры для того чтобы она выводилась только при вводе и чтобы фон не менялся-->
<Button.Style>
<Style TargetType="{x:Type Button}">
<Setter Property="Background" Value="Transparent" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<Border x:Name="Border" Background="{TemplateBinding Background}">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
<ControlTemplate.Triggers>
<DataTrigger Binding="{Binding Text, ElementName=NameBox}" Value="">
<Setter Property="Visibility" Value="Hidden"/>
</DataTrigger>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="Transparent" TargetName="Border" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Button.Style>
</Button>
</Grid>
</Border>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Тут я просто решил сделать прикольное оформление с textblock который исчезает при вводе и кнопкой которой как я и говорил хотел бы сделать так чтобы она появлялась только при фокусе(или при печатании). Надеюсь на вашу помощь!
Ответы (1 шт):
Стоило поискать по лучше и я понял, что просто использовал не тот триггер, нужно было использовать не focused
(у меня там в button почему-то text
), а IsKeyboardFocused
!