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

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

Grid

在这里插入图片描述
要点:

  • IsSharedSizeScope属性
  • <GridSplitter>
<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来解决

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

注意

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

特殊形状窗口

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

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

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

在这里插入图片描述

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
WPF可以通过以下步骤实现拖拽打开文件: 1. 在XAML中,为窗口或控件添加AllowDrop属性,以允许在其上拖放文件。 2. 为窗口或控件的PreviewDragOver事件添加事件处理程序。在该事件处理程序中,可以检查拖放的数据格式是否为文件,并根据需要设置拖放操作的效果。 3. 为窗口或控件的Drop事件添加事件处理程序。在该事件处理程序中,可以获取拖放的文件路径,并进行相应的处理,例如打开文件、读取文件内容等。 以下是一个简单的示例代码: ```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" AllowDrop="True" PreviewDragOver="Window_PreviewDragOver" Drop="Window_Drop"> <Grid> </Grid> </Window> ``` ```csharp private void Window_PreviewDragOver(object sender, DragEventArgs e) { if (e.Data.GetDataPresent(DataFormats.FileDrop)) { e.Effects = DragDropEffects.Copy; } else { e.Effects = DragDropEffects.None; } e.Handled = true; } private void Window_Drop(object sender, DragEventArgs e) { string[] files = (string[])e.Data.GetData(DataFormats.FileDrop); foreach (string file in files) { // 打开文件或进行其他处理 } e.Handled = true; } ``` 在上述代码中,AllowDrop属性设置为True,允许窗口或控件接受拖放文件。PreviewDragOver事件处理程序检查拖放的数据格式是否为文件,并根据需要设置拖放操作的效果。Drop事件处理程序获取拖放的文件路径,并进行相应的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

步、步、为营

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值