重绘MenuStrip 控件
重绘MenuStrip控件
效果如图:
首先添加 CustomProfessionalRenderer类 用于重绘控件菜单样式
/// <summary>
/// 自定义MenuStrip 控件菜单样式类
/// </summary>
public class CustomProfessionalRenderer : ToolStripProfessionalRenderer
{
private Color _startColor = Color.White;//选中的渐变开始颜色
private Color _endCoolor = Color.Blue;//选中的渐变颜色结束值
public CustomProfessionalRenderer()
: base()
{
}
////public CustomProfessionalRenderer(Color startColor, Color endColor)
//// : base()
////{
//// _startColor = startColor;
//// _endCoolor = endColor;
////} public Color StartColor
{
get { return _startColor; }
set
{
_startColor = value;
}
} public Color EndColor
{
get { return _endCoolor; }
set
{
_endCoolor = value;
}
} /// <summary>
/// 获取圆角矩形区域 radius=直径
/// </summary>
/// <param name="rect"></param>
/// <param name="radius"></param>
/// <returns></returns>
public static GraphicsPath GetRoundedRectPath(Rectangle rect, int radius)
{
int diameter = radius;
Rectangle arcRect = new Rectangle(rect.Location, new Size(diameter, diameter));
GraphicsPath path = new GraphicsPath(); // 左上角
path.AddArc(arcRect, , ); // 右上角
arcRect.X = rect.Right - diameter;
path.AddArc(arcRect, , ); // 右下角
arcRect.Y = rect.Bottom - diameter;
path.AddArc(arcRect, , ); // 左下角
arcRect.X = rect.Left;
path.AddArc(arcRect, , );
path.CloseFigure();
return path;
} /// <summary>
/// 渲染背景 包括menustrip背景 toolstripDropDown背景
/// </summary>
/// <param name="e"></param>
protected override void OnRenderToolStripBackground(ToolStripRenderEventArgs e)
{
ToolStrip toolStrip = e.ToolStrip;
Graphics g = e.Graphics;
g.SmoothingMode = SmoothingMode.HighQuality;//抗锯齿
Rectangle bounds = e.AffectedBounds;
LinearGradientBrush lgbrush = new LinearGradientBrush(new Point(, ), new Point(, toolStrip.Height), Color.FromArgb(, _startColor), Color.FromArgb(, _endCoolor));
if (toolStrip is MenuStrip)
{
//由menuStrip的Paint方法定义 这里不做操作 }
else if (toolStrip is ToolStripDropDown)
{
int diameter = ;//直径
GraphicsPath path = new GraphicsPath();
Rectangle rect = new Rectangle(Point.Empty, toolStrip.Size);
Rectangle arcRect = new Rectangle(rect.Location, new Size(diameter, diameter)); path.AddLine(, , , );
// 右上角
arcRect.X = rect.Right - diameter;
path.AddArc(arcRect, , ); // 右下角
arcRect.Y = rect.Bottom - diameter;
path.AddArc(arcRect, , ); // 左下角
arcRect.X = rect.Left;
path.AddArc(arcRect, , );
path.CloseFigure();
toolStrip.Region = new Region(path);
g.FillPath(lgbrush, path);
}
else
{
base.OnRenderToolStripBackground(e);
}
} //渲染边框 不绘制边框
protected override void OnRenderToolStripBorder(ToolStripRenderEventArgs e)
{
//不调用基类的方法 屏蔽掉该方法 去掉边框
} //渲染箭头 更改箭头颜色
protected override void OnRenderArrow(ToolStripArrowRenderEventArgs e)
{
e.ArrowColor = _endCoolor;
base.OnRenderArrow(e);
} /// <summary>
/// 渲染项 不调用基类同名方法
/// </summary>
/// <param name="e"></param>
protected override void OnRenderMenuItemBackground(ToolStripItemRenderEventArgs e)
{
Graphics g = e.Graphics;
ToolStripItem item = e.Item;
ToolStrip toolstrip = e.ToolStrip; //渲染顶级项
if (toolstrip is MenuStrip)
{
LinearGradientBrush lgbrush = new LinearGradientBrush(new Point(, ), new Point(, item.Height), Color.FromArgb(, _endCoolor), Color.FromArgb(, _startColor));
if (e.Item.Selected)//选中
{
GraphicsPath gp = GetRoundedRectPath(new Rectangle(new Point(, ), item.Size), );
g.FillPath(lgbrush, gp);
}
if (item.Pressed)//按下
{
//创建上面左右2圆角的矩形路径
GraphicsPath path = new GraphicsPath();
int diameter = ;
Rectangle rect = new Rectangle(Point.Empty, item.Size);
Rectangle arcRect = new Rectangle(rect.Location, new Size(diameter, diameter));
// 左上角
path.AddArc(arcRect, , );
// 右上角
arcRect.X = rect.Right - diameter;
path.AddArc(arcRect, , );
path.AddLine(new Point(rect.Width, rect.Height), new Point(, rect.Height));
path.CloseFigure();
//填充路径
g.FillPath(lgbrush, path);
//g.FillRectangle(Brushes.White, new Rectangle(Point.Empty, item.Size));
}
}
else if (toolstrip is ToolStripDropDown)//渲染下拉项
{
g.SmoothingMode = SmoothingMode.HighQuality;
LinearGradientBrush lgbrush = new LinearGradientBrush(new Point(, ), new Point(item.Width, ), Color.FromArgb(, _startColor), Color.FromArgb(, _endCoolor));
if (item.Selected)
{
GraphicsPath gp = GetRoundedRectPath(new Rectangle(, , item.Width, item.Height), );
g.FillPath(lgbrush, gp);
}
}
else
{
base.OnRenderMenuItemBackground(e);
}
} /// <summary>
/// 渲染分界线
/// </summary>
/// <param name="e"></param>
protected override void OnRenderSeparator(ToolStripSeparatorRenderEventArgs e)
{
Graphics g = e.Graphics;
LinearGradientBrush lgbrush = new LinearGradientBrush(new Point(, ), new Point(e.Item.Width, ), _startColor, Color.FromArgb(, _endCoolor));
g.FillRectangle(lgbrush, new Rectangle(, e.Item.Height / , e.Item.Width, ));
//base.OnRenderSeparator(e);
} /// <summary>
/// 渲染图片区域 下拉菜单左边的图片区域
/// </summary>
/// <param name="e"></param>
protected override void OnRenderImageMargin(ToolStripRenderEventArgs e)
{
// base.OnRenderImageMargin(e);
//屏蔽掉左边图片竖条
} }
其次添加类 CustomMenuStripControl 继承MenuStrip类
public partial class CustomMenuStripControl : MenuStrip
{
private Color _startColor = Color.White;//选中的渐变开始颜色
private Color _endCoolor = Color.Blue;//选中的渐变颜色结束值
private CustomProfessionalRenderer render;
public CustomMenuStripControl()
{
render = new CustomProfessionalRenderer();
this.Renderer = render;
} [Category("wyl")]
[Description("选中渐变开始的颜色")]
public Color StartColor
{
get { return _startColor; }
set
{
_startColor = value;
render.StartColor = value;
base.Invalidate();
}
} [Category("wyl")]
[Description("选中渐变结束的颜色")]
public Color EndColor
{
get { return _endCoolor; }
set
{
_endCoolor = value;
render.EndColor = value;
base.Invalidate();
}
}
}
完成。
CustomProfessionalRenderer类样式可以用于右键菜单按键样式。只要修改其属性contextMenuStrip1.Renderer = new CustomProfessionalRenderer();
重绘MenuStrip 控件的更多相关文章
- 自行实现透明的控件如Panel GroupBox(使用不需要重绘父控件的效果,一切都因为窗口有了WS_EX_TRANSPARENT属性)
CSDN的Blog开通了.我想这里的Blog作为今后自己回答别人问题的时候,收藏答案的地方很不错呢. 因为社区的贴子早晚都会沉下去,查找起来很不方便,甚至再也找不到呢. Q: http://commu ...
- 重绘panel控件,实现panel的阴影效果
最近想在项目中添加一个要有阴影的panel控件,找了好多资料,最后通过采用图片的方式实现了panel的阴影效果,效果图如下: 重绘代码如下: using System; using System.Co ...
- android控件拖动,移动、解决父布局重绘时控件回到原点
这是主要代码: 保证其params发生改变,相对于父布局的位置就能达到位置移动到原来的位置 // 每次移动都要设置其layout,不然由于父布局可能嵌套listview,当父布局发生改变冲毁(如下拉刷 ...
- C# Winform学习---MDI窗体的设计,PictureBox控件(图片上一页下一页),Timer控件,MenuStrip控件
一.MDI窗体的设计 1.MDI简介 MDI(Multiple Document Interface)就是所谓的多文档界面,与此对应就有单文档界面 (SDI), 它是微软公司从Windows 2.0下 ...
- Menustrip控件和ContextMenustrip控件
Menustrip 控件是由System.Windows.Forms.Menustrip类提供,取代了以前的MainMenu控件,是应用程序菜单结构的容器,在建立菜单时,要给Menustrip控件添加 ...
- 自绘Tab控件
自绘tab按钮效果图如下: 使用例子: MyTabControl *tabControl = NULL; tabControl = new MyTabControl();tabControl-> ...
- ToolStrip和MenuStrip控件簡介及常用屬性(转)
ToolStrip和MenuStrip實際上是相同的控件,因為MenuStrip直接派生於ToolStrip.也就是說ToolStrip可以做的工作,MenuStrip也能完成. ToolStrip( ...
- C#自绘蒙版控件,带延时隐藏显示,拷贝底图功能
using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; u ...
- (转载)C#工具箱Menustrip控件中分割线的设置方法
最近编C#程序,因为初学,不是太清楚,碰到了toolstripMenu中分割线设置的问题.遍寻中文网页,都是语言不详的,甚是呕人. 上网找了个外文网站,给的答案甚是详细,先贴在下面. http://w ...
随机推荐
- 【AI测试】也许这有你想知道的人工智能 (AI) 测试--开篇
人工智能测试 什么是人工智能,人工智能是怎么测试的.可能是大家一开始最想了解的. 大家看图中关于人工智能的定义.通俗点来说呢,就是 让机器实现原来只有人类才能完成的任务:比如看懂照片,听懂说话,思考等 ...
- 你所不知的 PHP 断言(assert)
PHP 中的断言常用于调试,检查一个表达式或语句是否为 FALSE.本文带你重新认识 PHP assert() 函数的神(Qi)通(Yin)广(Ji)大(Qiao). 本文基于 PHP Version ...
- Google Analytics 学习笔记四 —— GA的Channels划分规则
一.流量的Source.Medium和Campaigns 1.Source Source或traffic source通常表示流量的来源,一般通过urm_source参数跟踪 在GA中,流量来源的名字 ...
- linux 线程基础
线程基础函数 查看进程中有多少个线程,查看线程的LWP ps -Lf 进程ID(pid) 执行结果:LWP列 y:~$ ps -Lf 1887 UID PID PPID LWP C NLWP STIM ...
- C++ vector初始化方式
C++的初始化方法很多,各种初始化方法有一些不同. (1): vector<int> ilist1; 默认初始化,vector为空, size为0,表明容器中没有元素,而且 capacit ...
- Gym101667 H. Rock Paper Scissors
将第二个字符串改成能赢对方时对方的字符并倒序后,字符串匹配就是卷积的过程. 那么就枚举字符做三次卷积即可. #include <bits/stdc++.h> struct Complex ...
- vmware centos 桥接模式 联网记录
参考这篇文章 https://www.cnblogs.com/jasmine-Jobs/p/5928218.html 记得要修改/etc/sysconfig/network文件的网关配置,因为ip变动 ...
- Win10提示 该文件没有与之关联的程序来执行操作
在Win10 2018年更新系统中,如果你手动删除注册表里的快捷箭头注册项,就会打开固定到底部任务栏的应用就会报错,要想恢复正常,先手动恢复原来删除的注册表项. 注册表位置:HKEY_CLASSES_ ...
- 10.24考试题解qwq
考点难度都很合适的一套题目,大概在day1到day2之前 T1 猴猴最喜欢在树上玩耍,一天猴猴又跳上了一棵树,这棵树有N个苹果,每个苹果有一个编号,分别为0~N-1,它们之间由N-1个树枝相连,猴猴可 ...
- Linux性能优化实战学习笔记:第三十二讲
一.上节总结 专栏更新至今,四大基础模块的第三个模块——文件系统和磁盘 I/O 篇,我们就已经学完了.很开心你还没有掉队,仍然在积极学习思考和实践操作,并且热情地留言与讨论. 今天是性能优化的第四期. ...