【C#/WPF】GridSplitter 分割布局,拖拽控件分隔栏以改变控件尺寸

70 篇文章 4 订阅

需求:界面由多部分控件组成,想要拖拽控件之间的分隔栏以改变尺寸。

MainWindow.xaml:

<Grid>
    <Grid.ColumnDefinitions>
        <ColumnDefinition Width="300"/>
        <ColumnDefinition Width="300"/>
    </Grid.ColumnDefinitions>

    <ListBox Grid.Row="0" Grid.Column="0">
        <ListBoxItem>aaaa</ListBoxItem>
        <ListBoxItem>bbbb</ListBoxItem>
        <ListBoxItem>cccb</ListBoxItem>
    </ListBox>

    <TextBlock Grid.Row="0" Grid.Column="1">sadfas</TextBlock>

    <GridSplitter Grid.Row="0" Grid.Column="0" Width="0" VerticalAlignment="Stretch" HorizontalAlignment="Right"/>

</Grid>

运行效果如下:

红色虚线表示了拖动分隔栏以改变控件的尺寸边缘。

分隔栏往左拖动

分隔栏往右拖动

坑点:

  • 必须使用Grid及其行和列来定义,否则能显示但无法拖动。例如下面的写法是无效的:
<StackPanel Orientation="Horizontal">
    <TextBlock Text="LLLLLLLLLLLLLL"/>
    <GridSplitter Width="10" HorizontalAlignment="Center" VerticalAlignment="Stretch" Background="Wheat"/>
    <TextBlock Text="RRRRRRRRRRRRRR"/>
</StackPanel>
  • 对于左右分割列,必须指定分隔栏GridSplitter的宽度Width,以及设置VerticalAlignment,否则无效。
  • 对于上下分割行,必须指定分隔栏GridSplitter的高度Height,以及设置HorizontalAlignment,否则无效。

再来一个详细一点的例子:

<Window x:Class="WpfApplication1.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:WpfApplication1"
        xmlns:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
        xmlns:xcdg="http://schemas.xceed.com/wpf/xaml/datagrid"
        mc:Ignorable="d"
        Title="MainWindow" Height="600" Width="1000">

    <Grid>
        <Grid.RowDefinitions/>
        <Grid.ColumnDefinitions>
            <ColumnDefinition/>
            <ColumnDefinition Width="10"/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>

        <TextBlock Grid.Row="0" Grid.Column="0" Text="LLLLLLLLLLLLLL"/>
        <GridSplitter Grid.Row="0" Grid.Column="1" Width="10" HorizontalAlignment="Center" VerticalAlignment="Stretch" Background="Wheat"/>

        <Grid Grid.Row="0" Grid.Column="2">
            <Grid.RowDefinitions>
                <RowDefinition/>
                <RowDefinition Height="10"/>
                <RowDefinition/>
            </Grid.RowDefinitions>
            <Grid.ColumnDefinitions>
                <ColumnDefinition/>
            </Grid.ColumnDefinitions>

            <TextBlock Grid.Row="0" Grid.Column="0" Text="RRRRRRTTTTTTTT"/>
            <GridSplitter Grid.Row="1" Grid.Column="0" Height="10" HorizontalAlignment="Stretch" Background="Wheat"/>
            <TextBlock Grid.Row="2" Grid.Column="0" Text="RRRRRRBBBBBBBB"/>

        </Grid>       
    </Grid>

</Window>

运行效果如图:下面的水平和垂直的黄色分隔栏都是可以拖动的。
这里写图片描述

重要的参考:

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果你想要实现WPF缩放时真实改变控件尺寸并保持控件在画布中心位置的效果,可以尝试以下步骤: 1. 将控件放置在一个Canvas控件中,并设置Canvas.Left和Canvas.Top属性,将控件放置在画布中心。 2. 将Canvas控件放置在一个Grid控件中,并将该Grid控件放置在Window中。 3. 在Window的Loaded事件中,通过VisualTreeHelper.GetChild方法获取Canvas控件,并获取其LayoutTransform属性。 4. 创建一个ScaleTransform对象,并将其应用于Canvas控件的LayoutTransform属性中。 5. 在ScaleTransform对象中设置CenterX和CenterY属性,使其缩放时围绕画布中心进行缩放。 下面是一个示例代码: ```xml <Window x:Class="WpfApp1.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="MainWindow" Height="450" Width="800" Loaded="Window_Loaded"> <Grid> <Canvas Width="200" Height="200" Background="LightGray" Left="300" Top="125" RenderTransformOrigin="0.5,0.5"> <Ellipse x:Name="ellipse" Width="100" Height="100" Fill="Red"/> </Canvas> </Grid> </Window> ``` ```csharp private void Window_Loaded(object sender, RoutedEventArgs e) { var canvas = VisualTreeHelper.GetChild(this.grid, 0) as Canvas; var transform = new ScaleTransform(); canvas.LayoutTransform = transform; transform.CenterX = canvas.Width / 2; transform.CenterY = canvas.Height / 2; var sizeChangedEventHandler = new SizeChangedEventHandler((s, args) => { var scale = Math.Min(canvas.ActualWidth / this.ellipse.Width, canvas.ActualHeight / this.ellipse.Height); transform.ScaleX = scale; transform.ScaleY = scale; }); this.ellipse.SizeChanged += sizeChangedEventHandler; sizeChangedEventHandler(this.ellipse, null); } ``` 在上面的示例中,我们将Canvas控件放置在Grid控件中,并将其放置在Window中。在Window的Loaded事件中,我们获取了Canvas控件,并创建了一个ScaleTransform对象,将其应用于Canvas控件的LayoutTransform属性中。然后,我们设置了ScaleTransform对象的CenterX和CenterY属性,使其缩放时围绕画布中心进行缩放。 最后,我们添加了一个SizeChanged事件处理程序,该处理程序会根据Canvas的实际尺寸控件的原始尺寸来计算缩放比例,并将其应用于ScaleTransform对象的ScaleX和ScaleY属性中,以实现真实改变控件尺寸并保持控件在画布中心位置的效果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值