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
- OleCmdHelper.cs
- XmlSchemaChoice.cs
- EmbeddedMailObjectsCollection.cs
- D3DImage.cs
- ValidationSummary.cs
- MatrixCamera.cs
- ScriptRegistrationManager.cs
- ProcessThread.cs
- WebRequestModuleElement.cs
- CopyOfAction.cs
- StructuralComparisons.cs
- GroupStyle.cs
- Highlights.cs
- WebContext.cs
- TextTreeUndoUnit.cs
- BuildProvider.cs
- DebugView.cs
- ContentType.cs
- ClientSettings.cs
- MessageSecurityVersion.cs
- HTMLTagNameToTypeMapper.cs
- CaseCqlBlock.cs
- BrowserCapabilitiesCompiler.cs
- Assembly.cs
- CallTemplateAction.cs
- OleAutBinder.cs
- UnitySerializationHolder.cs
- DecoderNLS.cs
- FloaterParaClient.cs
- InputReferenceExpression.cs
- PageEventArgs.cs
- SerTrace.cs
- TextEditorSelection.cs
- Label.cs
- Empty.cs
- ExpressionBuilder.cs
- EntityWrapper.cs
- MatrixTransform3D.cs
- DbConvert.cs
- EntityViewContainer.cs
- ColorInterpolationModeValidation.cs
- CompositeScriptReferenceEventArgs.cs
- DataGridLinkButton.cs
- ResourceWriter.cs
- InstancePersistenceException.cs
- WriteFileContext.cs
- DurableMessageDispatchInspector.cs
- KeyPullup.cs
- Bitmap.cs
- UnsafeNativeMethods.cs
- WindowsTooltip.cs
- WindowsListViewItemCheckBox.cs
- BitStack.cs
- ComboBoxRenderer.cs
- ParameterBuilder.cs
- DispatchChannelSink.cs
- PropertyChangingEventArgs.cs
- ClipboardData.cs
- TextChange.cs
- BinaryFormatter.cs
- _LoggingObject.cs
- ItemMap.cs
- SequentialActivityDesigner.cs
- VirtualPathProvider.cs
- AngleUtil.cs
- BlurBitmapEffect.cs
- LoginUtil.cs
- MethodBody.cs
- CompilerTypeWithParams.cs
- SpotLight.cs
- HMAC.cs
- DataRowChangeEvent.cs
- VectorAnimationBase.cs
- RIPEMD160Managed.cs
- BuildManagerHost.cs
- XmlWriterSettings.cs
- EventRouteFactory.cs
- CodeDesigner.cs
- RevocationPoint.cs
- BitmapEffectDrawingContextWalker.cs
- LineMetrics.cs
- COM2PictureConverter.cs
- hresults.cs
- SQLStringStorage.cs
- ConfigurationValidatorAttribute.cs
- CapabilitiesPattern.cs
- Utils.cs
- DataColumnChangeEvent.cs
- TextChangedEventArgs.cs
- AdRotator.cs
- ISAPIApplicationHost.cs
- AttachedAnnotationChangedEventArgs.cs
- IDReferencePropertyAttribute.cs
- ExpressionEditorAttribute.cs
- ValueTypeFixupInfo.cs
- UrlMappingsModule.cs
- SettingsPropertyValue.cs
- DirtyTextRange.cs
- RoutingService.cs
- BoundColumn.cs