首頁 > 後端開發 > C++ > 如何在 Windows 窗體中建立可調整大小且可移動的無邊框窗體?

如何在 Windows 窗體中建立可調整大小且可移動的無邊框窗體?

Mary-Kate Olsen
發布: 2025-01-11 13:21:42
原創
586 人瀏覽過

How to Create a Resizable and Movable Borderless Form in Windows Forms?

在Windows Forms中建立可調整大小和可移動的無邊框窗體

在Windows Forms中,透過將「FormBorderStyle」屬性設為「None」可以輕鬆建立無邊框窗體。但是,此預設操作會停用調整窗體大小的功能。要克服此限制,需要更高級的方法。

以下程式碼示範了一個自訂解決方案,可以同時移動和調整無邊框窗體的大小:

<code class="language-csharp">public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
        this.FormBorderStyle = FormBorderStyle.None;
        this.DoubleBuffered = true;
        this.SetStyle(ControlStyles.ResizeRedraw, true);
    }

    private const int cGrip = 16;      // 调整大小控制柄大小
    private const int cCaption = 32;   // 标题栏高度

    protected override void OnPaint(PaintEventArgs e)
    {
        // 在右下角绘制调整大小控制柄
        Rectangle rc = new Rectangle(this.ClientSize.Width - cGrip, this.ClientSize.Height - cGrip, cGrip, cGrip);
        ControlPaint.DrawSizeGrip(e.Graphics, this.BackColor, rc);

        // 绘制模拟标题栏
        rc = new Rectangle(0, 0, this.ClientSize.Width, cCaption);
        e.Graphics.FillRectangle(Brushes.DarkBlue, rc);
    }

    protected override void WndProc(ref Message m)
    {
        if (m.Msg == 0x84) {  // 捕获WM_NCHITTEST消息
            Point pos = new Point(m.LParam.ToInt32());
            pos = this.PointToClient(pos);
            if (pos.X >= this.ClientSize.Width - cGrip && pos.Y >= this.ClientSize.Height - cGrip)
            {
                m.Result = (IntPtr)17; // HTBOTTOMRIGHT
                return;
            }
        }
        base.WndProc(ref m);
    }
}</code>
登入後複製

程式碼工作原理說明:

  • 自訂標題列:OnPaint重寫方法在視窗頂部繪製藍色條,以模擬標題列。
  • 調整大小控制柄:DrawSizeGrip函數在窗體的右下角繪製一個控制柄,允許拖曳以調整大小。
  • WM_NCHITTEST事件:WndProc重寫方法攔截WM_NCHITTEST訊息以偵測滑鼠遊標位置。如果遊標在標題列或控制柄內,則傳回對應的命中測試程式碼。 程式碼中pos.Y應改為pos.X才符合邏輯,確保正確偵測右下角的調整大小控制柄區域。

以上是如何在 Windows 窗體中建立可調整大小且可移動的無邊框窗體?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板