.. _doxcsid-class_p1_1_1_image_sdk_1_1_convert_config: ConvertConfig Class ~~~~~~~~~~~~~~~~~~~ Definition ^^^^^^^^^^ *Namespace:* ``P1.ImageSdk`` Defines a set of RAW convertion- and filter-flags, that can be applied to a raw-image :ref:`More...` .. ref-code-block:: csharp :class: doxyrest-overview-code-block public class ConvertConfig .. _csdetails-class_p1_1_1_image_sdk_1_1_convert_config: Remarks ^^^^^^^ Defines a set of RAW convertion- and filter-flags, that can be applied to a raw-image This class let you raw convert an IIQ raw-image. Use it to setup decoding and convertion options, before actual triggering the convertion with :ref:`ApplyTo `. You can also apply different filters to the image, including scaling and cropping. You should note that the order the filters are applied is fixed. You cannot define any ordering on your own. Any applied cropping or resizing dimensions might not be followed 100% by resampling algorithm. The resulting image might differ with a few pixels. Always check the output dimensions, and do not assume your image has the crop you requested. Simple one-liner raw convertion and scaling var bitmap = new :ref:`ConvertConfig() `.SetScale(0.25).AppleTo(new :ref:`RawImage ` ("some-file.iiq")); .. rubric:: See also: :ref:`RawImage.Convert ` Constructors ^^^^^^^^^^^^ .. toctree:: :hidden: ConvertConfig .. list-table:: :widths: 30 70 * - :ref:`ConvertConfig() ` - Creates a new raw convertion config object Members ^^^^^^^ .. toctree:: :hidden: outputImage ExposureRange ContrastRange BrightnessRange SaturationRange ShadowRecoveryRange HighlightRecoveryRange BlackLevelRange WhiteLevelRange MidtoneLevelRange CurveInOutRange ClarityMethodRange ClarityFactorRange SharpeningAmountRange SharpeningRadiusRange SharpeningThresholdRange HaloSuppressionAmountRange LuminanceNoiseReductionAmountRange ColorNoiseReductionAmountRange WhiteBalanceGainRange GeometricCorrectionFocalLengthRange GeometricCorrectionPixelPitchRange GeometricCorrectionShiftRange GeometricCorrectionPolinomRange GeometricCorrectionAffinityRange .. list-table:: :widths: 30 70 * - :ref:`outputImage ` - Trigger processing of the applied options on the raw-buffer and return a new image as an RGB bitmap * - :ref:`ExposureRange ` - The :ref:`value range ` of the Exposure property. * - :ref:`ContrastRange ` - The :ref:`value range ` of the Contrast property. * - :ref:`BrightnessRange ` - The :ref:`value range ` of the Brightness property. * - :ref:`SaturationRange ` - The :ref:`value range ` of the Saturation property. * - :ref:`ShadowRecoveryRange ` - The :ref:`value range ` of the ShadowRecovery property. * - :ref:`HighlightRecoveryRange ` - The :ref:`value range ` of the HighlightRecovery property. * - :ref:`BlackLevelRange ` - The :ref:`value range ` of the BlackLevel property. * - :ref:`WhiteLevelRange ` - The :ref:`value range ` of the WhiteLevel property. * - :ref:`MidtoneLevelRange ` - The :ref:`value range ` of the MidtoneLevel property. * - :ref:`CurveInOutRange ` - The :ref:`value range ` of the X and Y field of each element of the curve type properties. * - :ref:`ClarityMethodRange ` - The :ref:`value range ` of the Method field of the :ref:`Clarity ` property. * - :ref:`ClarityFactorRange ` - The :ref:`value range ` of the Factor field of the :ref:`Clarity ` property. * - :ref:`SharpeningAmountRange ` - The :ref:`value range ` of the amount of sharpening gain. * - :ref:`SharpeningRadiusRange ` - The :ref:`value range ` of radius of sharpening algorithm. * - :ref:`SharpeningThresholdRange ` - The :ref:`value range ` of the threshold for noise reduction. * - :ref:`HaloSuppressionAmountRange ` - The :ref:`value range ` of the amount of halo suppresion in sharpening * - :ref:`LuminanceNoiseReductionAmountRange ` - The :ref:`value range ` of the LuminanceNoiseReductionAmount property. * - :ref:`ColorNoiseReductionAmountRange ` - The :ref:`value range ` of the ColorNoiseReductionAmount property. * - :ref:`WhiteBalanceGainRange ` - The :ref:`value range ` of the RGB channels of the White Balance Gain property. * - :ref:`GeometricCorrectionFocalLengthRange ` - The :ref:`value range ` of the FocalLength field of the :ref:`GeometricCorrection ` property. * - :ref:`GeometricCorrectionPixelPitchRange ` - The :ref:`value range ` of the PixelSize field of the :ref:`GeometricCorrection ` property. * - :ref:`GeometricCorrectionShiftRange ` - The :ref:`value range ` of the xp, yp fields of the :ref:`GeometricCorrection ` property. * - :ref:`GeometricCorrectionPolinomRange ` - The :ref:`value range ` of the k1, k2, k3, p1, p2 fields of the :ref:`GeometricCorrection ` property. * - :ref:`GeometricCorrectionAffinityRange ` - The :ref:`value range ` of the b1, b2 fields of the :ref:`GeometricCorrection ` property. Properties ^^^^^^^^^^ .. toctree:: :hidden: Exposure Contrast Brightness Saturation HighlightRecovery ShadowRecovery BlackLevel BlackLevelTarget MidtoneLevel WhiteLevel WhiteLevelTarget RedCurve GreenCurve Gain BlueCurve LumaCurve RGBCurve WhiteBalanceGain WhiteBalanceMode Clarity LuminanceNoiseReductionAmount NoiseReductionSinglePixel ColorNoiseReductionAmount SharpeningAmount SharpeningRadius SharpeningThreshold HaloSuppressionAmount GeometricCorrectionEnabled GeometricCorrectionCompensationEnabled GeometricCompensationPressure GeometricCorrection LightFalloffCorrectionEnabled DualExposureOutput EnableLinearPath PolynomialTransform PolynomialTransformNormalized Orientation ChromaticAberrationCorrectionEnabled ExposureWarningMaskEnabled ExposureWarningThresholdOver ExposureWarningThresholdUnder ClipWarningMaskEnabled ClipWarningCount CanvasClip Crop OutputScaleFactor OutputWidth OutputHeight .. list-table:: :widths: 30 70 * - :ref:`Exposure ` - Adjust the exposure of the image * - :ref:`Contrast ` - Adjust the contrast of the image. * - :ref:`Brightness ` - Adjust the brightness of the image * - :ref:`Saturation ` - Adjust the saturation of the image * - :ref:`HighlightRecovery ` - Used to extract details only in the highlights of the image by reducing the brightness of highlight pixels. * - :ref:`ShadowRecovery ` - Used to extract details only in the shadows of the image by making them brighter. * - :ref:`BlackLevel ` - Set the level used for black. This is a color that black color is mapped into (as in a level tool) * - :ref:`BlackLevelTarget ` - Set the target level used for black. This is a color that black color is mapped into (as in a level tool) * - :ref:`MidtoneLevel ` - Set the midtone level. This is a color that is used as 50% level of the color values * - :ref:`WhiteLevel ` - Set the level used for white. This is a color that white color is mapped into (as in a level tool) * - :ref:`WhiteLevelTarget ` - Set the level used for white target. This is a color that white color is mapped into (as in a level tool) * - :ref:`RedCurve ` - Set the curve for red values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`GreenCurve ` - Set the curve for green values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`Gain ` - Set image gain. TODO TNT * - :ref:`BlueCurve ` - Set the curve for blue values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`LumaCurve ` - Set the curve for luma values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`RGBCurve ` - Set the curve for rgb values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`WhiteBalanceGain ` - The White Balance as gain for each channels (RGB). The valid range of each individual channel is between 0.0f and 10.0f. * - :ref:`WhiteBalanceMode ` - * - :ref:`Clarity ` - Setup the clarity tool. Its used as a tool to help control the local contrast in the image. * - :ref:`LuminanceNoiseReductionAmount ` - The strength of the luminocity noise reduction. The value is between 0.0 and 1.0. Default is 0.0 * - :ref:`NoiseReductionSinglePixel ` - Remove spike noise which may occure in high ISO captures * - :ref:`ColorNoiseReductionAmount ` - The strength of the color noise reduction. The value is between 0.0 and 1.0. Default is 0.0 * - :ref:`SharpeningAmount ` - Adjust the amount of sharpening of the image. SharpeningAmount is a value between 0.0 and 10.0. Default is 0.0 * - :ref:`SharpeningRadius ` - Patch size for detecting detail, value between 0 and 3. Default is 1.0 * - :ref:`SharpeningThreshold ` - Defines noise level or weak detail, which will be ignored. Value between 0 and 10. Default is 1.0. * - :ref:`HaloSuppressionAmount ` - Amount of halo suppression, value between 0 and 1. Default is 0.0 * - :ref:`GeometricCorrectionEnabled ` - A Boolean value indicating if the conversion will include Geometric Aberration correction * - :ref:`GeometricCorrectionCompensationEnabled ` - A Boolean value indicating if the conversion will include Compensation of Geometric Aberration correction * - :ref:`GeometricCompensationPressure ` - User can inject pressure value to be used for environmental compensetation * - :ref:`GeometricCorrection ` - Custom Geometric Aberration correction parameter set. If geometricCorrection is set to an invalid value, the the conversion will try to load the geometric correction data embedded in the source IIQ file * - :ref:`LightFalloffCorrectionEnabled ` - A Boolean value indicating if the conversion will include Lens Light falloff correction for recognized lenses * - :ref:`DualExposureOutput ` - Setting that defines how to handle dual exposure * - :ref:`EnableLinearPath ` - Set EnableLinearPath setting. This setting is used to disable most of the processing steps to make sure that the debayering of the image into rgb domain is done only using a simple linear mapping enabling only the minimum needed processing. * - :ref:`PolynomialTransform ` - Set Polynomial transformation on bayer data. Six parametters are: ax, bx, cx, ay, by, cy. Range of x and y is [0, Width] and [0, height] * - :ref:`PolynomialTransformNormalized ` - Set Polynomial transformation on bayer data. Six parametters are: ax, bx, cx, ay, by, cy. Range of x and y is [0, 1] * - :ref:`Orientation ` - * - :ref:`ChromaticAberrationCorrectionEnabled ` - A Boolean value indicating if the conversion will include Chromatic Aberration (CA) correction * - :ref:`ExposureWarningMaskEnabled ` - Control generation of exposure mask in the mask image. True means enable. Default is disabled. When doing the actual convertion of an image - a mask buffer must be provided. If enabled the ExposureWarningThresholdOver and ExposureWarningThresholdUnder must be set in advance * - :ref:`ExposureWarningThresholdOver ` - Set the value of the overexposed warning settings used when exposure mask generation is enabled. ExposeWarningThresholdOver is a value between 0.0 and 1.0 so it is independend oof the bitdepth of the image * - :ref:`ExposureWarningThresholdUnder ` - Set the value of the underexposed warning settings used when exposure mask generation is enabled. ExposeWarningThresholdUnder is a value between 0.0 and 1.0 so it is independend oof the bitdepth of the image * - :ref:`ClipWarningMaskEnabled ` - enable the clip warning mask. For this setting to be used the mask image must be enabled and provided when processing the image * - :ref:`ClipWarningCount ` - Set the minimum required count of neighbour pixels that must be outside the threshold limits to be set in the clip warning mask. For this to take effect the mask image must be enabled . ClipWarningCount is a value between 1 and 8. * - :ref:`CanvasClip ` - Configures the Canvas Clipping for the conversion * - :ref:`Crop ` - The cropping configuration of the outpu * - :ref:`OutputScaleFactor ` - The scaling factor of the output image if set. * - :ref:`OutputWidth ` - The width of the output image if set. * - :ref:`OutputHeight ` - The height of the output image if set. Methods ^^^^^^^ .. toctree:: :hidden: Clone GetDiscretizedRedCurve GetDiscretizedGreenCurve GetDiscretizedBlueCurve GetDiscretizedLumaCurve GetDiscretizedRgbCurve SetOutputFormat OutputFormat SetOutputColorSpace OutputColorSpace SetCanvasClip SetCrop SetCrop ResetCrop ResetOutputScaling SetOutputScale SetOutputWidth SetOutputHeight SetContrast SetBrightness SetSaturation SetExposure SetPolynomialTransformation SetPolynomialTransformationNormalized SetGain SetBlackLevel SetBlackLevelTarget SetMidtoneLevel SetWhiteLevel SetWhiteLevelTarget SetSharpening SetLuminanceNoiseReductionAmount SetNoiseReductionSinglePixelEnabled SetColorNoiseReductionAmount SetClarity SetShadowRecovery SetHighlightRecovery SetWhiteBalanceGain SetWhiteBalanceMode SetGeometricCorrectionEnabled SetGeometricCorrection SetGeometricCorrectionCompensationEnabled SetGeometricCorrectionCompensationPressure SetEnableLinearPath SetOrientation SetDualExposureOutput SetExposureMaskThreshold SetMaskThresholdClipWarningCount SetRedCurve SetGreenCurve SetBlueCurve SetLumaCurve SetRgbCurve SaveToFile Serialize ApplyTo ApplyTo LoadFromFile Deserialize Discretize .. list-table:: :widths: 33 67 * - :ref:`Clone() ` - Creates a clone of the current :ref:`ConvertConfig `, which can be modified independently of the current object * - :ref:`GetDiscretizedRedCurve(int numDiscretizedPoints) ` - Get the curve used by internal ImageSDK * - :ref:`GetDiscretizedGreenCurve(int numDiscretizedPoints) ` - Get the curve used by internal ImageSDK * - :ref:`GetDiscretizedBlueCurve(int numDiscretizedPoints) ` - Get the curve used by internal ImageSDK * - :ref:`GetDiscretizedLumaCurve(int numDiscretizedPoints) ` - Get the curve used by internal ImageSDK * - :ref:`GetDiscretizedRgbCurve(int numDiscretizedPoints) ` - Get the curve used by internal ImageSDK * - :ref:`SetOutputFormat(BitmapFormat format) ` - Set the pixel format for the output image. * - :ref:`OutputFormat() ` - Gets the current configured pixel format, that this config object will produce * - :ref:`SetOutputColorSpace(ColorSpace colorspace) ` - Set the pixel format for the output image. * - :ref:`OutputColorSpace() ` - The color space of the output image * - :ref:`SetCanvasClip(CanvasClip canvasClip) ` - Sets the :ref:`CanvasClip ` property * - :ref:`SetCrop(int x, int y, int width, int height) ` - Configure for cropping the raw-image * - :ref:`SetCrop(Rect cropRect) ` - Configure for cropping the raw-image * - :ref:`ResetCrop() ` - Reset (remove) any applied crop * - :ref:`ResetOutputScaling() ` - Convenience method to reset (remove) any scaling. * - :ref:`SetOutputScale(double scaleFactor) ` - Configure scaling of the raw-image * - :ref:`SetOutputWidth(int destinationWidth) ` - Configures the output scaling using an absolute output *width*. Height is automatically calculated from the aspect ratio. * - :ref:`SetOutputHeight(int destinationHeight) ` - Configures the output scaling using an absolute output *height*. Width is automatically calculated from the aspect ratio. * - :ref:`SetContrast(float contrast) ` - Adjust the contrast of the image * - :ref:`SetBrightness(float brightness) ` - Adjust the brightness of the image * - :ref:`SetSaturation(float saturation) ` - Adjust the saturation of colors in the image * - :ref:`SetExposure(float exposure) ` - Adjust th exposure of the image. This is doing almost the same as the SetGain but using an exponential function. * - :ref:`SetPolynomialTransformation(float ax, float bx, float cx, float ay, float by, float cy) ` - Gain image nonlinearly. See :ref:`PolynomialTransform ` * - :ref:`SetPolynomialTransformationNormalized(float ax, float bx, float cx, float ay, float by, float cy) ` - Gain image nonlinearly. See :ref:`PolynomialTransformNormalized ` * - :ref:`SetGain(float gain) ` - Adjust the gain of the image. This is doing almost the same as SetExposure but just as a linear gain value. * - :ref:`SetBlackLevel(float r, float g, float b) ` - Set the black level. This is a color that is regarded as black as in the level tool of most image editors * - :ref:`SetBlackLevelTarget(float r, float g, float b) ` - Set the black level target. This is a color that is regarded as black as in the level tool of most image editors * - :ref:`SetMidtoneLevel(float r, float g, float b) ` - Set the midtone level. This is a color that is used as 50% level of the color values. Known from the level tool of most image editors * - :ref:`SetWhiteLevel(float r, float g, float b) ` - Set the white level. This is a color that is regarded as white. Known from the level tool of most image editors * - :ref:`SetWhiteLevelTarget(float r, float g, float b) ` - Set the white level target. This is a color that is regarded as white. Known from the level tool of most image editors * - :ref:`SetSharpening(float amount, float radius, float threshold, float haloAmount) ` - Adjust the parameters of sharpening of the image. * - :ref:`SetLuminanceNoiseReductionAmount(float luminanceNoiseReductionAmount) ` - Sets the strength of the Luminance Noise Reduction algorithm to reduce noise. * - :ref:`SetNoiseReductionSinglePixelEnabled(bool noiseReductionSinglePixelEnabled) ` - Toggles Single Pixel noise reduction to eliminate hot pixels * - :ref:`SetColorNoiseReductionAmount(float colorNoiseReductionAmount) ` - Sets the strength of the :ref:`Color ` Noise Reduction algorithm to reduce noise. * - :ref:`SetClarity(int clarityMethod, float clarityFactor) ` - Setup the clarity tool. Its used as a tool to help control the local contrast in the image. A negative value will decrease local contrast and and positive increase it. Its a combination of selecting a method and a factor (amount) * - :ref:`SetShadowRecovery(float shadowRecovery) ` - Set shadow recovery. Used to extract details only in the shadows of the image by making them brighter. * - :ref:`SetHighlightRecovery(float highlightRecovery) ` - Set highlight recovery. Used to extract details only in the highlights of the image by reducing the brightness of highlight pixels. * - :ref:`SetWhiteBalanceGain(float redGain, float greenGain, float blueGain) ` - Sets the White Balance as gain for each channels (RGB) * - :ref:`SetWhiteBalanceMode(WhiteBalanceMode mode) ` - Sets the White Balance mode * - :ref:`SetGeometricCorrectionEnabled(bool enabled) ` - Sets the Enabled state of the Geometric Aberration correction * - :ref:`SetGeometricCorrection(GeometricCorrection geometricCorrection) ` - Sets Geometric Aberration correction parameters to be applied. * - :ref:`SetGeometricCorrectionCompensationEnabled(bool enabled) ` - Sets the Enabled to allow to compensation Geometric Aberration for environmental variables * - :ref:`SetGeometricCorrectionCompensationPressure(float pressure) ` - Inject a value for the environmental pressure variable used for compensation of Geometric Aberration * - :ref:`SetEnableLinearPath(bool enabled) ` - Set EnableLinearPath setting. This setting is used to disable most of the processing steps to make sure that the debayering of the image into rgb domain is done only using a simple linear mapping enabling only the minimum needed processing. * - :ref:`SetOrientation(OrientationMode orientation) ` - * - :ref:`SetDualExposureOutput(DualExposureOutput mode) ` - * - :ref:`SetExposureMaskThreshold(float overExposureThreshold, float underExposureThreshold) ` - Threshold for exposure mask * - :ref:`SetMaskThresholdClipWarningCount(int count) ` - Threshold for clipping count * - :ref:`SetRedCurve(Point2D[] points) ` - Set the curve for red values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`SetGreenCurve(Point2D[] points) ` - Set the curve for green values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`SetBlueCurve(Point2D[] points) ` - Set the curve for blue values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`SetLumaCurve(Point2D[] points) ` - Set the curve for luma values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`SetRgbCurve(Point2D[] points) ` - Set the curve for rgb values as known from the curves tool in most image editors. The curve is defined as a vector of discreete coordinate pairs (x,y) that is interpolated. * - :ref:`SaveToFile(string filePath) ` - Stores the :ref:`ConvertConfig ` object to a persisted model located at filePath * - :ref:`Serialize() ` - Returns a serialized JSON representation of the :ref:`ConvertConfig ` object * - :ref:`ApplyTo(RawImage image, Func\< UInt32, byte[]> allocFunction=null) ` - Trigger processing of the applied options on the raw-image and return a new image as an RGB bitmap * - :ref:`ApplyTo(RawImage image, ref BitmapImage maskImage, Func\< UInt32, byte[]> allocFunction=null) ` - Trigger processing of the applied options on the raw-image and return a new image as an RGB bitmap * - :ref:`LoadFromFile(string filePath) ` - Creates a :ref:`ConvertConfig ` object from a persisted model located at filePath * - :ref:`Deserialize(string json) ` - Creates a :ref:`ConvertConfig ` object from a well-formed JSON string * - :ref:`Discretize(Point2D[] points, UInt16 bits) ` - Returns a list of 'Y' values of the :ref:`Curve ` defined by the input Points. This is applicable for the RGB/LumaCurve)