Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / WinForms / Managed / System / WinForms / ContextMenu.cs / 1305376 / ContextMenu.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using Microsoft.Win32; using System; using System.ComponentModel; using System.Diagnostics; using System.Drawing; using System.Runtime.InteropServices; using System.Runtime.Remoting; using System.Security; using System.Security.Permissions; ////// /// This class is used to put context menus on your form and show them for /// controls at runtime. It basically acts like a regular Menu control, /// but can be set for the ContextMenu property that most controls have. /// [ DefaultEvent("Popup"), ] public class ContextMenu : Menu { private EventHandler onPopup; private EventHandler onCollapse; internal Control sourceControl; private RightToLeft rightToLeft = System.Windows.Forms.RightToLeft.Inherit; ////// /// Creates a new ContextMenu object with no items in it by default. /// public ContextMenu() : base(null) { } ////// /// Creates a ContextMenu object with the given MenuItems. /// public ContextMenu(MenuItem[] menuItems) : base(menuItems) { } ////// /// The last control that was acted upon that resulted in this context /// menu being displayed. /// VSWHIDBEY 426099 - add demand for AllWindows. /// [ Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), SRDescription(SR.ContextMenuSourceControlDescr) ] public Control SourceControl { [UIPermission(SecurityAction.Demand, Window=UIPermissionWindow.AllWindows)] get { return sourceControl; } } ////// /// [SRDescription(SR.MenuItemOnInitDescr)] public event EventHandler Popup { add { onPopup += value; } remove { onPopup -= value; } } ///[To be supplied.] ////// /// Fires when the context menu collapses. /// [SRDescription(SR.ContextMenuCollapseDescr)] public event EventHandler Collapse { add { onCollapse += value; } remove { onCollapse -= value; } } ////// /// This is used for international applications where the language /// is written from RightToLeft. When this property is true, /// text alignment and reading order will be from right to left. /// // VSWhidbey 164244: Add a DefaultValue attribute so that the Reset context menu becomes // available in the Property Grid but the default value remains No. [ Localizable(true), DefaultValue(RightToLeft.No), SRDescription(SR.MenuRightToLeftDescr) ] public virtual RightToLeft RightToLeft { get { if (System.Windows.Forms.RightToLeft.Inherit == rightToLeft) { if (sourceControl != null) { return ((Control)sourceControl).RightToLeft; } else { return RightToLeft.No; } } else { return rightToLeft; } } set { //valid values are 0x0 to 0x2. if (!ClientUtils.IsEnumValid(value, (int)value, (int)RightToLeft.No, (int)RightToLeft.Inherit)){ throw new InvalidEnumArgumentException("RightToLeft", (int)value, typeof(RightToLeft)); } if (RightToLeft != value) { rightToLeft = value; UpdateRtl((value == System.Windows.Forms.RightToLeft.Yes)); } } } internal override bool RenderIsRightToLeft { get { return (rightToLeft == System.Windows.Forms.RightToLeft.Yes); } } ////// /// Fires the popup event /// protected internal virtual void OnPopup(EventArgs e) { if (onPopup != null) { onPopup(this, e); } } ////// /// Fires the collapse event /// protected internal virtual void OnCollapse(EventArgs e) { if (onCollapse != null) { onCollapse(this, e); } } ////// /// ///[ System.Security.Permissions.SecurityPermissionAttribute(System.Security.Permissions.SecurityAction.LinkDemand, Flags=System.Security.Permissions.SecurityPermissionFlag.UnmanagedCode), System.Security.Permissions.SecurityPermissionAttribute(System.Security.Permissions.SecurityAction.InheritanceDemand, Flags=System.Security.Permissions.SecurityPermissionFlag.UnmanagedCode) ] protected internal virtual bool ProcessCmdKey(ref Message msg, Keys keyData, Control control) { sourceControl = control; return ProcessCmdKey(ref msg, keyData); } private void ResetRightToLeft() { RightToLeft = RightToLeft.No; } /// /// /// Returns true if the RightToLeft should be persisted in code gen. /// internal virtual bool ShouldSerializeRightToLeft() { if (System.Windows.Forms.RightToLeft.Inherit == rightToLeft) { return false; } return true; } ////// /// Displays the context menu at the specified position. This method /// doesn't return until the menu is dismissed. /// public void Show(Control control, Point pos) { Show(control, pos, NativeMethods.TPM_VERTICAL | NativeMethods.TPM_RIGHTBUTTON); } ////// /// Displays the context menu at the specified position. This method /// doesn't return until the menu is dismissed. /// public void Show(Control control, Point pos, LeftRightAlignment alignment) { // This code below looks wrong but it's correct. // [....] Left alignment means we want the menu to show up left of the point it is invoked from. // We specify TPM_RIGHTALIGN which tells win32 to align the right side of this // menu with the point (which aligns it Left visually) if (alignment == LeftRightAlignment.Left) { Show(control, pos, NativeMethods.TPM_VERTICAL | NativeMethods.TPM_RIGHTBUTTON | NativeMethods.TPM_RIGHTALIGN); } else { Show(control, pos, NativeMethods.TPM_VERTICAL | NativeMethods.TPM_RIGHTBUTTON | NativeMethods.TPM_LEFTALIGN); } } private void Show(Control control, Point pos, int flags) { if (control == null) throw new ArgumentNullException("control"); if (!control.IsHandleCreated || !control.Visible) throw new ArgumentException(SR.GetString(SR.ContextMenuInvalidParent), "control"); sourceControl = control; OnPopup(EventArgs.Empty); pos = control.PointToScreen(pos); SafeNativeMethods.TrackPopupMenuEx(new HandleRef(this, Handle), flags, pos.X, pos.Y, new HandleRef(control, control.Handle), null); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using Microsoft.Win32; using System; using System.ComponentModel; using System.Diagnostics; using System.Drawing; using System.Runtime.InteropServices; using System.Runtime.Remoting; using System.Security; using System.Security.Permissions; ////// /// This class is used to put context menus on your form and show them for /// controls at runtime. It basically acts like a regular Menu control, /// but can be set for the ContextMenu property that most controls have. /// [ DefaultEvent("Popup"), ] public class ContextMenu : Menu { private EventHandler onPopup; private EventHandler onCollapse; internal Control sourceControl; private RightToLeft rightToLeft = System.Windows.Forms.RightToLeft.Inherit; ////// /// Creates a new ContextMenu object with no items in it by default. /// public ContextMenu() : base(null) { } ////// /// Creates a ContextMenu object with the given MenuItems. /// public ContextMenu(MenuItem[] menuItems) : base(menuItems) { } ////// /// The last control that was acted upon that resulted in this context /// menu being displayed. /// VSWHIDBEY 426099 - add demand for AllWindows. /// [ Browsable(false), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), SRDescription(SR.ContextMenuSourceControlDescr) ] public Control SourceControl { [UIPermission(SecurityAction.Demand, Window=UIPermissionWindow.AllWindows)] get { return sourceControl; } } ////// /// [SRDescription(SR.MenuItemOnInitDescr)] public event EventHandler Popup { add { onPopup += value; } remove { onPopup -= value; } } ///[To be supplied.] ////// /// Fires when the context menu collapses. /// [SRDescription(SR.ContextMenuCollapseDescr)] public event EventHandler Collapse { add { onCollapse += value; } remove { onCollapse -= value; } } ////// /// This is used for international applications where the language /// is written from RightToLeft. When this property is true, /// text alignment and reading order will be from right to left. /// // VSWhidbey 164244: Add a DefaultValue attribute so that the Reset context menu becomes // available in the Property Grid but the default value remains No. [ Localizable(true), DefaultValue(RightToLeft.No), SRDescription(SR.MenuRightToLeftDescr) ] public virtual RightToLeft RightToLeft { get { if (System.Windows.Forms.RightToLeft.Inherit == rightToLeft) { if (sourceControl != null) { return ((Control)sourceControl).RightToLeft; } else { return RightToLeft.No; } } else { return rightToLeft; } } set { //valid values are 0x0 to 0x2. if (!ClientUtils.IsEnumValid(value, (int)value, (int)RightToLeft.No, (int)RightToLeft.Inherit)){ throw new InvalidEnumArgumentException("RightToLeft", (int)value, typeof(RightToLeft)); } if (RightToLeft != value) { rightToLeft = value; UpdateRtl((value == System.Windows.Forms.RightToLeft.Yes)); } } } internal override bool RenderIsRightToLeft { get { return (rightToLeft == System.Windows.Forms.RightToLeft.Yes); } } ////// /// Fires the popup event /// protected internal virtual void OnPopup(EventArgs e) { if (onPopup != null) { onPopup(this, e); } } ////// /// Fires the collapse event /// protected internal virtual void OnCollapse(EventArgs e) { if (onCollapse != null) { onCollapse(this, e); } } ////// /// ///[ System.Security.Permissions.SecurityPermissionAttribute(System.Security.Permissions.SecurityAction.LinkDemand, Flags=System.Security.Permissions.SecurityPermissionFlag.UnmanagedCode), System.Security.Permissions.SecurityPermissionAttribute(System.Security.Permissions.SecurityAction.InheritanceDemand, Flags=System.Security.Permissions.SecurityPermissionFlag.UnmanagedCode) ] protected internal virtual bool ProcessCmdKey(ref Message msg, Keys keyData, Control control) { sourceControl = control; return ProcessCmdKey(ref msg, keyData); } private void ResetRightToLeft() { RightToLeft = RightToLeft.No; } /// /// /// Returns true if the RightToLeft should be persisted in code gen. /// internal virtual bool ShouldSerializeRightToLeft() { if (System.Windows.Forms.RightToLeft.Inherit == rightToLeft) { return false; } return true; } ////// /// Displays the context menu at the specified position. This method /// doesn't return until the menu is dismissed. /// public void Show(Control control, Point pos) { Show(control, pos, NativeMethods.TPM_VERTICAL | NativeMethods.TPM_RIGHTBUTTON); } ////// /// Displays the context menu at the specified position. This method /// doesn't return until the menu is dismissed. /// public void Show(Control control, Point pos, LeftRightAlignment alignment) { // This code below looks wrong but it's correct. // [....] Left alignment means we want the menu to show up left of the point it is invoked from. // We specify TPM_RIGHTALIGN which tells win32 to align the right side of this // menu with the point (which aligns it Left visually) if (alignment == LeftRightAlignment.Left) { Show(control, pos, NativeMethods.TPM_VERTICAL | NativeMethods.TPM_RIGHTBUTTON | NativeMethods.TPM_RIGHTALIGN); } else { Show(control, pos, NativeMethods.TPM_VERTICAL | NativeMethods.TPM_RIGHTBUTTON | NativeMethods.TPM_LEFTALIGN); } } private void Show(Control control, Point pos, int flags) { if (control == null) throw new ArgumentNullException("control"); if (!control.IsHandleCreated || !control.Visible) throw new ArgumentException(SR.GetString(SR.ContextMenuInvalidParent), "control"); sourceControl = control; OnPopup(EventArgs.Empty); pos = control.PointToScreen(pos); SafeNativeMethods.TrackPopupMenuEx(new HandleRef(this, Handle), flags, pos.X, pos.Y, new HandleRef(control, control.Handle), null); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DataBindingHandlerAttribute.cs
- DragEventArgs.cs
- UInt16.cs
- SafeArrayTypeMismatchException.cs
- IPGlobalProperties.cs
- TabRenderer.cs
- ClockGroup.cs
- DataGridHeaderBorder.cs
- IPPacketInformation.cs
- BitmapFrameDecode.cs
- RelationshipConverter.cs
- GenericWebPart.cs
- OdbcInfoMessageEvent.cs
- ListItemViewAttribute.cs
- MDIControlStrip.cs
- SqlBooleanizer.cs
- DesignerOptionService.cs
- InkPresenter.cs
- StatusStrip.cs
- RequestQueue.cs
- IsolatedStorage.cs
- COM2EnumConverter.cs
- EditorPartCollection.cs
- EventEntry.cs
- FontFamilyConverter.cs
- SortExpressionBuilder.cs
- ApplicationHost.cs
- XmlSyndicationContent.cs
- XmlSchemaElement.cs
- Pair.cs
- _LocalDataStore.cs
- Iis7Helper.cs
- KeyTimeConverter.cs
- Unit.cs
- HostingPreferredMapPath.cs
- NumberFunctions.cs
- SettingsPropertyWrongTypeException.cs
- SafeNativeMethods.cs
- DependencyPropertyHelper.cs
- BindingGroup.cs
- XmlCharCheckingWriter.cs
- WeakReferenceList.cs
- InlineObject.cs
- CompensatableTransactionScopeActivityDesigner.cs
- SQLMembershipProvider.cs
- MailWebEventProvider.cs
- EncoderReplacementFallback.cs
- ReverseInheritProperty.cs
- InvalidPipelineStoreException.cs
- Size.cs
- CodeDelegateInvokeExpression.cs
- Baml2006Reader.cs
- XmlElementCollection.cs
- DispatcherHooks.cs
- VarRefManager.cs
- IntSecurity.cs
- StringHandle.cs
- AsyncCompletedEventArgs.cs
- ToolboxCategory.cs
- SplitterEvent.cs
- XmlConvert.cs
- InputLanguageProfileNotifySink.cs
- DataGridTableCollection.cs
- webclient.cs
- DataSetSchema.cs
- IntegerValidator.cs
- NonBatchDirectoryCompiler.cs
- XmlDataImplementation.cs
- Attributes.cs
- GenericWebPart.cs
- MasterPageBuildProvider.cs
- BezierSegment.cs
- LayoutEditorPart.cs
- TypeToken.cs
- TextBoxDesigner.cs
- PolicyUtility.cs
- MetadataCache.cs
- PagedControl.cs
- DocumentPageViewAutomationPeer.cs
- TextInfo.cs
- DesignerMetadata.cs
- SqlDataSourceParameterParser.cs
- SapiRecoInterop.cs
- TypedServiceOperationListItem.cs
- SoapClientProtocol.cs
- SiteMapDataSource.cs
- ProfileSettingsCollection.cs
- DispatcherFrame.cs
- _Semaphore.cs
- CardSpacePolicyElement.cs
- DrawListViewItemEventArgs.cs
- AnimationLayer.cs
- TextRange.cs
- NativeMethods.cs
- UnknownWrapper.cs
- IndexExpression.cs
- HtmlTable.cs
- ImageAttributes.cs
- ObjectHelper.cs
- PropertyChangingEventArgs.cs