Ответ 1
Для a ContextMenu
:
Проблема заключается в том, что параметр sender
указывает на элемент в контекстном меню, который был нажат, а не на контекстное меню.
Это простое исправление, потому что каждый MenuItem
предоставляет метод GetContextMenu
, который расскажет вам, что ContextMenu
содержит это пункт меню.
Измените код на следующее:
private void MenuViewDetails_Click(object sender, EventArgs e)
{
// Try to cast the sender to a MenuItem
MenuItem menuItem = sender as MenuItem;
if (menuItem != null)
{
// Retrieve the ContextMenu that contains this MenuItem
ContextMenu menu = menuItem.GetContextMenu();
// Get the control that is displaying this context menu
Control sourceControl = menu.SourceControl;
}
}
При a ContextMenuStrip
:
Это немного изменит ситуацию, если вы используете ContextMenuStrip
вместо ContextMenu
. Два элемента управления не связаны друг с другом, и экземпляр одного не может быть передан экземпляру другого.
Как и раньше, элемент, который был нажат, по-прежнему возвращается в параметре sender
, поэтому вам нужно будет определить ContextMenuStrip
, которому принадлежит этот отдельный пункт меню. Вы делаете это с помощью свойства Owner
. Наконец, вы будете использовать свойство SourceControl
, чтобы определить, какой элемент управления отображает контекстное меню.
Измените свой код следующим образом:
private void MenuViewDetails_Click(object sender, EventArgs e)
{
// Try to cast the sender to a ToolStripItem
ToolStripItem menuItem = sender as ToolStripItem;
if (menuItem != null)
{
// Retrieve the ContextMenuStrip that owns this ToolStripItem
ContextMenuStrip owner = menuItem.Owner as ContextMenuStrip;
if (owner != null)
{
// Get the control that is displaying this context menu
Control sourceControl = owner.SourceControl;
}
}
}