【Win10】修改标题栏颜色

 Win10标题栏颜色有多种选择,但是默认的那个颜色却很难看。所以就有必要修改一下Win10窗口标题栏颜色,怎么修改呢?一起来看一下:

教你怎么样修改Win10标题栏颜色

  修改Win10标题栏颜色步骤

  1、首先在win10系统打开文件夹到C:/Windows/Resources/Themes;复制Aero文件夹,并在原所在文件夹粘贴,如果MSS文件存取被拒,直接略过;把“aero -副本”文件夹更名为“ Windows”;进入Windows文件夹把aero(可能会有后戳名.msstyles)重命名为windows

  2、接着就进入到zh-CN文件夹,把aero.msstyles.mui 文件更名为Windows.msstyles.mui;完成后把C:/Windows/Resources/Themes/文件夹下的aero(.theme)文件复制到桌面,重命名为windows用记事本打开

  3、然后在记事本里找到[VisualStyles]这一区,删掉这一行:Path=%ResourceDir%/Themes/Aero/Aero.msstyles;关闭并保存桌面上的Windows.theme,双击打开系统自动应用新的主题文件,之后窗口标题栏就会呈现指定颜色了,大家可以在设置-个性化里选择想要的颜色。

  以上就是修改Win10标题栏颜色的方法的介绍了,学会这个方法就可以把标题栏换成你喜欢的颜色了。

自定义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中绘制一个按钮到标题栏可以通过以下步骤完成: 1. 首先,创建一个自定义的窗体类,继承自Form类。 2. 在自定义的窗体类中,重写WndProc方法。WndProc方法用于处理窗口消息,包括绘制窗口的各个部分。 3. 在重写的WndProc方法中,找到WM_NCPAINT消息,这个消息表示需要重新绘制非客户区(窗口边框、标题栏等)。 4. 在WM_NCPAINT消息的处理中,可以通过调用Win32 API中的方法绘制自定义的按钮。 5. 使用Graphics类和Rectangle类来绘制按钮的外观,可以通过Handle属性获取窗口的句柄来绘制在标题栏中。 6. 在绘制按钮时,可以通过处理鼠标消息来实现按钮的交互效果,例如点击按钮时改变按钮的颜色或状态。 7. 最后,通过设置窗体的ControlBox属性为false,来隐藏原有的窗口标题栏按钮。 通过以上步骤,我们可以在Winform中实现自定义的标题栏按钮。这样可以增加窗体的个性化和用户交互性,以满足特定应用场景的需求。 ### 回答2: 在WinForm中绘制一个按钮到标题栏可以通过以下步骤实现: 1. 首先,在WinForm窗体的构造函数中添加以下代码: ``` // 设置窗体样式为可绘制标题栏 this.FormBorderStyle = FormBorderStyle.FixedSingle; this.ControlBox = false; ``` 2. 在窗体的`WndProc`方法中重写窗口消息的处理方式,以便实现自定义控件的绘制: ``` protected override void WndProc(ref Message m) { base.WndProc(ref m); const int WM_NCPAINT = 0x85; // 非客户区重绘消息 if (m.Msg == WM_NCPAINT) { IntPtr hDC = GetWindowDC(m.HWnd); if (hDC != IntPtr.Zero) { Graphics g = Graphics.FromHdc(hDC); // 绘制按钮的图标或背景 // ... ReleaseDC(m.HWnd, hDC); } } } ``` 3. 在绘制代码中使用`Graphics`对象的绘图方法来绘制按钮的图标或背景,可以使用`DrawRectangle`、`DrawImage`等方法来绘制按钮的样式。 4. 最后,在窗体的其他事件处理方法中,如点击事件或鼠标移动事件中,可以对按钮进行相应的操作。 通过以上步骤,我们可以实现在WinForm的标题栏中绘制一个按钮,来实现自定义的交互效果。请注意,以上代码仅为示例,具体的绘制逻辑和样式可以根据实际需求进行修改
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值