BitmapDataExtensionsDitherAsync Method

Quantizes an IReadWriteBitmapData with dithering asynchronously (reduces the number of colors while trying to preserve details) using the specified quantizer and ditherer.


Namespace: KGySoft.Drawing.Imaging
Assembly: KGySoft.Drawing.Core (in KGySoft.Drawing.Core.dll) Version: 7.0.0
public static Task DitherAsync(
	this IReadWriteBitmapData bitmapData,
	IQuantizer quantizer,
	IDitherer ditherer,
	TaskConfig? asyncConfig = null


bitmapData  IReadWriteBitmapData
An IReadWriteBitmapData instance to be quantized.
quantizer  IQuantizer
An IQuantizer implementation to be used for quantizing the specified bitmapData.
ditherer  IDitherer
An IDitherer implementation to be used for dithering during the quantization of the specified bitmapData.
asyncConfig  TaskConfig  (Optional)
The configuration of the asynchronous operation such as parallelization, cancellation, reporting progress, etc. When Progress is set in this parameter, then this library always passes a DrawingOperation instance to the generic methods of the IAsyncProgress interface. This parameter is optional.
Default value: .

Return Value

A Task that represents the asynchronous operation, which could still be pending.

Usage Note

In Visual Basic and C#, you can call this method as an instance method on any object of type IReadWriteBitmapData. When you use instance method syntax to call this method, omit the first parameter. For more information, see Extension Methods (Visual Basic) or Extension Methods (C# Programming Guide).


This method is not a blocking call even if the MaxDegreeOfParallelism property of the asyncConfig parameter is 1.


See the Remarks section of the Dither method for more details.


ArgumentNullExceptionbitmapData, quantizer or ditherer is .
InvalidOperationExceptionThe IQuantizer.Initialize method or the IDitherer.Initialize method returned .

See Also