WPF隐藏控件后,怎么让其上部的控件空间自动撑高

隐藏底部的日志显示控件_StackPanel3后,stackPanel1会自动撑高;

关键属性设置:

xml 复制代码
 <Grid.RowDefinitions>
     <!-- 上部控件占满剩余空间 -->
     <RowDefinition Height="*" />

     <!--按钮部分  -->
     <RowDefinition Height="auto" />

     <!--日志部分,会被隐藏的 -->
     <RowDefinition Height="auto" />
 </Grid.RowDefinitions>

WPF xaml页面参考代码

xml 复制代码
<Window x:Class="WpfAppYolo11_test1.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:WpfAppYolo11_test1"
        mc:Ignorable="d"
        Title="MainWindow" Height="900" Width="1300" WindowStartupLocation="CenterScreen">
    <Grid  x:Name="grid1">
        <Grid.RowDefinitions>
            <!-- 上部控件占满剩余空间 -->
            <RowDefinition Height="*" />

            <!--按钮部分  -->
            <RowDefinition Height="auto" />

            <!--日志部分,会被隐藏的 -->
            <RowDefinition Height="auto" />
        </Grid.RowDefinitions>
        <StackPanel Grid.Row="0" Name="stackPanel1" Background="LightGreen"  >
            <!--<Viewbox x:Name="testView"  >
                 </Viewbox>-->
            <Image x:Name="imgShow"   MinHeight="690"  VerticalAlignment="Stretch"  Stretch="Uniform" HorizontalAlignment="Center"    />

        </StackPanel>
        <StackPanel Grid.Row="1"  Name="_StackPanel2" >
            <Border BorderThickness="2" BorderBrush="Green" Padding="2">
                <StackPanel>
                    <DockPanel>
                        <Button   Content="识别图" Click="Button_Click" FontSize="16"   Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button   Content="下一张图" Click="Button_Click_5" FontSize="16"   Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button   Content="上一张图" Click="Button_Click_6" FontSize="16"   Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        
                        <Button x:Name="btnVideoDetection"   Content="识别视频" Click="Button_Click_2" FontSize="16"   Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button x:Name="btnVideoCapter"   Content="识别视频帧" Click="btnVideoCapter_Click" FontSize="16"   Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button x:Name="btnVideoDetection2"   Content="打开摄像头" Click="btnVideoDetection2_Click" FontSize="16"  Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button   Content="停止视频检测" Click="Button_Click_3" FontSize="16" Width="100" Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button   Content="清空图片" Click="Button_Click_Clear" FontSize="16" Width="100" Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <TextBox x:Name="txtbox2" Background="GreenYellow" FontSize="15" Width="400" HorizontalAlignment="Left" Height="25" TextWrapping="Wrap" />
                        <Button   Content="窗1" Click="Button_Click_4" FontSize="16"  Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                    </DockPanel>
                    <DockPanel>
                        <Button x:Name="btnGame1"  Content="启动游戏" Click="btnGame1_Click" FontSize="16"  Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <Button x:Name="btnGameDetectionStop"  Content="停止按钮查找" Click="btnGameDetectionStop_Click" FontSize="16"  Margin="5" HorizontalAlignment="Left"   VerticalAlignment="Top"/>
                        <TextBox x:Name="txtbox3" Background="GreenYellow" FontSize="15" Width="200" HorizontalAlignment="Left" Height="25" TextWrapping="Wrap" />
                        <CheckBox x:Name="isShowLog"   IsChecked="True" Click="ShowLogCtrl_Click" Content="显示日志" Height="20" Width="90"/>
                    </DockPanel>                     
                </StackPanel>
            </Border>
        </StackPanel>

 <!--日志部分,会被隐藏的 -->
        <StackPanel Grid.Row="2" Name="_StackPanel3">
            <TextBox     x:Name="txtbox1" Height="115" HorizontalAlignment="Stretch"    Background="Yellow" VerticalScrollBarVisibility="Auto" FontSize="12"     TextWrapping="Wrap" />
        </StackPanel>
    </Grid>
</Window>
csharp 复制代码
  /// <summary>
  /// 控制日志是否显示
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void ShowLogCtrl_Click(object sender, RoutedEventArgs e)
  {
      if (this.isShowLog.IsChecked!=null && this.isShowLog.IsChecked.Value )
      {       
          _StackPanel3.Visibility = Visibility.Visible;
          
      }
      else
      {
          _StackPanel3.Visibility = Visibility.Collapsed;//隐藏     
           this.Height +=1;//通知图片控件更新布局,更新尺寸     
      }
相关推荐
没有bug.的程序员2 天前
SOA、微服务、分布式系统的区别与联系
java·jvm·微服务·架构·wpf·日志·gc
Macbethad2 天前
基于WPF的半导体设备配方管理程序技术方案
wpf
FuckPatience2 天前
WPF Geometry
wpf
武藤一雄3 天前
.NET 中常见计时器大全
microsoft·微软·c#·.net·wpf·.netcore
MarkHD3 天前
车辆TBOX科普 第70次 AUTOSAR Adaptive、容器化与云原生的融合革命
云原生·wpf
极客智造3 天前
WPF Behavior 实战:自定义 InvokeCommandAction 实现事件与命令解耦
wpf
L、2183 天前
Flutter 与 OpenHarmony 深度集成:构建分布式多端协同应用
分布式·flutter·wpf
布伦鸽3 天前
C# WPF -MaterialDesignTheme 找不到资源“xxx“问题记录
开发语言·c#·wpf
小二·4 天前
MyBatis基础入门《十五》分布式事务实战:Seata + MyBatis 实现跨服务数据一致性
分布式·wpf·mybatis
helloworddm4 天前
UnregisterManyAsync
wpf