winform自定义标题条窗口

效果如下图:

 

将窗口设为无边,增加一个panel,三个按钮和一个label,属性设置见下代码,重点部分已注释.

 private void InitializeComponent()
        {
            //标题条
            this.panel1 = new System.Windows.Forms.Panel();
            //窗口控制按钮
            this.button1 = new System.Windows.Forms.Button();
            this.button2 = new System.Windows.Forms.Button();
            this.button3 = new System.Windows.Forms.Button();
            //窗口名标签
            this.label1 = new System.Windows.Forms.Label();
            this.panel1.SuspendLayout();
            this.SuspendLayout();
            // 
            // panel1
            // 
            this.panel1.BackColor = System.Drawing.SystemColors.ButtonFace;
            this.panel1.Controls.Add(this.label1);
            this.panel1.Controls.Add(this.button3);
            this.panel1.Controls.Add(this.button2);
            this.panel1.Controls.Add(this.button1);
            //标题条的停靠方式为顶部
            this.panel1.Dock = System.Windows.Forms.DockStyle.Top;
            this.panel1.Location = new System.Drawing.Point(0, 0);
            this.panel1.Name = "panel1";
            this.panel1.Size = new System.Drawing.Size(853, 29);
            this.panel1.TabIndex = 0;
            this.panel1.MouseDown += new System.Windows.Forms.MouseEventHandler(this.panel1_MouseDown);
            this.panel1.MouseMove += new System.Windows.Forms.MouseEventHandler(this.panel1_MouseMove);
            // 
            // 关闭窗口按钮设置
            // 
            this.button1.Dock = System.Windows.Forms.DockStyle.Right;
            //使按钮无边
            this.button1.FlatAppearance.BorderSize = 0;
            //使按钮为平式的外观
            this.button1.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
            this.button1.Font = new System.Drawing.Font("宋体", 9F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
            this.button1.Location = new System.Drawing.Point(827, 0);
            this.button1.Margin = new System.Windows.Forms.Padding(0);
            this.button1.Name = "button1";
            this.button1.Size = new System.Drawing.Size(26, 29);
            this.button1.TabIndex = 1;
            this.button1.Text = "╳";
            this.button1.UseVisualStyleBackColor = true;
            this.button1.Click += new System.EventHandler(this.button1_Click);
            // 
            // button2
            // 
            this.button2.Dock = System.Windows.Forms.DockStyle.Right;
            this.button2.FlatAppearance.BorderSize = 0;
            this.button2.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
            this.button2.Font = new System.Drawing.Font("宋体", 10.5F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
            this.button2.Location = new System.Drawing.Point(798, 0);
            this.button2.Margin = new System.Windows.Forms.Padding(0);
            this.button2.Name = "button2";
            this.button2.Size = new System.Drawing.Size(29, 29);
            this.button2.TabIndex = 2;
            this.button2.Text = "□";
            this.button2.UseVisualStyleBackColor = true;
            // 
            // button3
            // 
            this.button3.Dock = System.Windows.Forms.DockStyle.Right;
            this.button3.FlatAppearance.BorderSize = 0;
            this.button3.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
            this.button3.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
            this.button3.Location = new System.Drawing.Point(769, 0);
            this.button3.Margin = new System.Windows.Forms.Padding(0);
            this.button3.Name = "button3";
            this.button3.Size = new System.Drawing.Size(29, 29);
            this.button3.TabIndex = 3;
            this.button3.Text = "─";
            this.button3.UseVisualStyleBackColor = true;
            // 
            // label1
            // 
            this.label1.AutoSize = true;
            this.label1.Dock = System.Windows.Forms.DockStyle.Left;
            this.label1.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
            this.label1.Location = new System.Drawing.Point(0, 0);
            this.label1.Margin = new System.Windows.Forms.Padding(0);
            this.label1.Name = "label1";
            this.label1.Padding = new System.Windows.Forms.Padding(0, 6, 0, 0);
            this.label1.Size = new System.Drawing.Size(77, 20);
            this.label1.TabIndex = 4;
            this.label1.Text = "ThinkAbout";
            this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
            // 
            // Form1
            // 
            this.AutoScaleDimensions = new System.Drawing.SizeF(7F, 14F);
            this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
            this.ClientSize = new System.Drawing.Size(853, 525);
            this.ControlBox = false;
            this.Controls.Add(this.panel1);
            this.Font = new System.Drawing.Font("宋体", 10.5F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
            //设置窗口无边,这样就不会显示默认的控制按钮了.
            this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.None;
            this.Name = "Form1";
            this.Text = "Form1";
            this.Load += new System.EventHandler(this.Form1_Load);
            this.MouseDown += new System.Windows.Forms.MouseEventHandler(this.Form1_MouseDown);
            this.MouseMove += new System.Windows.Forms.MouseEventHandler(this.Form1_MouseMove);
            this.panel1.ResumeLayout(false);
            this.panel1.PerformLayout();
            this.ResumeLayout(false);

        }

编写拖动窗口和关闭窗口的代码.如下:

  public partial class Form1 : Form
    {
        Point LeftDown;
             
        public Form1()
        {
            InitializeComponent();
            LeftDown = new Point();

        }

        private void panel1_MouseDown(object sender, MouseEventArgs e)
        {
            LeftDown.X = e.X;
            LeftDown.Y = e.Y;
        }

        private void panel1_MouseMove(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Left)
            {
                Point p = MousePosition;
                p.Offset(-LeftDown.X, -LeftDown.Y);
                Location = p;
            }
        }
    }

 

 

 

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自定义winform 窗口标题栏 主要代码 public partial class ZForm : Form { private bool moving = false; private Point oldMousePosition; public new FormBorderStyle FormBorderStyle { get { return base.FormBorderStyle; } set { if (value != FormBorderStyle.Sizable && value != FormBorderStyle.SizableToolWindow) { titlepanel.Controls.Remove(button2); } base.FormBorderStyle = value; } } #region 隐藏父类的属性,使其不可见 [Browsable(false)] public new string Text { get { return titlelabel.Text; } set { } } [Browsable(false)] public new bool ControlBox { get { return false; } set { base.ControlBox = false; } } #endregion [Browsable(true)] [EditorBrowsable(EditorBrowsableState.Always)] [Description("窗体标题")] public string Title { get { return titlelabel.Text; } set { titlelabel.Text = value; } } [Browsable(true)] [EditorBrowsable(EditorBrowsableState.Always)] [Description("窗体标题字体样式")] public Font TitleFont { get { return titlelabel.Font; } set { titlelabel.Font = value; } } [Browsable(true)] [EditorBrowsable(EditorBrowsableState.Always)] [Description("窗体标题字体颜色")] public Color TitleColor { get { return titlelabel.ForeColor; } set { titlelabel.ForeColor = value; } } [Browsable(true)] [EditorBrowsable(EditorBrowsableState.Always)] [Description("窗体标题栏背景色")] public Color TitleBarBackColor { get { return titlepanel.BackColor; } set { titlepanel.BackColor = value; } } public new bool MaximizeBox { get { return titlepanel.Contains(button2); } set { if (!value) { titlepanel.Controls.Remove(button2); } else if (!titlepanel.Contains(button2)) { titlepanel.Controls.Add(button2); } } } public new bool MinimizeBox { get { return titlepanel.Contains(button3); } set { if (!value) { titlepanel.Controls.Remove(button3); } else if (!titlepanel.Contains(button3)) { titlepanel.Controls.Add(button3); } } } private void ResetTitlePanel() { base.ControlBox = false; base.Text = null; SetToolTip(button1, "关闭"); button2.Size = button1.Size; SetToolTip(button2, "最大化或还原"); button3.Size = button1.Size; SetToolTip(button3, "最小化"); } private void SetToolTip(Control ctrl, string tip) { new ToolTip().SetToolTip(ctrl, tip); } public ZForm() { InitializeComponent(); ResetTitlePanel(); } private void Titlebutton_Click(object sender, EventArgs e) { Button btn = (Button)sender; switch (btn.Tag.ToString()) { case "close": { this.Close(); break; } case "max": { if (this.WindowState == FormWindowState.Maximized) { this.WindowState = FormWindowState.Normal; } else { this.WindowState = FormWindowState.Maximized; } break; } case "min": { if (this.WindowState != FormWindowState.Minimized) { this.WindowState = FormWindowState.Minimized; } break; } } } private void Titlepanel_MouseDown(object sender, MouseEventArgs e) { if (this.WindowState == FormWindowState.Maximized) { return; } //Titlepanel.Cursor = Cursors.NoMove2D; oldMousePosition = e.Location; moving = true; } private void Titlepanel_MouseUp(object sender, MouseEventArgs e) { //Titlepanel.Cursor = Cursors.Default; moving = false; } private void Titlepanel_MouseMove(object sender, MouseEventArgs e) { if (e.Button == MouseButtons.Left && moving) { Point newPosition = new Point(e.Location.X - oldMousePosition.X, e.Location.Y - oldMousePosition.Y); this.Location += new Size(newPosition); } } private void Titlepanel_DoubleClick(object sender, EventArgs e) { if (titlepanel.Contains(button2)) { button2.PerformClick(); } } private void titlepanel_ControlRemoved(object sender, ControlEventArgs e) { switch (e.Control.Name) { case "button2": { if (titlepanel.Contains(button3)) { button3.Left = button1.Left - button1.Width; } break; } } } private void titlepanel_ControlAdded(object sender, ControlEventArgs e) { switch (e.Control.Name) { case "button2": { if (titlepanel.Contains(button3)) { button3.Left = button2.Left - button2.Width; } break; } case "button3": { if (titlepanel.Contains(button2)) { button3.Left = button2.Left - button2.Width; } break; } } } }
#region 改变窗口样式         #if !DEBUG         [DllImport ("User32.dll")]         private static extern IntPtr GetWindowDC(IntPtr hwnd);         [DllImport ("User32.dll")]         private static extern int ReleaseDC(IntPtr hwnd, IntPtr hdc);         protected override void WndProc(ref Message m)         ...{                      base.WndProc(ref m);                          switch(m.Msg)                          ...{                     case 0x86://WM_NCACTIVATE                         goto case 0x85;                     case 0x85://WM_NCPAINT                     ...{                                                             IntPtr hDC = GetWindowDC(m.HWnd);                              //把DC转换为.NET的Graphics就可以很方便地使用Framework提供的绘图功能了                         Graphics gs = Graphics.FromHdc(hDC);                         处理色彩#region 处理色彩                         int ibox = 1;                         if (this.MaximizeBox) ibox ++;                         if (this.MinimizeBox) ibox ++;                         //得到相关背景图片                         Image imgpm = Image.FromFile( Application.StartupPath+ @"Main.bmp");
### 回答1: WinForm是微软的一个桌面应用程序开发框架,其中包含了MessageBox控件,用于弹出消息框显示信息。但是默认的MessageBox只能显示固定的按钮和图标,无法满足个性化的需求。因此,我们可以自定义一个MessageBox,满足我们特定的需求。 为了实现自定义MessageBox,我们可以创建一个新的窗体,命名为CustomMessageBox。在该窗体中,我们可以自定义布局、样式和交互方式。 首先,我们需要定义一个静态的方法,例如Show方法,用于显示自定义MessageBox,并且该方法可以接受不同的参数以满足不同的需求。 在Show方法中,我们可以设置CustomMessageBox窗体标题、文本、图标和按钮等属性。我们还可以根据需要自定义布局,例如添加更多的文本框、复选框或者其他控件。 另外,我们可以为CustomMessageBox窗体定义一些事件,例如按钮的点击事件,以便用户点击按钮后执行相应的操作。可以根据按钮的不同使用不同的事件响应,例如确认按钮可以执行特定的操作,取消按钮可以关闭CustomMessageBox窗口。 最后,在应用程序的代码中,可以通过调用CustomMessageBox的Show方法来显示自定义的消息框,传入相应的参数,使其满足我们的需求。 总的来说,通过自定义WinForm的MessageBox,我们可以更加灵活和个性化地显示消息框,满足不同的需求。这样用户在使用我们的应用程序时,将会有更好的用户体验。 ### 回答2: WinForm是一种用户界面开发工具,在.NET平台上使用C#编写窗体应用程序的工具。WinForm中提供了MessageBox控件,用于显示提示消息、询问消息及警告消息。但是我们也可以通过自定义MessageBox类来实现个性化的消息框。 要自定义MessageBox,我们可以创建一个继承自Form类的新窗体,然后在该窗体中添加各种控件,来实现我们想要的消息框效果。可以自定义消息文字、标题、图标、按钮等。 首先,我们可以设置窗体的样式,例如调整窗体的大小、位置、样式、背景色等。接着,我们可以添加一个Label控件来显示消息内容,并根据需要设置其字体、颜色、对齐方式等属性。 然后,我们可以添加一个PictureBox控件来显示图标,可以是默认的信息图标,也可以是自定义图标。可以根据消息类型来选择不同的图标,例如,信息类型可以使用Info图标,警告类型可以使用Warning图标,错误类型可以使用Error图标等。 接下来,我们可以添加多个按钮,并根据需要设置其样式、文本、事件等属性。例如,我们可以添加一个确定按钮,点击后关闭消息框,并返回一个确定结果给调用者;我们也可以添加一个取消按钮,点击后关闭消息框,并返回一个取消结果给调用者。 最后,在自定义MessageBox类中添加必要的属性和方法,例如,用于设置消息内容、图标类型、按钮样式等属性的方法,用于获取点击按钮结果的方法等。 总之,通过自定义MessageBox类,我们可以更加灵活地定制化消息框,使其符合我们的设计需求,并提供更好的用户体验。 ### 回答3: WinForm自定义MessageBox可以通过继承MessageBox类,并重写其相应方法来实现。以下是一种实现方式: 首先,新建一个名为CustomMessageBox的类,并继承自MessageBox类。 然后,在CustomMessageBox类中重写Show方法,该方法用于显示自定义的消息框。 在重写的Show方法中,可以通过创建一个自定义窗体,来代替系统默认的MessageBox窗体。 在自定义窗体中,可以添加自定义的控件,例如Label用于显示消息内容,Button用于表示确定或取消等按钮。 可以通过修改窗体的样式、大小、位置等属性,使其与自己的需求相匹配。 添加事件处理方法,处理按钮的点击事件,以响应用户的操作。 最后,根据用户的操作结果,返回相应的DialogResult,以便调用方可以根据返回值进行相应的处理。 这样,我们就可以调用自定义的Show方法来显示我们定义的消息框了,例如: CustomMessageBox.Show("这是一个自定义的消息框。"); 通过以上步骤,我们可以实现一个自定义WinForm消息框,以满足我们特定的需求,如更改消息框的样式、增加额外的功能等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值