Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Core / CSharp / System / Windows / Media / Imaging / BitmapSourceSafeMILHandle.cs / 1 / BitmapSourceSafeMILHandle.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // // Description: // A sub-class of SafeMILHandle that can estimate size for bitmap // source objects. //--------------------------------------------------------------------------- using System; using System.Diagnostics; using System.Security; using MS.Internal; using MS.Win32; using UnsafeNativeMethods=MS.Win32.PresentationCore.UnsafeNativeMethods; namespace System.Windows.Media.Imaging { ////// Constructor which computes size of the handle and delegates /// to baseclass safe handle. /// internal class BitmapSourceSafeMILHandle : SafeMILHandle { ////// Critical - initializes critical static field (autogenerated ctor) /// TreatAsSafe - sets them to the correct values, it's ok /// [SecurityCritical, SecurityTreatAsSafe] static BitmapSourceSafeMILHandle() { } ////// Use this constructor if the handle isn't ready yet and later /// set the handle with SetHandle. /// ////// Critical: This derives from a class that has a link demand and inheritance demand /// TreatAsSafe: Ok to call constructor /// [SecurityCritical,SecurityTreatAsSafe] internal BitmapSourceSafeMILHandle() : base() { } ////// Use this constructor if the handle exists at construction time. /// SafeMILHandle owns the release of the parameter. /// ////// Critical: It is used to keep memory around /// [SecurityCritical] internal BitmapSourceSafeMILHandle(IntPtr handle) : base() { SetHandle(handle); } ////// Calculate the rough size for this handle /// ////// Critical - access unmanaged code /// TreatAsSafe - queries size of the bitmap, safe operation /// /// Attributes are required for UnsafeNativeMethods.* calls /// [SecurityCritical,SecurityTreatAsSafe] internal void CalculateSize() { UpdateEstimatedSize(ComputeEstimatedSize(handle)); } ////// Compute a rough estimate of the size in bytes for the image /// ////// Critical - access unmanaged code and takes an IntPtr /// [SecurityCritical] private static long ComputeEstimatedSize(IntPtr bitmapObject) { long estimatedSize = 0; if (bitmapObject != null && bitmapObject != IntPtr.Zero) { IntPtr wicBitmap; // // QueryInterface for the bitmap source to ensure we are // calling through the right vtable on the pinvoke. // int hr = UnsafeNativeMethods.MILUnknown.QueryInterface( bitmapObject, ref _uuidBitmap, out wicBitmap ); if (hr == HRESULT.S_OK) { Debug.Assert(wicBitmap != IntPtr.Zero); // The safe handle will release the ref added by the above QI SafeMILHandle bitmapSourceSafeHandle = new SafeMILHandle(wicBitmap, 0); uint pixelWidth = 0; uint pixelHeight = 0; hr = UnsafeNativeMethods.WICBitmapSource.GetSize( bitmapSourceSafeHandle, out pixelWidth, out pixelHeight); if (hr == HRESULT.S_OK) { Guid guidFormat; hr = UnsafeNativeMethods.WICBitmapSource.GetPixelFormat(bitmapSourceSafeHandle, out guidFormat); if (hr == HRESULT.S_OK) { // // Go to long space to avoid overflow and check for overlfow // PixelFormat pixelFormat = new PixelFormat(guidFormat); long scanlineSize = (long)pixelWidth * pixelFormat.InternalBitsPerPixel / 8; // // Check that scanlineSize is small enough that we can multiply by 2*pixelWidth // without an overflow. Since pixelHeight is a 32-bit value and we multiply by 2*pixelHeight, // then we can only have a 31-bit scanlineSize. Since we need a sign bit as well, // we need to check that scanlineSize can fit in 30 bits. // if (scanlineSize < 0x40000000) { // We often duplicate the image bits in a managed texture or elsewhere, so // estimate twice the natural size of the image. estimatedSize = 2*pixelHeight*scanlineSize; } } } } } return estimatedSize; } ////// Guid for IIDM_IMILBitmapSource /// ////// Critical - guid used for COM interop, need to be careful not to overwrite /// [SecurityCritical] private static Guid _uuidBitmap = MILGuidData.IID_IWICBitmap; } } // 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: // A sub-class of SafeMILHandle that can estimate size for bitmap // source objects. //--------------------------------------------------------------------------- using System; using System.Diagnostics; using System.Security; using MS.Internal; using MS.Win32; using UnsafeNativeMethods=MS.Win32.PresentationCore.UnsafeNativeMethods; namespace System.Windows.Media.Imaging { ////// Constructor which computes size of the handle and delegates /// to baseclass safe handle. /// internal class BitmapSourceSafeMILHandle : SafeMILHandle { ////// Critical - initializes critical static field (autogenerated ctor) /// TreatAsSafe - sets them to the correct values, it's ok /// [SecurityCritical, SecurityTreatAsSafe] static BitmapSourceSafeMILHandle() { } ////// Use this constructor if the handle isn't ready yet and later /// set the handle with SetHandle. /// ////// Critical: This derives from a class that has a link demand and inheritance demand /// TreatAsSafe: Ok to call constructor /// [SecurityCritical,SecurityTreatAsSafe] internal BitmapSourceSafeMILHandle() : base() { } ////// Use this constructor if the handle exists at construction time. /// SafeMILHandle owns the release of the parameter. /// ////// Critical: It is used to keep memory around /// [SecurityCritical] internal BitmapSourceSafeMILHandle(IntPtr handle) : base() { SetHandle(handle); } ////// Calculate the rough size for this handle /// ////// Critical - access unmanaged code /// TreatAsSafe - queries size of the bitmap, safe operation /// /// Attributes are required for UnsafeNativeMethods.* calls /// [SecurityCritical,SecurityTreatAsSafe] internal void CalculateSize() { UpdateEstimatedSize(ComputeEstimatedSize(handle)); } ////// Compute a rough estimate of the size in bytes for the image /// ////// Critical - access unmanaged code and takes an IntPtr /// [SecurityCritical] private static long ComputeEstimatedSize(IntPtr bitmapObject) { long estimatedSize = 0; if (bitmapObject != null && bitmapObject != IntPtr.Zero) { IntPtr wicBitmap; // // QueryInterface for the bitmap source to ensure we are // calling through the right vtable on the pinvoke. // int hr = UnsafeNativeMethods.MILUnknown.QueryInterface( bitmapObject, ref _uuidBitmap, out wicBitmap ); if (hr == HRESULT.S_OK) { Debug.Assert(wicBitmap != IntPtr.Zero); // The safe handle will release the ref added by the above QI SafeMILHandle bitmapSourceSafeHandle = new SafeMILHandle(wicBitmap, 0); uint pixelWidth = 0; uint pixelHeight = 0; hr = UnsafeNativeMethods.WICBitmapSource.GetSize( bitmapSourceSafeHandle, out pixelWidth, out pixelHeight); if (hr == HRESULT.S_OK) { Guid guidFormat; hr = UnsafeNativeMethods.WICBitmapSource.GetPixelFormat(bitmapSourceSafeHandle, out guidFormat); if (hr == HRESULT.S_OK) { // // Go to long space to avoid overflow and check for overlfow // PixelFormat pixelFormat = new PixelFormat(guidFormat); long scanlineSize = (long)pixelWidth * pixelFormat.InternalBitsPerPixel / 8; // // Check that scanlineSize is small enough that we can multiply by 2*pixelWidth // without an overflow. Since pixelHeight is a 32-bit value and we multiply by 2*pixelHeight, // then we can only have a 31-bit scanlineSize. Since we need a sign bit as well, // we need to check that scanlineSize can fit in 30 bits. // if (scanlineSize < 0x40000000) { // We often duplicate the image bits in a managed texture or elsewhere, so // estimate twice the natural size of the image. estimatedSize = 2*pixelHeight*scanlineSize; } } } } } return estimatedSize; } ////// Guid for IIDM_IMILBitmapSource /// ////// Critical - guid used for COM interop, need to be careful not to overwrite /// [SecurityCritical] private static Guid _uuidBitmap = MILGuidData.IID_IWICBitmap; } } // 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
- LicenseProviderAttribute.cs
- SecurityTokenParametersEnumerable.cs
- TableCell.cs
- SettingsPropertyValueCollection.cs
- BuildResultCache.cs
- HasCopySemanticsAttribute.cs
- UserPersonalizationStateInfo.cs
- GridViewUpdatedEventArgs.cs
- SHA512Cng.cs
- PopupEventArgs.cs
- HeaderCollection.cs
- OciEnlistContext.cs
- SiteMap.cs
- Int32.cs
- PenThreadPool.cs
- XmlCDATASection.cs
- XmlConvert.cs
- TextRunProperties.cs
- StylusSystemGestureEventArgs.cs
- ColorContext.cs
- TouchesOverProperty.cs
- ComEventsHelper.cs
- ProcessStartInfo.cs
- SoapRpcServiceAttribute.cs
- DataControlFieldsEditor.cs
- FixUpCollection.cs
- AlternateView.cs
- AssemblyCache.cs
- SelectionProviderWrapper.cs
- OleDbPropertySetGuid.cs
- TimelineClockCollection.cs
- HostedTransportConfigurationBase.cs
- UnSafeCharBuffer.cs
- OutputCacheModule.cs
- SqlDataSourceCache.cs
- XmlExtensionFunction.cs
- UnSafeCharBuffer.cs
- AnchoredBlock.cs
- XhtmlBasicListAdapter.cs
- WebPartDisplayModeCancelEventArgs.cs
- WebPartHeaderCloseVerb.cs
- CompilerTypeWithParams.cs
- ManifestResourceInfo.cs
- UserNamePasswordServiceCredential.cs
- InputProcessorProfiles.cs
- WasEndpointConfigContainer.cs
- BitmapSourceSafeMILHandle.cs
- HostProtectionException.cs
- TypeNameParser.cs
- DragSelectionMessageFilter.cs
- SqlCacheDependencyDatabase.cs
- XmlNodeWriter.cs
- EmptyCollection.cs
- SiteIdentityPermission.cs
- HMACSHA1.cs
- User.cs
- QueryContinueDragEvent.cs
- DetailsViewPagerRow.cs
- PerfService.cs
- Int32AnimationUsingKeyFrames.cs
- ObjectStateManager.cs
- DataGridView.cs
- WmlTextBoxAdapter.cs
- PackagingUtilities.cs
- X509AsymmetricSecurityKey.cs
- SequentialOutput.cs
- DataSvcMapFileSerializer.cs
- WebMessageEncodingElement.cs
- RoleService.cs
- Page.cs
- TreeViewBindingsEditorForm.cs
- MaskDescriptor.cs
- SortedSetDebugView.cs
- EnumBuilder.cs
- WeakReferenceList.cs
- RootBrowserWindowProxy.cs
- TableCell.cs
- SatelliteContractVersionAttribute.cs
- DesignerLoader.cs
- Image.cs
- GridViewCommandEventArgs.cs
- GuidelineSet.cs
- PersistenceContext.cs
- X509ChainPolicy.cs
- EventsTab.cs
- XamlPathDataSerializer.cs
- FamilyTypefaceCollection.cs
- Gdiplus.cs
- ResourceDescriptionAttribute.cs
- ConsoleTraceListener.cs
- ToolTipService.cs
- QilPatternVisitor.cs
- ClientBuildManagerCallback.cs
- GroupByExpressionRewriter.cs
- OperationValidationEventArgs.cs
- DynamicILGenerator.cs
- ResourcePermissionBaseEntry.cs
- MultiBinding.cs
- SchemaSetCompiler.cs
- LayoutSettings.cs