WPF 窗体自定义拖拽缩放

先看效果:

 

自定义WindowChrome

通过WindowChromeResizeBorderThickness属性进行设置

XAML代码

<Window x:Class="SmartClient.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:SmartClient"
        xmlns:extendedResizeBorder="clr-namespace:ExtendedResizeBorder;assembly=ExtendedResizeBorder"
        mc:Ignorable="d"
        Style="{StaticResource NoResize_window}"
        Title="MainWindow" Height="780" Width="1200" Loaded="Window_Loaded">
    <extendedResizeBorder:ExtendedResizeBorder.ExtendedResizeBorder>
        <extendedResizeBorder:ExtendedResizeBorder Radius="8" />
    </extendedResizeBorder:ExtendedResizeBorder.ExtendedResizeBorder>
    <WindowChrome.WindowChrome>
        <WindowChrome ResizeBorderThickness="10"></WindowChrome>
    </WindowChrome.WindowChrome>
    <Grid Background="Transparent" MouseDown="UIElement_OnMouseDown" x:Name="wb">
        <!--<Grid Background="White" />-->
        <!--<Button Width="100" Height="100" Command="Undo" />-->
    </Grid>
</Window>

后台代码:

public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }

        protected override void OnMouseLeftButtonDown(MouseButtonEventArgs e)
        {
            base.OnMouseLeftButtonDown(e);

            // 获取鼠标相对标题栏位置
            Point position = e.GetPosition(wb);

            // 如果鼠标位置在标题栏内,允许拖动
            if (e.LeftButton == MouseButtonState.Pressed)
            {
                if (position.X >= 0 && position.X < wb.ActualWidth && position.Y >= 0 && position.Y < wb.ActualHeight)
                {
                    this.DragMove();
                }
            }
        }

        private void Window_Loaded(object sender, RoutedEventArgs e)
        {
        }

        private void UIElement_OnMouseDown(object sender, MouseButtonEventArgs e)
        {
        }
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值