To enable or disable the Balance White Auto auto function:
Assign at least one auto function ROI to the Balance White Auto auto function. Make sure the auto function ROI overlaps the image ROI, either partially or completely.
Set the BalanceWhiteAuto parameter to one of the following operating modes:
Once: The camera adjusts the white balance until the average gray values for red, green, and blue are identical. When this has been achieved, or after several calculation cycles, the camera sets the auto function to Off and applies the balance ratios resulting from the last calculation to all following images.
Continuous: The camera adjusts the white balance continuously while images are being acquired. The adjustment process continues until the operating mode is set to Once or Off.
Off: Disables the Balance White Auto auto function. The BalanceRatioAbs parameters remain at the values resulting from the last automatic or manual adjustment.
Info
On the following camera models, the Continuous operating mode is not available: acA1600-20gc, acA1920-25gc, acA2500-14gc, racer 2 S color cameras
The camera compares the average gray values of the red, green, and blue pixels. It determines the color with the highest average gray value (i.e., the brightest color) and sets the BalanceRatioAbs parameter value for this color to 1.
The camera automatically adjusts the BalanceRatioAbs parameter values of the other two colors until the average gray values for red, green, and blue are identical.
As a result, the BalanceRatioAbs parameter is set to 1 for one color and to a value between 1 and ≈15.98 for the other two colors.
Example: Assume the green pixels in your image have the highest average gray value. If you enable the Balance White Auto auto function, the camera sets the BalanceRatioAbs parameter value for green to 1. Then, the camera automatically adjusts the BalanceRatioAbs parameter values for red and blue until the average gray values for red, green, and blue are identical. The new balance ratios could be, e.g., green = 1, red = 1.08789, and blue = 2.19678.
Info
To view the BalanceRatioAbs parameter values for red, green, or blue, switch to the respective color channel using the BalanceRatioSelector.
When the camera is capturing images continuously, the auto function takes effect with a short delay. The first few images may not be affected by the auto function.
On boost V color cameras, the auto function ROIs which are assigned to the Balance White Auto auto function, must not contain any color pixels with 100 % saturation. Otherwise, undesirable false-color effects will occur.
// Select auto function ROI 2camera.AutoFunctionAOISelector.SetValue(AutoFunctionAOISelector_AOI2);// Enable the Balance White Auto auto function// for the auto function ROI selectedcamera.AutoFunctionAOIUsageWhiteBalance.SetValue(true);// Enable Balance White Auto by setting the operating mode to Continuouscamera.BalanceWhiteAuto.SetValue(BalanceWhiteAuto_Continuous);
INodeMap&nodemap=camera.GetNodeMap();// Select auto function ROI 2CEnumParameter(nodemap,"AutoFunctionAOISelector").SetValue("AOI2");// Enable the Balance White Auto auto function// for the auto function ROI selectedCBooleanParameter(nodemap,"AutoFunctionAOIUsageWhiteBalance").SetValue(true);// Enable Balance White Auto by setting the operating mode to ContinuousCEnumParameter(nodemap,"BalanceWhiteAuto").SetValue("Continuous");
// Select auto function ROI 2camera.Parameters[PLCamera.AutoFunctionAOISelector].SetValue(PLCamera.AutoFunctionAOISelector.AOI2);// Enable the Balance White Auto auto function// for the auto function ROI selectedcamera.Parameters[PLCamera.AutoFunctionAOIUsageWhiteBalance].SetValue(true);// Enable Balance White Auto by setting the operating mode to Continuouscamera.Parameters[PLCamera.BalanceWhiteAuto].SetValue(PLCamera.BalanceWhiteAuto.Continuous);
/* Macro to check for errors */#define CHECK(errc) if (GENAPI_E_OK != errc) printErrorAndExit(errc)GENAPIC_RESULTerrRes=GENAPI_E_OK;/* Return value of pylon methods *//* Select auto function ROI 2 */errRes=PylonDeviceFeatureFromString(hdev,"AutoFunctionAOISelector","AOI2");CHECK(errRes);/* Enable the Balance White Auto auto function *//* for the auto function ROI selected */errRes=PylonDeviceSetBooleanFeature(hdev,"AutoFunctionAOIUsageWhiteBalance",1);CHECK(errRes);/* Enable Balance White Auto by setting the operating mode to Continuous */errRes=PylonDeviceFeatureFromString(hdev,"BalanceWhiteAuto","Continuous");CHECK(errRes);
# Select auto function ROI 2camera.AutoFunctionAOISelector.Value="AOI2"# Enable the Balance White Auto auto function# for the auto function ROI selectedcamera.AutoFunctionAOIUsageWhiteBalance.Value=True# Enable Balance White Auto by setting the operating mode to Continuouscamera.BalanceWhiteAuto.Value="Continuous"
// Select auto function ROI 2camera.AutoFunctionROISelector.SetValue(AutoFunctionROISelector_ROI2);// Enable the Balance White Auto auto function// for the auto function ROI selectedcamera.AutoFunctionROIUseWhiteBalance.SetValue(true);// Enable Balance White Auto by setting the operating mode to Continuouscamera.BalanceWhiteAuto.SetValue(BalanceWhiteAuto_Continuous);
INodeMap&nodemap=camera.GetNodeMap();// Select auto function ROI 2CEnumParameter(nodemap,"AutoFunctionROISelector").SetValue("ROI2");// Enable the Balance White Auto auto function// for the auto function ROI selectedCBooleanParameter(nodemap,"AutoFunctionROIUseWhiteBalance").SetValue(true);// Enable Balance White Auto by setting the operating mode to ContinuousCEnumParameter(nodemap,"BalanceWhiteAuto").SetValue("Continuous");
// Select auto function ROI 2camera.Parameters[PLCamera.AutoFunctionROISelector].SetValue(PLCamera.AutoFunctionROISelector.ROI2);// Enable the Balance White Auto auto function// for the auto function ROI selectedcamera.Parameters[PLCamera.AutoFunctionROIUseWhiteBalance].SetValue(true);// Enable Balance White Auto by setting the operating mode to Continuouscamera.Parameters[PLCamera.BalanceWhiteAuto].SetValue(PLCamera.BalanceWhiteAuto.Continuous);
/* Macro to check for errors */#define CHECK(errc) if (GENAPI_E_OK != errc) printErrorAndExit(errc)GENAPIC_RESULTerrRes=GENAPI_E_OK;/* Return value of pylon methods *//* Select auto function ROI 2 */errRes=PylonDeviceFeatureFromString(hdev,"AutoFunctionROISelector","ROI2");CHECK(errRes);/* Enable the Balance White Auto auto function *//* for the auto function ROI selected */errRes=PylonDeviceSetBooleanFeature(hdev,"AutoFunctionROIUseWhiteBalance",1);CHECK(errRes);/* Enable Balance White Auto by setting the operating mode to Continuous */errRes=PylonDeviceFeatureFromString(hdev,"BalanceWhiteAuto","Continuous");CHECK(errRes);
# Select auto function ROI 2camera.AutoFunctionROISelector.Value="ROI2"# Enable the Balance White Auto auto function# for the auto function ROI selectedcamera.AutoFunctionROIUseWhiteBalance.Value=True# Enable Balance White Auto by setting the operating mode to Continuouscamera.BalanceWhiteAuto.Value="Continuous"