Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / CommonUI / System / Drawing / Advanced / EncoderParameters.cs / 1 / EncoderParameters.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Drawing.Imaging { using System.Text; using System.Runtime.InteropServices; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System; using System.Drawing.Internal; using Marshal = System.Runtime.InteropServices.Marshal; using System.Drawing; //[StructLayout(LayoutKind.Sequential)] ////// /// public sealed class EncoderParameters : IDisposable { EncoderParameter[] param; ///[To be supplied.] ////// /// public EncoderParameters(int count) { param = new EncoderParameter[count]; } ///[To be supplied.] ////// /// public EncoderParameters() { param = new EncoderParameter[1]; } ///[To be supplied.] ////// /// public EncoderParameter[] Param { // get { return param; } set { param = value; } } ///[To be supplied.] ////// Copy the EncoderParameters data into a chunk of memory to be consumed by native GDI+ code. /// /// We need to marshal the EncoderParameters info from/to native GDI+ ourselve since the definition of the managed/unmanaged classes /// are different and the native class is a bit weird. The native EncoderParameters class is defined in GDI+ as follows: /// /// class EncoderParameters { /// UINT Count; // Number of parameters in this structure /// EncoderParameter Parameter[1]; // Parameter values /// }; /// /// We don't have the 'Count' field since the managed array contains it. In order for this structure to work with more than one /// EncoderParameter we need to preallocate memory for the extra n-1 elements, something like this: /// /// EncoderParameters* pEncoderParameters = (EncoderParameters*) malloc(sizeof(EncoderParameters) + (n-1) * sizeof(EncoderParameter)); /// /// Also, in 64-bit platforms, 'Count' is aligned in 8 bytes (4 extra padding bytes) so we use IntPtr instead of Int32 to account for /// that (See VSW#451333). /// internal IntPtr ConvertToMemory() { int size = Marshal.SizeOf(typeof(EncoderParameter)); IntPtr memory = Marshal.AllocHGlobal(param.Length * size + Marshal.SizeOf(typeof(IntPtr))); if (memory == IntPtr.Zero){ throw SafeNativeMethods.Gdip.StatusException(SafeNativeMethods.Gdip.OutOfMemory); } Marshal.WriteIntPtr(memory, (IntPtr) param.Length); long arrayOffset = (long) memory + Marshal.SizeOf(typeof(IntPtr)); for (int i=0; i/// Copy the native GDI+ EncoderParameters data from a chunk of memory into a managed EncoderParameters object. /// See ConvertToMemory for more info. /// [SuppressMessage("Microsoft.Performance", "CA1808:AvoidCallsThatBoxValueTypes")] internal static EncoderParameters ConvertFromMemory(IntPtr memory) { if (memory == IntPtr.Zero) { throw SafeNativeMethods.Gdip.StatusException(SafeNativeMethods.Gdip.InvalidParameter); } int count = Marshal.ReadIntPtr(memory).ToInt32(); EncoderParameters p = new EncoderParameters(count); int size = Marshal.SizeOf(typeof(EncoderParameter)); long arrayOffset = (long)memory + Marshal.SizeOf(typeof(IntPtr)); for (int i=0; i public void Dispose() { foreach (EncoderParameter p in param) { if( p != null ){ p.Dispose(); } } param = null; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Drawing.Imaging { using System.Text; using System.Runtime.InteropServices; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System; using System.Drawing.Internal; using Marshal = System.Runtime.InteropServices.Marshal; using System.Drawing; //[StructLayout(LayoutKind.Sequential)] ////// /// public sealed class EncoderParameters : IDisposable { EncoderParameter[] param; ///[To be supplied.] ////// /// public EncoderParameters(int count) { param = new EncoderParameter[count]; } ///[To be supplied.] ////// /// public EncoderParameters() { param = new EncoderParameter[1]; } ///[To be supplied.] ////// /// public EncoderParameter[] Param { // get { return param; } set { param = value; } } ///[To be supplied.] ////// Copy the EncoderParameters data into a chunk of memory to be consumed by native GDI+ code. /// /// We need to marshal the EncoderParameters info from/to native GDI+ ourselve since the definition of the managed/unmanaged classes /// are different and the native class is a bit weird. The native EncoderParameters class is defined in GDI+ as follows: /// /// class EncoderParameters { /// UINT Count; // Number of parameters in this structure /// EncoderParameter Parameter[1]; // Parameter values /// }; /// /// We don't have the 'Count' field since the managed array contains it. In order for this structure to work with more than one /// EncoderParameter we need to preallocate memory for the extra n-1 elements, something like this: /// /// EncoderParameters* pEncoderParameters = (EncoderParameters*) malloc(sizeof(EncoderParameters) + (n-1) * sizeof(EncoderParameter)); /// /// Also, in 64-bit platforms, 'Count' is aligned in 8 bytes (4 extra padding bytes) so we use IntPtr instead of Int32 to account for /// that (See VSW#451333). /// internal IntPtr ConvertToMemory() { int size = Marshal.SizeOf(typeof(EncoderParameter)); IntPtr memory = Marshal.AllocHGlobal(param.Length * size + Marshal.SizeOf(typeof(IntPtr))); if (memory == IntPtr.Zero){ throw SafeNativeMethods.Gdip.StatusException(SafeNativeMethods.Gdip.OutOfMemory); } Marshal.WriteIntPtr(memory, (IntPtr) param.Length); long arrayOffset = (long) memory + Marshal.SizeOf(typeof(IntPtr)); for (int i=0; i/// Copy the native GDI+ EncoderParameters data from a chunk of memory into a managed EncoderParameters object. /// See ConvertToMemory for more info. /// [SuppressMessage("Microsoft.Performance", "CA1808:AvoidCallsThatBoxValueTypes")] internal static EncoderParameters ConvertFromMemory(IntPtr memory) { if (memory == IntPtr.Zero) { throw SafeNativeMethods.Gdip.StatusException(SafeNativeMethods.Gdip.InvalidParameter); } int count = Marshal.ReadIntPtr(memory).ToInt32(); EncoderParameters p = new EncoderParameters(count); int size = Marshal.SizeOf(typeof(EncoderParameter)); long arrayOffset = (long)memory + Marshal.SizeOf(typeof(IntPtr)); for (int i=0; i public void Dispose() { foreach (EncoderParameter p in param) { if( p != null ){ p.Dispose(); } } param = 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
- StylusPointPropertyUnit.cs
- ConstNode.cs
- Parser.cs
- DockPattern.cs
- TemplateField.cs
- MenuItem.cs
- EntityReference.cs
- ProxyElement.cs
- ClickablePoint.cs
- WebPartAuthorizationEventArgs.cs
- NonPrimarySelectionGlyph.cs
- VBIdentifierDesigner.xaml.cs
- CallbackValidatorAttribute.cs
- MergePropertyDescriptor.cs
- SchemaDeclBase.cs
- Pool.cs
- NodeInfo.cs
- DataGridViewCellStateChangedEventArgs.cs
- FileUpload.cs
- DateTimeOffset.cs
- ModifierKeysValueSerializer.cs
- DataGridViewRowDividerDoubleClickEventArgs.cs
- StreamGeometry.cs
- WmfPlaceableFileHeader.cs
- ChtmlPhoneCallAdapter.cs
- MachineKeySection.cs
- VirtualizingPanel.cs
- ProtocolException.cs
- MenuStrip.cs
- SafeRightsManagementPubHandle.cs
- AggregateNode.cs
- SynchronizedDispatch.cs
- webproxy.cs
- InternalDispatchObject.cs
- StringComparer.cs
- TaiwanCalendar.cs
- GACIdentityPermission.cs
- StartUpEventArgs.cs
- UserPreferenceChangingEventArgs.cs
- AvTraceDetails.cs
- UnhandledExceptionEventArgs.cs
- StubHelpers.cs
- DesigntimeLicenseContextSerializer.cs
- ConfigsHelper.cs
- DataTableClearEvent.cs
- ValidatorCompatibilityHelper.cs
- XmlCharacterData.cs
- FusionWrap.cs
- DnsPermission.cs
- ActiveXSite.cs
- OperatingSystemVersionCheck.cs
- CurrencyWrapper.cs
- WindowsListViewSubItem.cs
- SRef.cs
- EmptyStringExpandableObjectConverter.cs
- WindowInteropHelper.cs
- ReachDocumentSequenceSerializerAsync.cs
- BulletDecorator.cs
- SchemaMerger.cs
- TextCompositionEventArgs.cs
- DesignerActionPropertyItem.cs
- BamlTreeMap.cs
- PipelineModuleStepContainer.cs
- WindowsGraphicsCacheManager.cs
- WebPartMenu.cs
- DesignerTextWriter.cs
- DesignerVerbCollection.cs
- RegionIterator.cs
- UiaCoreProviderApi.cs
- Stroke.cs
- COAUTHIDENTITY.cs
- FieldNameLookup.cs
- Win32SafeHandles.cs
- ValidationEventArgs.cs
- MachineKeyValidationConverter.cs
- TypeToArgumentTypeConverter.cs
- EncoderExceptionFallback.cs
- Validator.cs
- FontCacheUtil.cs
- StateRuntime.cs
- XmlSchemaChoice.cs
- UpWmlMobileTextWriter.cs
- XamlClipboardData.cs
- DrawListViewItemEventArgs.cs
- HtmlControl.cs
- FederatedMessageSecurityOverHttpElement.cs
- NavigatingCancelEventArgs.cs
- SchemaTypeEmitter.cs
- SimpleWebHandlerParser.cs
- BaseAddressPrefixFilterElement.cs
- Encoding.cs
- Math.cs
- EntityDataSourceColumn.cs
- DurationConverter.cs
- HtmlInputText.cs
- IteratorAsyncResult.cs
- MethodExpr.cs
- HttpModuleCollection.cs
- RemoteWebConfigurationHost.cs
- PatternMatcher.cs