Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / WinForms / Managed / System / WinForms / ToolStripRendererSwitcher.cs / 1 / ToolStripRendererSwitcher.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using System; using System.Drawing; using System.Collections.Specialized; using System.ComponentModel; // this class encapsulates the logic for Renderer and RenderMode so it can // be shared across classes. internal class ToolStripRendererSwitcher { private static readonly int stateUseDefaultRenderer = BitVector32.CreateMask(); private static readonly int stateAttachedRendererChanged = BitVector32.CreateMask(stateUseDefaultRenderer); private ToolStripRenderer renderer = null; private Type currentRendererType = typeof(System.Type); private BitVector32 state = new BitVector32(); private ToolStripRenderMode defaultRenderMode = ToolStripRenderMode.ManagerRenderMode; public ToolStripRendererSwitcher(Control owner, ToolStripRenderMode defaultRenderMode) : this(owner) { this.defaultRenderMode = defaultRenderMode; this.RenderMode = defaultRenderMode; } public ToolStripRendererSwitcher(Control owner) { state[stateUseDefaultRenderer] = true; state[stateAttachedRendererChanged] = false; owner.Disposed += new EventHandler(OnControlDisposed); owner.VisibleChanged += new EventHandler(OnControlVisibleChanged); if (owner.Visible) { OnControlVisibleChanged(owner, EventArgs.Empty); } } public ToolStripRenderer Renderer { get { if (RenderMode == ToolStripRenderMode.ManagerRenderMode) { return ToolStripManager.Renderer; } // always return a valid renderer so our paint code // doesn't have to be bogged down by checks for null. state[stateUseDefaultRenderer] = false; if (renderer == null) { Renderer = ToolStripManager.CreateRenderer(RenderMode); } return renderer; } set { // if the value happens to be null, the next get // will autogenerate a new ToolStripRenderer. if (renderer != value) { state[stateUseDefaultRenderer] = (value == null); renderer = value; currentRendererType = (renderer != null) ? renderer.GetType() : typeof(System.Type); OnRendererChanged(EventArgs.Empty); } } } public ToolStripRenderMode RenderMode { get { if (state[stateUseDefaultRenderer]) { return ToolStripRenderMode.ManagerRenderMode; } if (renderer != null && !renderer.IsAutoGenerated) { return ToolStripRenderMode.Custom; } // check the type of the currently set renderer. // types are cached as this may be called frequently. if (currentRendererType == ToolStripManager.ProfessionalRendererType) { return ToolStripRenderMode.Professional; } if (currentRendererType == ToolStripManager.SystemRendererType) { return ToolStripRenderMode.System; } return ToolStripRenderMode.Custom; } set { //valid values are 0x0 to 0x3 if (!ClientUtils.IsEnumValid(value, (int)value, (int)ToolStripRenderMode.Custom, (int)ToolStripRenderMode.ManagerRenderMode)) { throw new InvalidEnumArgumentException("value", (int)value, typeof(ToolStripRenderMode)); } if (value == ToolStripRenderMode.Custom) { throw new NotSupportedException(SR.GetString(SR.ToolStripRenderModeUseRendererPropertyInstead)); } if (value == ToolStripRenderMode.ManagerRenderMode) { if (!state[stateUseDefaultRenderer] ) { state[stateUseDefaultRenderer] = true; OnRendererChanged(EventArgs.Empty); } } else { state[stateUseDefaultRenderer] = false; Renderer = ToolStripManager.CreateRenderer(value); } } } public event EventHandler RendererChanged; private void OnRendererChanged(EventArgs e) { if (this.RendererChanged != null) { this.RendererChanged(this, e); } } private void OnDefaultRendererChanged(object sender, EventArgs e) { if (state[stateUseDefaultRenderer]) { OnRendererChanged(e); } } private void OnControlDisposed(object sender, EventArgs e) { if (state[stateAttachedRendererChanged]) { ToolStripManager.RendererChanged -= new EventHandler(OnDefaultRendererChanged); state[stateAttachedRendererChanged] = false; } } private void OnControlVisibleChanged(object sender, EventArgs e) { Control control = sender as Control; if (control != null) { if (control.Visible) { if (!state[stateAttachedRendererChanged]) { ToolStripManager.RendererChanged += new EventHandler(OnDefaultRendererChanged); state[stateAttachedRendererChanged] = true; } } else { if (state[stateAttachedRendererChanged]) { ToolStripManager.RendererChanged -= new EventHandler(OnDefaultRendererChanged); state[stateAttachedRendererChanged] = false; } } } } public bool ShouldSerializeRenderMode() { // We should NEVER serialize custom. return (RenderMode != defaultRenderMode && RenderMode != ToolStripRenderMode.Custom); } public void ResetRenderMode() { this.RenderMode = defaultRenderMode; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Windows.Forms { using System; using System.Drawing; using System.Collections.Specialized; using System.ComponentModel; // this class encapsulates the logic for Renderer and RenderMode so it can // be shared across classes. internal class ToolStripRendererSwitcher { private static readonly int stateUseDefaultRenderer = BitVector32.CreateMask(); private static readonly int stateAttachedRendererChanged = BitVector32.CreateMask(stateUseDefaultRenderer); private ToolStripRenderer renderer = null; private Type currentRendererType = typeof(System.Type); private BitVector32 state = new BitVector32(); private ToolStripRenderMode defaultRenderMode = ToolStripRenderMode.ManagerRenderMode; public ToolStripRendererSwitcher(Control owner, ToolStripRenderMode defaultRenderMode) : this(owner) { this.defaultRenderMode = defaultRenderMode; this.RenderMode = defaultRenderMode; } public ToolStripRendererSwitcher(Control owner) { state[stateUseDefaultRenderer] = true; state[stateAttachedRendererChanged] = false; owner.Disposed += new EventHandler(OnControlDisposed); owner.VisibleChanged += new EventHandler(OnControlVisibleChanged); if (owner.Visible) { OnControlVisibleChanged(owner, EventArgs.Empty); } } public ToolStripRenderer Renderer { get { if (RenderMode == ToolStripRenderMode.ManagerRenderMode) { return ToolStripManager.Renderer; } // always return a valid renderer so our paint code // doesn't have to be bogged down by checks for null. state[stateUseDefaultRenderer] = false; if (renderer == null) { Renderer = ToolStripManager.CreateRenderer(RenderMode); } return renderer; } set { // if the value happens to be null, the next get // will autogenerate a new ToolStripRenderer. if (renderer != value) { state[stateUseDefaultRenderer] = (value == null); renderer = value; currentRendererType = (renderer != null) ? renderer.GetType() : typeof(System.Type); OnRendererChanged(EventArgs.Empty); } } } public ToolStripRenderMode RenderMode { get { if (state[stateUseDefaultRenderer]) { return ToolStripRenderMode.ManagerRenderMode; } if (renderer != null && !renderer.IsAutoGenerated) { return ToolStripRenderMode.Custom; } // check the type of the currently set renderer. // types are cached as this may be called frequently. if (currentRendererType == ToolStripManager.ProfessionalRendererType) { return ToolStripRenderMode.Professional; } if (currentRendererType == ToolStripManager.SystemRendererType) { return ToolStripRenderMode.System; } return ToolStripRenderMode.Custom; } set { //valid values are 0x0 to 0x3 if (!ClientUtils.IsEnumValid(value, (int)value, (int)ToolStripRenderMode.Custom, (int)ToolStripRenderMode.ManagerRenderMode)) { throw new InvalidEnumArgumentException("value", (int)value, typeof(ToolStripRenderMode)); } if (value == ToolStripRenderMode.Custom) { throw new NotSupportedException(SR.GetString(SR.ToolStripRenderModeUseRendererPropertyInstead)); } if (value == ToolStripRenderMode.ManagerRenderMode) { if (!state[stateUseDefaultRenderer] ) { state[stateUseDefaultRenderer] = true; OnRendererChanged(EventArgs.Empty); } } else { state[stateUseDefaultRenderer] = false; Renderer = ToolStripManager.CreateRenderer(value); } } } public event EventHandler RendererChanged; private void OnRendererChanged(EventArgs e) { if (this.RendererChanged != null) { this.RendererChanged(this, e); } } private void OnDefaultRendererChanged(object sender, EventArgs e) { if (state[stateUseDefaultRenderer]) { OnRendererChanged(e); } } private void OnControlDisposed(object sender, EventArgs e) { if (state[stateAttachedRendererChanged]) { ToolStripManager.RendererChanged -= new EventHandler(OnDefaultRendererChanged); state[stateAttachedRendererChanged] = false; } } private void OnControlVisibleChanged(object sender, EventArgs e) { Control control = sender as Control; if (control != null) { if (control.Visible) { if (!state[stateAttachedRendererChanged]) { ToolStripManager.RendererChanged += new EventHandler(OnDefaultRendererChanged); state[stateAttachedRendererChanged] = true; } } else { if (state[stateAttachedRendererChanged]) { ToolStripManager.RendererChanged -= new EventHandler(OnDefaultRendererChanged); state[stateAttachedRendererChanged] = false; } } } } public bool ShouldSerializeRenderMode() { // We should NEVER serialize custom. return (RenderMode != defaultRenderMode && RenderMode != ToolStripRenderMode.Custom); } public void ResetRenderMode() { this.RenderMode = defaultRenderMode; } } } // 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
- DecimalStorage.cs
- ContractCodeDomInfo.cs
- AsymmetricCryptoHandle.cs
- recordstatefactory.cs
- OdbcUtils.cs
- QilScopedVisitor.cs
- ScriptRegistrationManager.cs
- SizeFConverter.cs
- ThreadSafeMessageFilterTable.cs
- Timer.cs
- DiscreteKeyFrames.cs
- PersistChildrenAttribute.cs
- XmlSyndicationContent.cs
- ColorDialog.cs
- MediaSystem.cs
- FirstQueryOperator.cs
- MiniAssembly.cs
- ReliabilityContractAttribute.cs
- XmlSignatureProperties.cs
- SemanticResolver.cs
- FieldValue.cs
- DataSet.cs
- EntityDesignerUtils.cs
- VerificationAttribute.cs
- MouseGestureConverter.cs
- DependencyPropertyHelper.cs
- SqlAliaser.cs
- InvalidFilterCriteriaException.cs
- DictionarySectionHandler.cs
- NotConverter.cs
- BindUriHelper.cs
- GiveFeedbackEvent.cs
- Control.cs
- ErrorTableItemStyle.cs
- TextReader.cs
- XmlTextEncoder.cs
- XhtmlBasicTextViewAdapter.cs
- WebBrowser.cs
- DataGridViewEditingControlShowingEventArgs.cs
- RadioButtonBaseAdapter.cs
- TileBrush.cs
- SelectionUIService.cs
- TemplatedAdorner.cs
- WebServiceHandler.cs
- DataGridViewComboBoxColumnDesigner.cs
- EventSchemaTraceListener.cs
- BindingObserver.cs
- IdnElement.cs
- PeerTransportListenAddressConverter.cs
- DataRelationCollection.cs
- SecurityTokenParametersEnumerable.cs
- Random.cs
- XPathNavigatorReader.cs
- XPathNavigatorKeyComparer.cs
- PartialArray.cs
- TypeAccessException.cs
- DbConnectionStringCommon.cs
- SetStateEventArgs.cs
- ControlBuilder.cs
- HelpFileFileNameEditor.cs
- DiscoveryServiceExtension.cs
- CachedRequestParams.cs
- QuadraticBezierSegment.cs
- AppDomainFactory.cs
- XmlWriterDelegator.cs
- DayRenderEvent.cs
- CompoundFileIOPermission.cs
- BufferCache.cs
- Registry.cs
- RelativeSource.cs
- ToolStripDropDownButton.cs
- DecoderNLS.cs
- COM2Enum.cs
- TypeConverterHelper.cs
- DefaultAsyncDataDispatcher.cs
- WebZoneDesigner.cs
- X509Utils.cs
- AuthenticationServiceManager.cs
- UserPreferenceChangedEventArgs.cs
- ControlBuilder.cs
- OrderByBuilder.cs
- NativeMethodsOther.cs
- UrlMapping.cs
- UniqueIdentifierService.cs
- FileRecordSequenceCompletedAsyncResult.cs
- ValueQuery.cs
- SizeConverter.cs
- TextBox.cs
- DataGridSortingEventArgs.cs
- SingleAnimation.cs
- OptionUsage.cs
- jithelpers.cs
- DotExpr.cs
- OleCmdHelper.cs
- EndpointDesigner.cs
- MessageLogger.cs
- SchemaCollectionCompiler.cs
- RoutedEventConverter.cs
- SafeRightsManagementSessionHandle.cs
- DataGridViewImageCell.cs