WPF之Window无边框拖动、特殊形状、Grid拖拽

WPF之Window无边框拖动、特殊形状、Grid拖拽

WPF之Window无边框拖动、特殊形状、Grid拖拽

Grid


要点:

  • IsSharedSizeScope属性
  • <GridSplitter>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<Window x:Class="Grid.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:Grid"
mc:Ignorable="d"
Title="MainWindow" Height="250" Width="300">

<Grid Grid.IsSharedSizeScope="True">
<Grid.RowDefinitions>
<RowDefinition Height="30"/>
<RowDefinition/>
</Grid.RowDefinitions>

<!--列头-->
<Grid Grid.Row="0">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="50" SharedSizeGroup="A" />
<ColumnDefinition Width="100" SharedSizeGroup="B"/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<Border Background="Orange"/>
<Border Background="Green" Grid.Column="1" Margin="3,7,10,15"/>
<!--左上右下-->
<GridSplitter HorizontalAlignment="Right" Height="10" Width="5" Background="Gray"/>
<GridSplitter HorizontalAlignment="Right" Height="10" Width="5" Background="Gray" Grid.Column="1"/>
</Grid>

<!--数据表-->
<Grid Grid.Row="1" Height="60" VerticalAlignment="Top" Margin="0,10,0,0">
<Grid.ColumnDefinitions>
<ColumnDefinition SharedSizeGroup="A"/>
<ColumnDefinition SharedSizeGroup="B"/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<Border Background="Orange">
</Border>
<Border Grid.Column="1" BorderBrush="Red" BorderThickness="1">
<TextBlock/>
</Border>
</Grid>
</Grid>
</Window>

Window

无边框窗口

如果Window的WindowStyle=”None”,则Window会没有边框,此时无法拖动窗口,并且也没有最大最小和关闭按键。同时设置AllowsTransparency=”True”和Background=”Transparent”。

此时可以使用WindowChrome来解决

1
2
3
<WindowChrome.WindowChrome>
<WindowChrome CaptionHeight="50" UseAeroCaptionButtons="False"/>
</WindowChrome.WindowChrome>
  • CaptionHeight代表标题高度(也就是在哪个高度范围内可以拖动)
  • UseAeroCaptionButtons表示是否禁用自带的最小最大化按钮(一般禁用,配合自定义按钮)

注意

如果某个控件位于CaptionHeight设定的高度内,是不能被命中的,解决办法是在该控件内添加属性WindowChrome.IsHitTestVisibleInChrome="True"

特殊形状窗口

1
2
3
<Window.Clip>
<PathGeometry Figures="M0,0 200,0A75 75 0 0 1 200 150L0,150z"/>
</Window.Clip>

表示将图形之外的内容都裁剪掉

  • 必须配合AllowsTransparency="True" WindowStyle="None"使用
  • 不能和WindowChrome一起使用,因为给裁剪了
  • 若要实现拖拽效果,必须在某个控件下实现MouseLeftButtonDown事件
1
2
3
4
private void Border_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
this.DragMove();
}

WPF之Window无边框拖动、特殊形状、Grid拖拽

https://bubuweiying.site/WPF之Window无边框拖动、特殊形状、Grid拖拽/

作者

步步为营

发布于

2024-05-08

更新于

2025-03-15

许可协议