изменить высоту окна в зависимости от выбранного элемента TabItem - PullRequest
0 голосов
/ 26 октября 2018

Привет, я хочу, чтобы когда пользователь выбрал изменение высоты окна Tabitem, это мой код:

<Windows.Style>
        <Style TargetType="Windows">
            <Setter Property="Height" Value="220" />
            <Style.Triggers>
                <DataTrigger Binding="{Binding ElementName=tabc,Path=SelectedIndex, UpdateSourceTrigger=PropertyChanged, Mode=Twoway}" Value="1">
                    <Setter Property="Height" Value="400" />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </Windows.Style>

в Visual Studio, когда я изменяю код табуляции, работает отлично, но когда я компилирую код, не работает

1 Ответ

0 голосов
/ 26 октября 2018

Вы можете использовать DoubleAnimation для установки Height окна.Это работает как ожидалось:

<Window x:Class="WpfApp1.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfApp1"
        mc:Ignorable="d"
        Title="MainWindow" Height="300" Width="300">
    <Window.Style>
        <Style TargetType="Window">
            <Style.Triggers>
                <DataTrigger Binding="{Binding ElementName=tabc, Path=SelectedIndex}" Value="1">
                    <DataTrigger.EnterActions>
                        <BeginStoryboard>
                            <Storyboard>
                                <DoubleAnimation To="400" Duration="0:0:0" Storyboard.TargetProperty="Height" />
                            </Storyboard>
                        </BeginStoryboard>
                    </DataTrigger.EnterActions>
                    <DataTrigger.ExitActions>
                        <BeginStoryboard>
                            <Storyboard>
                                <DoubleAnimation To="220" Duration="0:0:0" Storyboard.TargetProperty="Height" />
                            </Storyboard>
                        </BeginStoryboard>
                    </DataTrigger.ExitActions>
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </Window.Style>
    <Grid>
        <TabControl x:Name="tabc">
            <TabItem Header="1">
                <TextBlock>first tab</TextBlock>
            </TabItem>
            <TabItem Header="2">
                <TextBlock>second tab</TextBlock>
            </TabItem>
        </TabControl>
    </Grid>
</Window>
...