Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Core / CSharp / System / Windows / Media / RenderCapability.cs / 1 / RenderCapability.cs
//------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // The RenderCapability class allows clients to query for the current // render tier associated with their Dispatcher and to register for // notification on change. // //----------------------------------------------------------------------------- using System; using System.Diagnostics; namespace System.Windows.Media { ////// RenderCapability - /// The RenderCapability class allows clients to query for the current /// render tier associated with their Dispatcher and to register for /// notification on change. /// public static class RenderCapability { ////// Tier Property - returns the current render tier for the Dispatcher associated /// with the current thread. /// public static int Tier { get { MediaContext mediaContext = MediaContext.CurrentMediaContext; // The Dispatcher auto-creates if there is no Dispatcher associated with this // thread, and the MediaContext does the same. Thus, mediaContext should never // be null. Debug.Assert(mediaContext != null); return mediaContext.Tier; } } ////// Returns whether the specified PixelShader major/minor version is /// supported by this version of WPF, and whether Effects using the /// specified major/minor version can run on the GPU. /// public static bool IsPixelShaderVersionSupported(short majorVersionRequested, short minorVersionRequested) { bool isSupported = false; // For now, we only support PS 2.0. Can only return true if this is // the version asked for. const short majorVersionRequired = 2; const short minorVersionRequired = 0; if (majorVersionRequested == majorVersionRequired && minorVersionRequested == minorVersionRequired) { // Now actually check. MediaContext mediaContext = MediaContext.CurrentMediaContext; byte majorVersion = (byte)((mediaContext.PixelShaderVersion >> 8) & 0xFF); byte minorVersion = (byte)((mediaContext.PixelShaderVersion >> 0) & 0xFF); // We assume here that a higher version does in fact support the // version we're requiring. if (majorVersion >= majorVersionRequired) { isSupported = true; } else if (majorVersion == majorVersionRequired && minorVersion >= minorVersionRequired) { isSupported = true; } } return isSupported; } ////// Returns whether Effects can be rendered in software on this machine. /// public static bool IsShaderEffectSoftwareRenderingSupported { get { MediaContext mediaContext = MediaContext.CurrentMediaContext; return mediaContext.HasSSE2Support; } } ////// TierChanged event - /// This event is raised when the Tier for a given Dispatcher changes. /// public static event EventHandler TierChanged { add { MediaContext mediaContext = MediaContext.CurrentMediaContext; // The Dispatcher auto-creates if there is no Dispatcher associated with this // thread, and the MediaContext does the same. Thus, mediaContext should never // be null. Debug.Assert(mediaContext != null); mediaContext.TierChanged += value; } remove { MediaContext mediaContext = MediaContext.CurrentMediaContext; // The Dispatcher auto-creates if there is no Dispatcher associated with this // thread, and the MediaContext does the same. Thus, mediaContext should never // be null. Debug.Assert(mediaContext != null); mediaContext.TierChanged -= value; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // The RenderCapability class allows clients to query for the current // render tier associated with their Dispatcher and to register for // notification on change. // //----------------------------------------------------------------------------- using System; using System.Diagnostics; namespace System.Windows.Media { ////// RenderCapability - /// The RenderCapability class allows clients to query for the current /// render tier associated with their Dispatcher and to register for /// notification on change. /// public static class RenderCapability { ////// Tier Property - returns the current render tier for the Dispatcher associated /// with the current thread. /// public static int Tier { get { MediaContext mediaContext = MediaContext.CurrentMediaContext; // The Dispatcher auto-creates if there is no Dispatcher associated with this // thread, and the MediaContext does the same. Thus, mediaContext should never // be null. Debug.Assert(mediaContext != null); return mediaContext.Tier; } } ////// Returns whether the specified PixelShader major/minor version is /// supported by this version of WPF, and whether Effects using the /// specified major/minor version can run on the GPU. /// public static bool IsPixelShaderVersionSupported(short majorVersionRequested, short minorVersionRequested) { bool isSupported = false; // For now, we only support PS 2.0. Can only return true if this is // the version asked for. const short majorVersionRequired = 2; const short minorVersionRequired = 0; if (majorVersionRequested == majorVersionRequired && minorVersionRequested == minorVersionRequired) { // Now actually check. MediaContext mediaContext = MediaContext.CurrentMediaContext; byte majorVersion = (byte)((mediaContext.PixelShaderVersion >> 8) & 0xFF); byte minorVersion = (byte)((mediaContext.PixelShaderVersion >> 0) & 0xFF); // We assume here that a higher version does in fact support the // version we're requiring. if (majorVersion >= majorVersionRequired) { isSupported = true; } else if (majorVersion == majorVersionRequired && minorVersion >= minorVersionRequired) { isSupported = true; } } return isSupported; } ////// Returns whether Effects can be rendered in software on this machine. /// public static bool IsShaderEffectSoftwareRenderingSupported { get { MediaContext mediaContext = MediaContext.CurrentMediaContext; return mediaContext.HasSSE2Support; } } ////// TierChanged event - /// This event is raised when the Tier for a given Dispatcher changes. /// public static event EventHandler TierChanged { add { MediaContext mediaContext = MediaContext.CurrentMediaContext; // The Dispatcher auto-creates if there is no Dispatcher associated with this // thread, and the MediaContext does the same. Thus, mediaContext should never // be null. Debug.Assert(mediaContext != null); mediaContext.TierChanged += value; } remove { MediaContext mediaContext = MediaContext.CurrentMediaContext; // The Dispatcher auto-creates if there is no Dispatcher associated with this // thread, and the MediaContext does the same. Thus, mediaContext should never // be null. Debug.Assert(mediaContext != null); mediaContext.TierChanged -= value; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DbConnectionFactory.cs
- CriticalFileToken.cs
- SoundPlayerAction.cs
- ReliabilityContractAttribute.cs
- PointCollection.cs
- TableLayoutRowStyleCollection.cs
- DataSourceListEditor.cs
- DefaultTextStore.cs
- HyperLinkColumn.cs
- PtsPage.cs
- ReadOnlyCollection.cs
- SqlCacheDependencyDatabaseCollection.cs
- xmlsaver.cs
- ConfigurationStrings.cs
- CommentEmitter.cs
- LayoutEvent.cs
- XmlChildNodes.cs
- ImageIndexConverter.cs
- CapabilitiesAssignment.cs
- QueryStringParameter.cs
- UIElement3D.cs
- CodeTypeReferenceExpression.cs
- MatrixKeyFrameCollection.cs
- Section.cs
- ListBindingHelper.cs
- ActiveXHelper.cs
- XmlTextEncoder.cs
- InvokeWebServiceDesigner.cs
- Root.cs
- ServiceHttpModule.cs
- Query.cs
- ProjectionCamera.cs
- DatagridviewDisplayedBandsData.cs
- StringOutput.cs
- EnvelopedSignatureTransform.cs
- AsnEncodedData.cs
- DesignerSerializationOptionsAttribute.cs
- TextBox.cs
- ManagementObjectCollection.cs
- XmlSchemaExternal.cs
- PolyBezierSegmentFigureLogic.cs
- translator.cs
- BitmapCodecInfoInternal.cs
- NotSupportedException.cs
- MissingMethodException.cs
- SoapWriter.cs
- LineSegment.cs
- SvcMapFile.cs
- Span.cs
- InputReferenceExpression.cs
- WeakEventTable.cs
- securitycriticaldata.cs
- ManipulationStartingEventArgs.cs
- ImageButton.cs
- Descriptor.cs
- WindowsAltTab.cs
- TransactionCache.cs
- CatalogZone.cs
- UnsafeNativeMethods.cs
- DiscoveryReference.cs
- ExpressionsCollectionEditor.cs
- ArraySegment.cs
- AnnouncementEndpoint.cs
- XsltSettings.cs
- JsonEncodingStreamWrapper.cs
- ObjectDisposedException.cs
- SystemColorTracker.cs
- SqlUtils.cs
- DialogResultConverter.cs
- Image.cs
- GeneralTransform3D.cs
- XmlSecureResolver.cs
- StringUtil.cs
- ClrPerspective.cs
- LocalizationComments.cs
- HMACSHA384.cs
- StickyNoteContentControl.cs
- mediaeventshelper.cs
- SqlWebEventProvider.cs
- ProfilePropertyNameValidator.cs
- AppliesToBehaviorDecisionTable.cs
- linebase.cs
- ObjectItemCollectionAssemblyCacheEntry.cs
- TextPattern.cs
- BindingExpressionUncommonField.cs
- NativeCppClassAttribute.cs
- NavigationEventArgs.cs
- IteratorFilter.cs
- CompilationUnit.cs
- Int64Animation.cs
- BinaryWriter.cs
- ExtendedPropertyCollection.cs
- Transform.cs
- SqlWebEventProvider.cs
- MemberInfoSerializationHolder.cs
- ISFTagAndGuidCache.cs
- TypeDependencyAttribute.cs
- SiteIdentityPermission.cs
- AttachedPropertyMethodSelector.cs
- CatalogPartCollection.cs