簡體   English   中英

基於TabItem Selected wpf更改窗口高度

[英]change windows height based on TabItem Selected wpf

您好,我想當用戶選擇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中,當我更改選項卡代碼時可以正常工作,但是在編譯時,代碼無法正常工作

您可以使用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>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM