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
- XmlAttributeCollection.cs
- SerializationSectionGroup.cs
- Lookup.cs
- SafeNativeMethods.cs
- SpinWait.cs
- InputLangChangeEvent.cs
- PackageProperties.cs
- ColorConvertedBitmap.cs
- ClaimComparer.cs
- MexHttpBindingElement.cs
- Serializer.cs
- EventLevel.cs
- SchemaAttDef.cs
- ImageCodecInfo.cs
- QueryStringHandler.cs
- DelegateSerializationHolder.cs
- DiagnosticTrace.cs
- BitmapMetadataEnumerator.cs
- AutomationPattern.cs
- SignatureGenerator.cs
- ParameterCollection.cs
- EntityDataSourceColumn.cs
- _Win32.cs
- XamlStackWriter.cs
- CultureTableRecord.cs
- WindowsFont.cs
- HttpEncoder.cs
- FrugalMap.cs
- TypeLibConverter.cs
- HitTestParameters.cs
- BooleanKeyFrameCollection.cs
- Win32KeyboardDevice.cs
- Timer.cs
- IgnoreFileBuildProvider.cs
- DataSourceControl.cs
- DocumentGrid.cs
- StringAttributeCollection.cs
- _Semaphore.cs
- RegexTypeEditor.cs
- InlineUIContainer.cs
- ConstantProjectedSlot.cs
- ExpressionTable.cs
- DoubleLinkListEnumerator.cs
- NamedPipeConnectionPoolSettings.cs
- SequenceQuery.cs
- DataGridViewColumnEventArgs.cs
- QilPatternVisitor.cs
- DisplayMemberTemplateSelector.cs
- RadioButtonRenderer.cs
- ComboBoxAutomationPeer.cs
- ObjectStorage.cs
- EventMap.cs
- safelink.cs
- TabPage.cs
- TextRangeBase.cs
- PropertyChangedEventManager.cs
- PersonalizationAdministration.cs
- XmlNodeWriter.cs
- CustomPopupPlacement.cs
- WebPartDescription.cs
- ResourceManager.cs
- GeneralTransformGroup.cs
- NullReferenceException.cs
- XmlChildEnumerator.cs
- CustomPopupPlacement.cs
- SqlTriggerAttribute.cs
- httpstaticobjectscollection.cs
- NavigationProperty.cs
- MemberInfoSerializationHolder.cs
- CallTemplateAction.cs
- PropertyEmitter.cs
- XmlSchemaObjectTable.cs
- TCEAdapterGenerator.cs
- DBConcurrencyException.cs
- SchemaInfo.cs
- Baml2006KeyRecord.cs
- Random.cs
- UnsafeNativeMethods.cs
- Int16Storage.cs
- TcpAppDomainProtocolHandler.cs
- EmptyEnumerable.cs
- EventSetter.cs
- BindingMAnagerBase.cs
- CodePageUtils.cs
- MultiTargetingUtil.cs
- BackgroundFormatInfo.cs
- TextTreeTextBlock.cs
- BindingNavigator.cs
- ReverseInheritProperty.cs
- ObjectDataSourceFilteringEventArgs.cs
- EventArgs.cs
- PolyLineSegment.cs
- MostlySingletonList.cs
- OraclePermission.cs
- LogicalExpr.cs
- GroupBoxAutomationPeer.cs
- DaylightTime.cs
- IgnoreFileBuildProvider.cs
- PartialArray.cs
- DependencyPropertyConverter.cs