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

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. Ajax方式上传文件
  2. Django分析之Middleware中间件
  3. cef3 获得js 返回值, 以及js 指挥delphi 函数的 总结参考
  4. Ajax 文件上传
  5. 微软BI 之SSIS 系列 - 通过设置 CheckPoints 检查点来增强 SSIS Package 流程的重用性
  6. Spring(四)Bean注入方试
  7. sql 字段重复值,in,like
  8. sublime3运行lua
  9. Linux系统及应用问题分析排查工具
  10. [置顶] Oracle GoldenGate 常见问题:长事务处理
  11. VBS脚本代码(手工编写---在windows 7上调用系统对话框,来选择文件)
  12. 利用PowerDesigner15在win7系统下对MySQL 进行反向工程(二)
  13. 有这iconfont.woff文件 为什么还报404
  14. web安全类
  15. SpringBoot 项目打包后运行报 org.apache.ibatis.binding.BindingException
  16. 15个实用的PHP正则表达式
  17. MySQL的常用命令:添加外键,修改字段名称,增加字段 设置主键自增长等
  18. JAVA学习路线——匹马行天下
  19. 【Spring】—— 自动装配
  20. C#之app.config、exe.config和vshost.exe.config作用区别

热门文章

  1. python标准日志模块logging的使用方法
  2. 获取网站资源 getResourceAsStream
  3. HDUOJ----3342Legal or Not
  4. Web 前端性能优化相关内容解析[转]
  5. 【js】with 语句
  6. [Android开发那点破事]解决android.os.NetworkOnMainThreadException
  7. Linux中网络通信中 使用的结构体
  8. spring boot几个初始配置文件
  9. 关于PFM工作模式的一些资料总结
  10. 独立成分分析(Independent component analysis, ICA)