ContextMenu重绘

简介:

private void cm_DrawItem(object sender, DrawItemEventArgs e)
{
try
{
Color cms1 = SkinForm.GetColor("gv", "abcolor");
Color cms2 = SkinForm.GetColor("gv", "rhbcolor");
Color cms3 = SkinForm.GetColor("gv", "afcolor");

MenuItem mnuItem = (MenuItem)sender;

SolidBrush Brush1 = new SolidBrush(cms1);
SolidBrush Brush2 = new SolidBrush(cms2);
SolidBrush Brush3 = new SolidBrush(cms3);

Pen cmPen = new Pen(SkinForm.GetColor("gv", "asfcolor"));

StringFormat Format = new StringFormat();

if ((e.State & DrawItemState.Selected) != 0)
{
if (this.Enabled)
{
e.Graphics.FillRectangle(Brush1, e.Bounds);
e.Graphics.DrawRectangle(cmPen, e.Bounds.Left, e.Bounds.Y, e.Bounds.Width - 2, e.Bounds.Height - 2);
}
}
else
{
e.Graphics.FillRectangle(Brush2, e.Bounds);
}

if (this.Text != "-")
{
Rectangle DisplayRect = new Rectangle(e.Bounds.Left, e.Bounds.Top + 2, e.Bounds.Width, e.Bounds.Bottom);
Format.Alignment = StringAlignment.Center;

if (this.Enabled)
{
e.Graphics.DrawString(mnuItem.Text, gv_songlist.Font, Brush3, DisplayRect, Format);
}
else
{
e.Graphics.DrawString(mnuItem.Text, gv_songlist.Font, Brush3, DisplayRect, Format);
}
}
else
{
e.Graphics.DrawLine(cmPen, e.Bounds.Left, e.Bounds.Top, e.Bounds.Right, e.Bounds.Top);
}
}
catch
{ }
}

private void cm_MeasureItem(object sender, MeasureItemEventArgs e)
{
try
{
MenuItem mnuItem = (MenuItem)sender;
e.ItemHeight = (int)e.Graphics.MeasureString(Text, gv_songlist.Font).Height + 3;
e.ItemWidth = (int)e.Graphics.MeasureString(Text, gv_songlist.Font).Width + 3;
}
catch
{ }
}

显示:
Win32.POINT point = new Win32.POINT();
Win32.GetCursorPos(ref point);
Win32.SetForegroundWindow(this.Handle);
Win32.TrackPopupMenuEx(this.cm.Handle, 0x40, point.x, point.y, this.Handle, new Win32.TPMPARAMS());

----------------------

public class Win32
{

[DllImport("user32.dll", EntryPoint = "SetForegroundWindow")]
public static extern int SetForegroundWindow(IntPtr hwnd);

[DllImport("user32.dll", EntryPoint = "TrackPopupMenuEx")]
public static extern int TrackPopupMenuEx(
IntPtr hMenu,
int un,
int n1,
int n2,
IntPtr hWnd,
TPMPARAMS lpTPMParams
);


[StructLayout(LayoutKind.Sequential)]
public struct TPMPARAMS
{
public int cbSize;
public RECT rcExclude;
}

[StructLayout(LayoutKind.Sequential)]
public struct RECT
{
public int Left;
public int Top;
public int Right;
public int Bottom;
}


[DllImport("user32.dll", EntryPoint = "GetCursorPos")]
public static extern int GetCursorPos(ref POINT lpPoint);

[StructLayout(LayoutKind.Sequential)]
public struct POINT
{
public int x;
public int y;
}
}




本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/archive/2009/09/24/1573129.html,如需转载请自行联系原作者


相关文章
|
6月前
|
Java API Android开发
22. 【Android教程】滚动条 ScrollView
22. 【Android教程】滚动条 ScrollView
112 2
|
6月前
|
XML Java API
23. 【Android教程】轮播滚动视图:ViewFlipper
23. 【Android教程】轮播滚动视图:ViewFlipper
191 2
|
7月前
自定义View实现点击事件
自定义View实现点击事件
55 2
|
JavaScript
原生js实现鼠标长按事件
原生js实现鼠标长按事件
157 0
|
Android开发 容器
ScrollView(滚动条)
本节带来的是Android基本UI控件中的第十个:ScrollView(滚动条),或者我们应该叫他 竖直滚动条,对应的另外一个水平方向上的滚动条:HorizontalScrollView,先来一发官方文档 的链接:ScrollView,我们可以看到类的结构如下
167 0
|
容器
利用CustomScrollView实现更有趣的滑动效果
本篇介绍了 CustomScrollView 的基本用法以及 SliverAppBar 的使用,通过 SliverAppBar 可以让导航栏的滑动更有趣。
839 0
利用CustomScrollView实现更有趣的滑动效果
|
数据可视化
UGUI系列-Button绑定事件的多种实现
今天分享一下UGUI Button绑定事件的几种方法,以及优点和缺点 有哪些地方不懂的小伙伴也可以联系我的QQ,我的QQ就在博客链接中隐藏着,看能不能找到咯
|
前端开发
scroll-view实现不了滑动效果
scroll-view实现不了滑动效果
274 0
|
容器 定位技术 JavaScript
滑动吸顶效果
使用vue组件构成整体页面,顶部titlebar,中间轮播banner,底部iscroll滑动部分,滑动到吸顶的时候初始化底部iscroll,继而导致页面监听滑动失效;
2284 0