Как отключить кнопку со стилем для тега Button.Content в WPF - PullRequest
0 голосов
/ 26 мая 2020

У меня есть такая кнопка:

<Button x:Name="CloseBtn" Click="CloseBtn_Click" IsEnabled="{Binding IsCloseEnabled}" 
                        HorizontalAlignment="Right" Style="{StaticResource TopButton}">
                    <Button.Content>
                        <StackPanel Orientation="Horizontal">
                            <Image Height="30" Width="30" Source="{StaticResource CloseIcon}" />
                            <Label Foreground="Black">Close</Label>
                        </StackPanel>
                    </Button.Content>
                </Button>

Ее стиль таков:

<Style x:Key="TopButton" TargetType="{x:Type Button}">
            <Setter Property="Padding" Value="10,5" />
            <Style.Triggers>
                <Trigger Property="IsEnabled" Value="False">
                    <Setter Property="TextBlock.Foreground" Value="#FFADADAD"/>
                </Trigger>

            </Style.Triggers>
        </Style>

Однако, когда привязка IsCloseEnabled возвращает false, кнопка не выглядит при отключении - цвет "#FFADADAD" не применяется к переднему плану. Не уверен, где что-то пошло не так.

1 Ответ

0 голосов
/ 26 мая 2020

Для вашего ярлыка установлено значение Foreground = "Black", которое переопределит любой другой цвет, который вы пытаетесь применить с помощью триггеров. Удалите «Foreground = Black» и посмотрите, решит ли это вашу проблему.

Обновление №2: если вы также хотите, чтобы изображение выглядело отключенным, вам лучше сделать источник изображения управляемым стилем который заменяет исходный файл на «отключенный» png. Примерно так:

        <Button x:Name="CloseBtn" Click="CloseBtn_Click" IsEnabled="{Binding IsCloseEnabled}" HorizontalAlignment="Right" Style="{StaticResource TopButton}">
            <Button.Content>
                <StackPanel Orientation="Horizontal">
                    <Image x:Name="myImage" Height="30" Width="30">
                        <Image.Style>
                            <Style TargetType="Image">
                                <Setter Property="Source" Value="{StaticResource CloseIcon}"/>
                                <Style.Triggers>
                                    <DataTrigger Binding="{Binding IsCloseEnabled}" Value="False">
                                        <Setter Property="Source" Value="{StaticResource CloseIconDisabled}"/>
                                    </DataTrigger>
                                    </Trigger>
                                </Style.Triggers>
                            </Style>
                        </Image.Style>
                    </Image>
                    <Label>Close</Label>
                </StackPanel>
            </Button.Content>
        </Button>

...