重绘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 ...
随机推荐
- APP弱网测试方法
常用工具 •利用抓包工具 -Fiddler/Charles•使用chrome浏览器的开发者工具•使用手机自带的限速功能(只适用IOS设备)•需要硬件设备(路由器或者网卡) -NEWT/ATC/ ...
- 利用Python模拟登录pastebin.com
任务 在https://pastebin.com网站注册一个账号,利用python实现用户的自动登录和创建paste.该任务需要分成如下两步利用python实现: 账号的自动登录 paste的自动创建 ...
- Spring Cloud Eureka的自我保护模式与实例下线剔除
之前我说明了Eureka注册中心的保护模式,由于在该模式下不能剔除失效节点,故按原有配置在实际中不剔除总感觉不是太好,所以深入研究了一下.当然,这里重申一下,不管实例是否有效剔除,消费端实现Ribbo ...
- ubuntu 16.04 实现远程图形界面连接
一.在操作系统中用管理员权限安装以下软件 1. 安装xrdp: sudo apt-get install xrdp 2. 安装vnc4server: sudo apt-get install vnc4 ...
- linux (01) linux基础
一.了解linux 都有哪些职位 机房运维 负责服务器的上下架 桌面运维 专业修电脑 修打印机 系统管理员 负责liunux操作系统的维护 运维开发 linux + python 把平时自己手敲 ...
- 201871010123-吴丽丽 《面向对象程序设计(Java)》第十周学习总结
项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业要求在哪里 https://www.cnblogs.com/nwnu-daizh/p/ ...
- 201871010134-周英杰《面向对象程序设计(java)》第十四周学习总结
项目 内容 这个作业属于哪个课程 <https://home.cnblogs.com/u/nwnu-daizh/> 这个作业的要求在哪里 <https://www.cnblogs.c ...
- python调用oracle存储过程
oracle 存储过程 python调用oracle存储过程 -- 通过cx_Oracle连接 import cx_Oracle # 连接数据库 orcl_engine = 'scott/s123@x ...
- mwArray和cv::Mat转化函数 20170812
不是新东西了,但是有必要专门把这两个函数拿出来记录一下. 需要注意的是,Mat2mwArry函数的输入Mat类型是 CV_8UC1,灰度图. 如果要传递多通道图像的话,需要先cv::split()成多 ...
- 03-cmake语法-变量,字符串
CMake的基本数据类型是字符串(不区分大小写),一组字符串在一起称为列表(list). 条件判断中的取值情况如下表: 真 1, ON, YES, TRUE, Y, 非0的数 假 0, OFF, N ...