/*============================================================================*/ | |
/* IMAQ Vision */ | |
/*----------------------------------------------------------------------------*/ | |
/* Copyright (c) National Instruments 2001. All Rights Reserved. */ | |
/*----------------------------------------------------------------------------*/ | |
/* */ | |
/* Title: NIVision.h */ | |
/* */ | |
/*============================================================================*/ | |
#if !defined(NiVision_h) | |
#define NiVision_h | |
//============================================================================ | |
// Includes | |
//============================================================================ | |
#include <stddef.h> | |
//============================================================================ | |
// Control Defines | |
//============================================================================ | |
#if !defined(IMAQ_IMPORT) | |
#ifndef __GNUC__ | |
#define IMAQ_IMPORT __declspec(dllimport) | |
#else | |
#define IMAQ_IMPORT | |
#endif | |
#endif | |
#if !defined(IMAQ_FUNC) | |
#if !defined(__cplusplus) | |
#define IMAQ_FUNC IMAQ_IMPORT | |
#else | |
#define IMAQ_FUNC extern "C" IMAQ_IMPORT | |
#endif | |
#endif | |
#if !defined(IMAQ_STDCALL) | |
#ifndef __GNUC__ | |
#define IMAQ_STDCALL __stdcall | |
#else | |
#define IMAQ_STDCALL | |
#endif | |
#endif | |
#ifdef _CVI_ | |
#pragma EnableLibraryRuntimeChecking | |
#include <ansi_c.h> | |
#endif | |
#define IMAQ_CALLBACK __cdecl | |
//============================================================================ | |
// Manifest Constants | |
//============================================================================ | |
#ifndef NULL | |
#ifdef __cplusplus | |
#define NULL 0 | |
#else | |
#define NULL ((void *)0) | |
#endif | |
#endif | |
#ifndef FALSE | |
#define FALSE 0 | |
#endif | |
#ifndef TRUE | |
#define TRUE 1 | |
#endif | |
#define IMAQ_DEFAULT_SHOW_COORDINATES TRUE | |
#define IMAQ_DEFAULT_MAX_ICONS_PER_LINE 4 | |
#define IMAQ_DEFAULT_LEARNING_MODE IMAQ_LEARN_SHIFT_INFORMATION | |
#define IMAQ_DEFAULT_BMP_COMPRESS FALSE | |
#define IMAQ_DEFAULT_PNG_QUALITY 750 | |
#define IMAQ_DEFAULT_JPEG_QUALITY 750 | |
#define IMAQ_ALL_CONTOURS -1 | |
#define IMAQ_ALL_WINDOWS -1 | |
#define IMAQ_SHIFT 1 | |
#define IMAQ_ALT 2 | |
#define IMAQ_CTRL 4 | |
#define IMAQ_CAPS_LOCK 8 | |
#define IMAQ_MODAL_DIALOG -1 | |
#define IMAQ_INIT_RGB_TRANSPARENT { 0, 0, 0, 1 } | |
#define IMAQ_INIT_RGB_RED { 0, 0, 255, 0 } | |
#define IMAQ_INIT_RGB_BLUE { 255, 0, 0, 0 } | |
#define IMAQ_INIT_RGB_GREEN { 0, 255, 0, 0 } | |
#define IMAQ_INIT_RGB_YELLOW { 0, 255, 255, 0 } | |
#define IMAQ_INIT_RGB_WHITE { 255, 255, 255, 0 } | |
#define IMAQ_INIT_RGB_BLACK { 0, 0, 0, 0 } | |
#define IMAQ_USE_DEFAULT_QUALITY -1 | |
#define IMAQ_ALL_SAMPLES -1 | |
#define IMAQ_ALL_OBJECTS -1 | |
#define IMAQ_ALL_CHARACTERS -1 | |
//============================================================================ | |
// Predefined Valid Characters | |
//============================================================================ | |
#define IMAQ_ANY_CHARACTER "" //Any Character | |
#define IMAQ_ALPHABETIC "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" //Alphabetic | |
#define IMAQ_ALPHANUMERIC "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789" //Alphanumeric | |
#define IMAQ_UPPERCASE_LETTERS "ABCDEFGHIJKLMNOPQRSTUVWXYZ" //Uppercase Letters | |
#define IMAQ_LOWERCASE_LETTERS "abcdefghijklmnopqrstuvwxyz" //Lowercase Letters | |
#define IMAQ_DECIMAL_DIGITS "0123456789" //Decimal Digits | |
#define IMAQ_HEXADECIMAL_DIGITS "0123456789ABCDEFabcdef" //Hexadecimal Digits | |
#define IMAQ_PATTERN "\xFF" //Pattern (A single character string with the character value set to 255) | |
#define IMAQ_FORCE_SPACE " " //Force Space | |
//============================================================================ | |
// Macros | |
//============================================================================ | |
#define IMAQ_NO_RECT imaqMakeRect( 0, 0, 0x7FFFFFFF, 0x7FFFFFFF) | |
#define IMAQ_NO_ROTATED_RECT imaqMakeRotatedRect( 0, 0, 0x7FFFFFFF, 0x7FFFFFFF, 0) | |
#define IMAQ_NO_POINT imaqMakePoint( -1, -1) | |
#define IMAQ_NO_POINT_FLOAT imaqMakePointFloat( -1.0, -1.0 ) | |
#define IMAQ_NO_OFFSET imaqMakePointFloat( 0.0, 0.0 ) | |
//============================================================================ | |
// When in Borland, some functions must be mapped to different names. | |
// This accomplishes said task. | |
//============================================================================ | |
#if defined(__BORLANDC__) || (defined(_CVI_) && defined(_NI_BC_)) | |
#define imaqMakePoint imaqMakePoint_BC | |
#define imaqMakePointFloat imaqMakePointFloat_BC | |
#endif | |
//============================================================================ | |
// When in Watcom, some functions must be mapped to different names. | |
// This accomplishes said task. | |
//============================================================================ | |
#if defined(__WATCOMC__) || (defined(_CVI_) && defined(_NI_WC_)) | |
#define imaqMakePoint imaqMakePoint_BC | |
#define imaqMakePointFloat imaqMakePointFloat_BC | |
#endif | |
//============================================================================ | |
// If using Visual C++, force startup & shutdown code to run. | |
//============================================================================ | |
#if defined(_MSC_VER) && !defined(_CVI_) && !defined(__BORLANDC__) | |
#pragma comment(linker, "/INCLUDE:_nivision_startup_shutdown") | |
#pragma comment(linker, "/DEFAULTLIB:nivision.lib") | |
#endif | |
//============================================================================ | |
// Error Codes | |
//============================================================================ | |
#define ERR_SUCCESS 0 // No error. | |
#define ERR_SYSTEM_ERROR -1074396160 // System error. | |
#define ERR_OUT_OF_MEMORY -1074396159 // Not enough memory for requested operation. | |
#define ERR_MEMORY_ERROR -1074396158 // Memory error. | |
#define ERR_UNREGISTERED -1074396157 // Unlicensed copy of NI Vision. | |
#define ERR_NEED_FULL_VERSION -1074396156 // The function requires an NI Vision 5.0 Advanced license. | |
#define ERR_UNINIT -1074396155 // NI Vision did not initialize properly. | |
#define ERR_IMAGE_TOO_SMALL -1074396154 // The image is not large enough for the operation. | |
#define ERR_BARCODE_CODABAR -1074396153 // The barcode is not a valid Codabar barcode. | |
#define ERR_BARCODE_CODE39 -1074396152 // The barcode is not a valid Code 3 of 9 barcode. | |
#define ERR_BARCODE_CODE93 -1074396151 // The barcode is not a valid Code93 barcode. | |
#define ERR_BARCODE_CODE128 -1074396150 // The barcode is not a valid Code128 barcode. | |
#define ERR_BARCODE_EAN8 -1074396149 // The barcode is not a valid EAN8 barcode. | |
#define ERR_BARCODE_EAN13 -1074396148 // The barcode is not a valid EAN13 barcode. | |
#define ERR_BARCODE_I25 -1074396147 // The barcode is not a valid Interleaved 2 of 5 barcode. | |
#define ERR_BARCODE_MSI -1074396146 // The barcode is not a valid MSI barcode. | |
#define ERR_BARCODE_UPCA -1074396145 // The barcode is not a valid UPCA barcode. | |
#define ERR_BARCODE_CODE93_SHIFT -1074396144 // The Code93 barcode contains invalid shift encoding. | |
#define ERR_BARCODE_TYPE -1074396143 // The barcode type is invalid. | |
#define ERR_BARCODE_INVALID -1074396142 // The image does not represent a valid linear barcode. | |
#define ERR_BARCODE_CODE128_FNC -1074396141 // The FNC value in the Code128 barcode is not located before the first data value. | |
#define ERR_BARCODE_CODE128_SET -1074396140 // The starting code set in the Code128 barcode is not valid. | |
#define ERR_ROLLBACK_RESOURCE_OUT_OF_MEMORY -1074396139 // Not enough reserved memory in the timed environment for the requested operation. | |
#define ERR_ROLLBACK_NOT_SUPPORTED -1074396138 // The function is not supported when a time limit is active. | |
#define ERR_DIRECTX_DLL_NOT_FOUND -1074396137 // Quartz.dll not found. Install DirectX 8.1 or later. | |
#define ERR_DIRECTX_INVALID_FILTER_QUALITY -1074396136 // The filter quality you provided is invalid. Valid quality values range from -1 to 1000. | |
#define ERR_INVALID_BUTTON_LABEL -1074396135 // Invalid button label. | |
#define ERR_THREAD_INITIALIZING -1074396134 // Could not execute the function in the separate thread because the thread has not completed initialization. | |
#define ERR_THREAD_COULD_NOT_INITIALIZE -1074396133 // Could not execute the function in the separate thread because the thread could not initialize. | |
#define ERR_MASK_NOT_TEMPLATE_SIZE -1074396132 // The mask must be the same size as the template. | |
#define ERR_NOT_RECT_OR_ROTATED_RECT -1074396130 // The ROI must only have either a single Rectangle contour or a single Rotated Rectangle contour. | |
#define ERR_ROLLBACK_UNBOUNDED_INTERFACE -1074396129 // During timed execution, you must use the preallocated version of this operation. | |
#define ERR_ROLLBACK_RESOURCE_CONFLICT_3 -1074396128 // An image being modified by one process cannot be requested by another process while a time limit is active. | |
#define ERR_ROLLBACK_RESOURCE_CONFLICT_2 -1074396127 // An image with pattern matching, calibration, or overlay information cannot be manipulated while a time limit is active. | |
#define ERR_ROLLBACK_RESOURCE_CONFLICT_1 -1074396126 // An image created before a time limit is started cannot be resized while a time limit is active. | |
#define ERR_INVALID_CONTRAST_THRESHOLD -1074396125 // Invalid contrast threshold. The threshold value must be greater than 0. | |
#define ERR_INVALID_CALIBRATION_ROI_MODE -1074396124 // NI Vision does not support the calibration ROI mode you supplied. | |
#define ERR_INVALID_CALIBRATION_MODE -1074396123 // NI Vision does not support the calibration mode you supplied. | |
#define ERR_DRAWTEXT_COLOR_MUST_BE_GRAYSCALE -1074396122 // Set the foreground and background text colors to grayscale to draw on a U8 image. | |
#define ERR_SATURATION_THRESHOLD_OUT_OF_RANGE -1074396121 // The value of the saturation threshold must be from 0 to 255. | |
#define ERR_NOT_IMAGE -1074396120 // Not an image. | |
#define ERR_CUSTOMDATA_INVALID_KEY -1074396119 // They custom data key you supplied is invalid. The only valid character values are decimal 32-126 and 161-255. There must also be no repeated, leading, or trailing spaces. | |
#define ERR_INVALID_STEP_SIZE -1074396118 // Step size must be greater than zero and less than Image size | |
#define ERR_MATRIX_SIZE -1074396117 // Invalid matrix size in the structuring element. | |
#define ERR_CALIBRATION_INSF_POINTS -1074396116 // Insufficient number of calibration feature points. | |
#define ERR_CALIBRATION_IMAGE_CORRECTED -1074396115 // The operation is invalid in a corrected image. | |
#define ERR_CALIBRATION_INVALID_ROI -1074396114 // The ROI contains an invalid contour type or is not contained in the ROI learned for calibration. | |
#define ERR_CALIBRATION_IMAGE_UNCALIBRATED -1074396113 // The source/input image has not been calibrated. | |
#define ERR_INCOMP_MATRIX_SIZE -1074396112 // The number of pixel and real-world coordinates must be equal. | |
#define ERR_CALIBRATION_FAILED_TO_FIND_GRID -1074396111 // Unable to automatically detect grid because the image is too distorted. | |
#define ERR_CALIBRATION_INFO_VERSION -1074396110 // Invalid calibration information version. | |
#define ERR_CALIBRATION_INVALID_SCALING_FACTOR -1074396109 // Invalid calibration scaling factor. | |
#define ERR_CALIBRATION_ERRORMAP -1074396108 // The calibration error map cannot be computed. | |
#define ERR_CALIBRATION_INFO_1 -1074396107 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_2 -1074396106 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_3 -1074396105 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_4 -1074396104 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_5 -1074396103 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_6 -1074396102 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_MICRO_PLANE -1074396101 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_PERSPECTIVE_PROJECTION -1074396100 // Invalid calibration template image. | |
#define ERR_CALIBRATION_INFO_SIMPLE_TRANSFORM -1074396099 // Invalid calibration template image. | |
#define ERR_RESERVED_MUST_BE_NULL -1074396098 // You must pass NULL for the reserved parameter. | |
#define ERR_INVALID_PARTICLE_PARAMETER_VALUE -1074396097 // You entered an invalid selection in the particle parameter. | |
#define ERR_NOT_AN_OBJECT -1074396096 // Not an object. | |
#define ERR_CALIBRATION_DUPLICATE_REFERENCE_POINT -1074396095 // The reference points passed are inconsistent. At least two similar pixel coordinates correspond to different real-world coordinates. | |
#define ERR_ROLLBACK_RESOURCE_CANNOT_UNLOCK -1074396094 // A resource conflict occurred in the timed environment. Two processes cannot manage the same resource and be time bounded. | |
#define ERR_ROLLBACK_RESOURCE_LOCKED -1074396093 // A resource conflict occurred in the timed environment. Two processes cannot access the same resource and be time bounded. | |
#define ERR_ROLLBACK_RESOURCE_NON_EMPTY_INITIALIZE -1074396092 // Multiple timed environments are not supported. | |
#define ERR_ROLLBACK_RESOURCE_UNINITIALIZED_ENABLE -1074396091 // A time limit cannot be started until the timed environment is initialized. | |
#define ERR_ROLLBACK_RESOURCE_ENABLED -1074396090 // Multiple timed environments are not supported. | |
#define ERR_ROLLBACK_RESOURCE_REINITIALIZE -1074396089 // The timed environment is already initialized. | |
#define ERR_ROLLBACK_RESIZE -1074396088 // The results of the operation exceeded the size limits on the output data arrays. | |
#define ERR_ROLLBACK_STOP_TIMER -1074396087 // No time limit is available to stop. | |
#define ERR_ROLLBACK_START_TIMER -1074396086 // A time limit could not be set. | |
#define ERR_ROLLBACK_INIT_TIMER -1074396085 // The timed environment could not be initialized. | |
#define ERR_ROLLBACK_DELETE_TIMER -1074396084 // No initialized timed environment is available to close. | |
#define ERR_ROLLBACK_TIMEOUT -1074396083 // The time limit has expired. | |
#define ERR_PALETTE_NOT_SUPPORTED -1074396082 // Only 8-bit images support the use of palettes. Either do not use a palette, or convert your image to an 8-bit image before using a palette. | |
#define ERR_BAD_PASSWORD -1074396081 // Incorrect password. | |
#define ERR_INVALID_IMAGE_TYPE -1074396080 // Invalid image type. | |
#define ERR_INVALID_METAFILE_HANDLE -1074396079 // Invalid metafile handle. | |
#define ERR_INCOMP_TYPE -1074396077 // Incompatible image type. | |
#define ERR_COORD_SYS_FIRST_AXIS -1074396076 // Unable to fit a line for the primary axis. | |
#define ERR_COORD_SYS_SECOND_AXIS -1074396075 // Unable to fit a line for the secondary axis. | |
#define ERR_INCOMP_SIZE -1074396074 // Incompatible image size. | |
#define ERR_MASK_OUTSIDE_IMAGE -1074396073 // When the mask's offset was applied, the mask was entirely outside of the image. | |
#define ERR_INVALID_BORDER -1074396072 // Invalid image border. | |
#define ERR_INVALID_SCAN_DIRECTION -1074396071 // Invalid scan direction. | |
#define ERR_INVALID_FUNCTION -1074396070 // Unsupported function. | |
#define ERR_INVALID_COLOR_MODE -1074396069 // NI Vision does not support the color mode you specified. | |
#define ERR_INVALID_ACTION -1074396068 // The function does not support the requested action. | |
#define ERR_IMAGES_NOT_DIFF -1074396067 // The source image and destination image must be different. | |
#define ERR_INVALID_POINTSYMBOL -1074396066 // Invalid point symbol. | |
#define ERR_CANT_RESIZE_EXTERNAL -1074396065 // Cannot resize an image in an acquisition buffer. | |
#define ERR_EXTERNAL_NOT_SUPPORTED -1074396064 // This operation is not supported for images in an acquisition buffer. | |
#define ERR_EXTERNAL_ALIGNMENT -1074396063 // The external buffer must be aligned on a 4-byte boundary. The line width and border pixels must be 4-byte aligned, as well. | |
#define ERR_INVALID_TOLERANCE -1074396062 // The tolerance parameter must be greater than or equal to 0. | |
#define ERR_INVALID_WINDOW_SIZE -1074396061 // The size of each dimension of the window must be greater than 2 and less than or equal to the size of the image in the corresponding dimension. | |
#define ERR_JPEG2000_LOSSLESS_WITH_FLOATING_POINT -1074396060 // Lossless compression cannot be used with the floating point wavelet transform mode. Either set the wavelet transform mode to integer, or use lossy compression. | |
#define ERR_INVALID_MAX_ITERATIONS -1074396059 // Invalid maximum number of iterations. Maximum number of iterations must be greater than zero. | |
#define ERR_INVALID_ROTATION_MODE -1074396058 // Invalid rotation mode. | |
#define ERR_INVALID_SEARCH_VECTOR_WIDTH -1074396057 // Invalid search vector width. The width must be an odd number greater than zero. | |
#define ERR_INVALID_MATRIX_MIRROR_MODE -1074396056 // Invalid matrix mirror mode. | |
#define ERR_INVALID_ASPECT_RATIO -1074396055 // Invalid aspect ratio. Valid aspect ratios must be greater than or equal to zero. | |
#define ERR_INVALID_CELL_FILL_TYPE -1074396054 // Invalid cell fill type. | |
#define ERR_INVALID_BORDER_INTEGRITY -1074396053 // Invalid border integrity. Valid values range from 0 to 100. | |
#define ERR_INVALID_DEMODULATION_MODE -1074396052 // Invalid demodulation mode. | |
#define ERR_INVALID_CELL_FILTER_MODE -1074396051 // Invalid cell filter mode. | |
#define ERR_INVALID_ECC_TYPE -1074396050 // Invalid ECC type. | |
#define ERR_INVALID_MATRIX_POLARITY -1074396049 // Invalid matrix polarity. | |
#define ERR_INVALID_CELL_SAMPLE_SIZE -1074396048 // Invalid cell sample size. | |
#define ERR_INVALID_LINEAR_AVERAGE_MODE -1074396047 // Invalid linear average mode. | |
#define ERR_INVALID_2D_BARCODE_CONTRAST_FOR_ROI -1074396046 // When using a region of interest that is not a rectangle, you must specify the contrast mode of the barcode as either black on white or white on black. | |
#define ERR_INVALID_2D_BARCODE_SUBTYPE -1074396045 // Invalid 2-D barcode Data Matrix subtype. | |
#define ERR_INVALID_2D_BARCODE_SHAPE -1074396044 // Invalid 2-D barcode shape. | |
#define ERR_INVALID_2D_BARCODE_CELL_SHAPE -1074396043 // Invalid 2-D barcode cell shape. | |
#define ERR_INVALID_2D_BARCODE_CONTRAST -1074396042 // Invalid 2-D barcode contrast. | |
#define ERR_INVALID_2D_BARCODE_TYPE -1074396041 // Invalid 2-D barcode type. | |
#define ERR_DRIVER -1074396040 // Cannot access NI-IMAQ driver. | |
#define ERR_IO_ERROR -1074396039 // I/O error. | |
#define ERR_FIND_COORDSYS_MORE_THAN_ONE_EDGE -1074396038 // When searching for a coordinate system, the number of lines to fit must be 1. | |
#define ERR_TIMEOUT -1074396037 // Trigger timeout. | |
#define ERR_INVALID_SKELETONMODE -1074396036 // The Skeleton mode you specified is invalid. | |
#define ERR_TEMPLATEIMAGE_NOCIRCLE -1074396035 // The template image does not contain enough information for learning the aggressive search strategy. | |
#define ERR_TEMPLATEIMAGE_EDGEINFO -1074396034 // The template image does not contain enough edge information for the sample size(s) requested. | |
#define ERR_TEMPLATEDESCRIPTOR_LEARNSETUPDATA -1074396033 // Invalid template descriptor. | |
#define ERR_TEMPLATEDESCRIPTOR_ROTATION_SEARCHSTRATEGY -1074396032 // The template descriptor does not contain data required for the requested search strategy in rotation-invariant matching. | |
#define ERR_INVALID_TETRAGON -1074396031 // The input tetragon must have four points. The points are specified clockwise starting with the top left point. | |
#define ERR_TOO_MANY_CLASSIFICATION_SESSIONS -1074396030 // There are too many classification sessions open. You must close a session before you can open another one. | |
#define ERR_TIME_BOUNDED_EXECUTION_NOT_SUPPORTED -1074396028 // NI Vision no longer supports time-bounded execution. | |
#define ERR_INVALID_COLOR_RESOLUTION -1074396027 // Invalid Color Resolution for the Color Classifier | |
#define ERR_INVALID_PROCESS_TYPE_FOR_EDGE_DETECTION -1074396026 // Invalid process type for edge detection. | |
#define ERR_INVALID_ANGLE_RANGE_FOR_STRAIGHT_EDGE -1074396025 // Angle range value should be equal to or greater than zero. | |
#define ERR_INVALID_MIN_COVERAGE_FOR_STRAIGHT_EDGE -1074396024 // Minimum coverage value should be greater than zero. | |
#define ERR_INVALID_ANGLE_TOL_FOR_STRAIGHT_EDGE -1074396023 // The angle tolerance should be equal to or greater than 0.001. | |
#define ERR_INVALID_SEARCH_MODE_FOR_STRAIGHT_EDGE -1074396022 // Invalid search mode for detecting straight edges | |
#define ERR_INVALID_KERNEL_SIZE_FOR_EDGE_DETECTION -1074396021 // Invalid kernel size for edge detection. The minimum kernel size is 3, the maximum kernel size is 1073741823 and the kernel size must be odd. | |
#define ERR_INVALID_GRADING_MODE -1074396020 // Invalid grading mode. | |
#define ERR_INVALID_THRESHOLD_PERCENTAGE -1074396019 // Invalid threshold percentage. Valid values range from 0 to 100. | |
#define ERR_INVALID_EDGE_POLARITY_SEARCH_MODE -1074396018 // Invalid edge polarity search mode. | |
#define ERR_OPENING_NEWER_AIM_GRADING_DATA -1074396017 // The AIM grading data attached to the image you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_NO_VIDEO_DRIVER -1074396016 // No video driver is installed. | |
#define ERR_RPC_EXECUTE_IVB -1074396015 // Unable to establish network connection with remote system. | |
#define ERR_INVALID_VIDEO_BLIT -1074396014 // RT Video Out does not support displaying the supplied image type at the selected color depth. | |
#define ERR_INVALID_VIDEO_MODE -1074396013 // Invalid video mode. | |
#define ERR_RPC_EXECUTE -1074396012 // Unable to display remote image on network connection. | |
#define ERR_RPC_BIND -1074396011 // Unable to establish network connection. | |
#define ERR_INVALID_FRAME_NUMBER -1074396010 // Invalid frame number. | |
#define ERR_DIRECTX -1074396009 // An internal DirectX error has occurred. Try upgrading to the latest version of DirectX. | |
#define ERR_DIRECTX_NO_FILTER -1074396008 // An appropriate DirectX filter to process this file could not be found. Install the filter that was used to create this AVI. Upgrading to the latest version of DirectX may correct this error. NI Vision requires DirectX 8.1 or higher. | |
#define ERR_DIRECTX_INCOMPATIBLE_COMPRESSION_FILTER -1074396007 // Incompatible compression filter. | |
#define ERR_DIRECTX_UNKNOWN_COMPRESSION_FILTER -1074396006 // Unknown compression filter. | |
#define ERR_INVALID_AVI_SESSION -1074396005 // Invalid AVI session. | |
#define ERR_DIRECTX_CERTIFICATION_FAILURE -1074396004 // A software key is restricting the use of this compression filter. | |
#define ERR_AVI_DATA_EXCEEDS_BUFFER_SIZE -1074396003 // The data for this frame exceeds the data buffer size specified when creating the AVI file. | |
#define ERR_INVALID_LINEGAUGEMETHOD -1074396002 // Invalid line gauge method. | |
#define ERR_TOO_MANY_AVI_SESSIONS -1074396001 // There are too many AVI sessions open. You must close a session before you can open another one. | |
#define ERR_FILE_FILE_HEADER -1074396000 // Invalid file header. | |
#define ERR_FILE_FILE_TYPE -1074395999 // Invalid file type. | |
#define ERR_FILE_COLOR_TABLE -1074395998 // Invalid color table. | |
#define ERR_FILE_ARGERR -1074395997 // Invalid parameter. | |
#define ERR_FILE_OPEN -1074395996 // File is already open for writing. | |
#define ERR_FILE_NOT_FOUND -1074395995 // File not found. | |
#define ERR_FILE_TOO_MANY_OPEN -1074395994 // Too many files open. | |
#define ERR_FILE_IO_ERR -1074395993 // File I/O error. | |
#define ERR_FILE_PERMISSION -1074395992 // File access denied. | |
#define ERR_FILE_INVALID_TYPE -1074395991 // NI Vision does not support the file type you specified. | |
#define ERR_FILE_GET_INFO -1074395990 // Could not read Vision info from file. | |
#define ERR_FILE_READ -1074395989 // Unable to read data. | |
#define ERR_FILE_WRITE -1074395988 // Unable to write data. | |
#define ERR_FILE_EOF -1074395987 // Premature end of file. | |
#define ERR_FILE_FORMAT -1074395986 // Invalid file format. | |
#define ERR_FILE_OPERATION -1074395985 // Invalid file operation. | |
#define ERR_FILE_INVALID_DATA_TYPE -1074395984 // NI Vision does not support the file data type you specified. | |
#define ERR_FILE_NO_SPACE -1074395983 // Disk full. | |
#define ERR_INVALID_FRAMES_PER_SECOND -1074395982 // The frames per second in an AVI must be greater than zero. | |
#define ERR_INSUFFICIENT_BUFFER_SIZE -1074395981 // The buffer that was passed in is not big enough to hold all of the data. | |
#define ERR_COM_INITIALIZE -1074395980 // Error initializing COM. | |
#define ERR_INVALID_PARTICLE_INFO -1074395979 // The image has invalid particle information. Call imaqCountParticles on the image to create particle information. | |
#define ERR_INVALID_PARTICLE_NUMBER -1074395978 // Invalid particle number. | |
#define ERR_AVI_VERSION -1074395977 // The AVI file was created in a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this AVI file. | |
#define ERR_NUMBER_OF_PALETTE_COLORS -1074395976 // The color palette must have exactly 0 or 256 entries. | |
#define ERR_AVI_TIMEOUT -1074395975 // DirectX has timed out reading or writing the AVI file. When closing an AVI file, try adding an additional delay. When reading an AVI file, try reducing CPU and disk load. | |
#define ERR_UNSUPPORTED_JPEG2000_COLORSPACE_METHOD -1074395974 // NI Vision does not support reading JPEG2000 files with this colorspace method. | |
#define ERR_JPEG2000_UNSUPPORTED_MULTIPLE_LAYERS -1074395973 // NI Vision does not support reading JPEG2000 files with more than one layer. | |
#define ERR_DIRECTX_ENUMERATE_FILTERS -1074395972 // DirectX is unable to enumerate the compression filters. This is caused by a third-party compression filter that is either improperly installed or is preventing itself from being enumerated. Remove any recently installed compression filters and try again. | |
#define ERR_INVALID_OFFSET -1074395971 // The offset you specified must be size 2. | |
#define ERR_INIT -1074395960 // Initialization error. | |
#define ERR_CREATE_WINDOW -1074395959 // Unable to create window. | |
#define ERR_WINDOW_ID -1074395958 // Invalid window ID. | |
#define ERR_ARRAY_SIZE_MISMATCH -1074395957 // The array sizes are not compatible. | |
#define ERR_INVALID_QUALITY -1074395956 // The quality you provided is invalid. Valid quality values range from -1 to 1000. | |
#define ERR_INVALID_MAX_WAVELET_TRANSFORM_LEVEL -1074395955 // Invalid maximum wavelet transform level. Valid values range from 0 to 255. | |
#define ERR_INVALID_QUANTIZATION_STEP_SIZE -1074395954 // The quantization step size must be greater than or equal to 0. | |
#define ERR_INVALID_WAVELET_TRANSFORM_MODE -1074395953 // Invalid wavelet transform mode. | |
#define ERR_ROI_NOT_POINT -1074395952 // The ROI must only have a single Point contour. | |
#define ERR_ROI_NOT_POINTS -1074395951 // The ROI must only have Point contours. | |
#define ERR_ROI_NOT_LINE -1074395950 // The ROI must only have a single Line contour. | |
#define ERR_ROI_NOT_ANNULUS -1074395949 // The ROI must only have a single Annulus contour. | |
#define ERR_INVALID_MEASURE_PARTICLES_CALIBRATION_MODE -1074395948 // Invalid measure particles calibration mode. | |
#define ERR_INVALID_PARTICLE_CLASSIFIER_THRESHOLD_TYPE -1074395947 // Invalid particle classifier threshold type. | |
#define ERR_INVALID_DISTANCE -1074395946 // Invalid Color Segmentation Distance | |
#define ERR_INVALID_PARTICLE_AREA -1074395945 // Invalid Color Segmenation Particle Area | |
#define ERR_CLASS_NAME_NOT_FOUND -1074395944 // Required Class name is not found in trained labels/Class names | |
#define ERR_NUMBER_LABEL_LIMIT_EXCEEDED -1074395943 // Number of Labels exceeded limit of label Image type | |
#define ERR_INVALID_DISTANCE_LEVEL -1074395942 // Invalid Color Segmentation distance level | |
#define ERR_INVALID_SVM_TYPE -1074395941 // Invalid SVM model type | |
#define ERR_INVALID_SVM_KERNEL -1074395940 // Invalid SVM kernel type | |
#define ERR_NO_SUPPORT_VECTOR_FOUND -1074395939 // No Support Vector is found at SVM training | |
#define ERR_COST_LABEL_NOT_FOUND -1074395938 // Label name is not found in added samples | |
#define ERR_EXCEEDED_SVM_MAX_ITERATION -1074395937 // SVM training exceeded maximim Iteration limit | |
#define ERR_INVALID_SVM_PARAMETER -1074395936 // Invalid SVM Parameter | |
#define ERR_INVALID_IDENTIFICATION_SCORE -1074395935 // Invalid Identification score. Must be between 0-1000. | |
#define ERR_INVALID_TEXTURE_FEATURE -1074395934 // Requested for invalid texture feature | |
#define ERR_INVALID_COOCCURRENCE_LEVEL -1074395933 // The coOccurrence Level must lie between 1 and the maximum pixel value of an image (255 for U8 image) | |
#define ERR_INVALID_WAVELET_SUBBAND -1074395932 // Request for invalid wavelet subBand | |
#define ERR_INVALID_FINAL_STEP_SIZE -1074395931 // The final step size must be lesser than the initial step size | |
#define ERR_INVALID_ENERGY -1074395930 // Minimum Energy should lie between 0 and 100 | |
#define ERR_INVALID_TEXTURE_LABEL -1074395929 // The classification label must be texture or defect for texture defect classifier | |
#define ERR_INVALID_WAVELET_TYPE -1074395928 // The wavelet type is invalid | |
#define ERR_SAME_WAVELET_BANDS_SELECTED -1074395927 // Same Wavelet band is selected multiple times | |
#define ERR_IMAGE_SIZE_MISMATCH -1074395926 // The two input image sizes are different | |
#define ERR_NUMBER_CLASS -1074395920 // Invalid number of classes. | |
#define ERR_INVALID_LUCAS_KANADE_WINDOW_SIZE -1074395888 // Both dimensions of the window size should be odd, greater than 2 and less than 16. | |
#define ERR_INVALID_MATRIX_TYPE -1074395887 // The type of matrix supplied to the function is not supported. | |
#define ERR_INVALID_OPTICAL_FLOW_TERMINATION_CRITERIA_TYPE -1074395886 // An invalid termination criteria was specified for the optical flow computation. | |
#define ERR_LKP_NULL_PYRAMID -1074395885 // The pyramid levels where not properly allocated. | |
#define ERR_INVALID_PYRAMID_LEVEL -1074395884 // The pyramid level specified cannot be negative | |
#define ERR_INVALID_LKP_KERNEL -1074395883 // The kernel must be symmetric with non-zero coefficients and of odd size | |
#define ERR_INVALID_HORN_SCHUNCK_LAMBDA -1074395882 // Invalid smoothing parameter in Horn Schunck operation. | |
#define ERR_INVALID_HORN_SCHUNCK_TYPE -1074395881 // Invalid stopping criteria type for Horn Schunck optical flow. | |
#define ERR_PARTICLE -1074395880 // Invalid particle. | |
#define ERR_BAD_MEASURE -1074395879 // Invalid measure number. | |
#define ERR_PROP_NODE_WRITE_NOT_SUPPORTED -1074395878 // The Image Display control does not support writing this property node. | |
#define ERR_COLORMODE_REQUIRES_CHANGECOLORSPACE2 -1074395877 // The specified color mode requires the use of imaqChangeColorSpace2. | |
#define ERR_UNSUPPORTED_COLOR_MODE -1074395876 // This function does not currently support the color mode you specified. | |
#define ERR_BARCODE_PHARMACODE -1074395875 // The barcode is not a valid Pharmacode symbol | |
#define ERR_BAD_INDEX -1074395840 // Invalid handle table index. | |
#define ERR_INVALID_COMPRESSION_RATIO -1074395837 // The compression ratio must be greater than or equal to 1. | |
#define ERR_TOO_MANY_CONTOURS -1074395801 // The ROI contains too many contours. | |
#define ERR_PROTECTION -1074395800 // Protection error. | |
#define ERR_INTERNAL -1074395799 // Internal error. | |
#define ERR_INVALID_CUSTOM_SAMPLE -1074395798 // The size of the feature vector in the custom sample must match the size of those you have already added. | |
#define ERR_INVALID_CLASSIFIER_SESSION -1074395797 // Not a valid classifier session. | |
#define ERR_INVALID_KNN_METHOD -1074395796 // You requested an invalid Nearest Neighbor classifier method. | |
#define ERR_K_TOO_LOW -1074395795 // The k parameter must be greater than two. | |
#define ERR_K_TOO_HIGH -1074395794 // The k parameter must be <= the number of samples in each class. | |
#define ERR_INVALID_OPERATION_ON_COMPACT_SESSION_ATTEMPTED -1074395793 // This classifier session is compact. Only the Classify and Dispose functions may be called on a compact classifier session. | |
#define ERR_CLASSIFIER_SESSION_NOT_TRAINED -1074395792 // This classifier session is not trained. You may only call this function on a trained classifier session. | |
#define ERR_CLASSIFIER_INVALID_SESSION_TYPE -1074395791 // This classifier function cannot be called on this type of classifier session. | |
#define ERR_INVALID_DISTANCE_METRIC -1074395790 // You requested an invalid distance metric. | |
#define ERR_OPENING_NEWER_CLASSIFIER_SESSION -1074395789 // The classifier session you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_NO_SAMPLES -1074395788 // This operation cannot be performed because you have not added any samples. | |
#define ERR_INVALID_CLASSIFIER_TYPE -1074395787 // You requested an invalid classifier type. | |
#define ERR_INVALID_PARTICLE_OPTIONS -1074395786 // The sum of Scale Dependence and Symmetry Dependence must be less than 1000. | |
#define ERR_NO_PARTICLE -1074395785 // The image yielded no particles. | |
#define ERR_INVALID_LIMITS -1074395784 // The limits you supplied are not valid. | |
#define ERR_BAD_SAMPLE_INDEX -1074395783 // The Sample Index fell outside the range of Samples. | |
#define ERR_DESCRIPTION_TOO_LONG -1074395782 // The description must be <= 255 characters. | |
#define ERR_CLASSIFIER_INVALID_ENGINE_TYPE -1074395781 // The engine for this classifier session does not support this operation. | |
#define ERR_INVALID_PARTICLE_TYPE -1074395780 // You requested an invalid particle type. | |
#define ERR_CANNOT_COMPACT_UNTRAINED -1074395779 // You may only save a session in compact form if it is trained. | |
#define ERR_INVALID_KERNEL_SIZE -1074395778 // The Kernel size must be smaller than the image size. | |
#define ERR_INCOMPATIBLE_CLASSIFIER_TYPES -1074395777 // The session you read from file must be the same type as the session you passed in. | |
#define ERR_INVALID_USE_OF_COMPACT_SESSION_FILE -1074395776 // You can not use a compact classification file with read options other than Read All. | |
#define ERR_ROI_HAS_OPEN_CONTOURS -1074395775 // The ROI you passed in may only contain closed contours. | |
#define ERR_NO_LABEL -1074395774 // You must pass in a label. | |
#define ERR_NO_DEST_IMAGE -1074395773 // You must provide a destination image. | |
#define ERR_INVALID_REGISTRATION_METHOD -1074395772 // You provided an invalid registration method. | |
#define ERR_OPENING_NEWER_INSPECTION_TEMPLATE -1074395771 // The golden template you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_INVALID_INSPECTION_TEMPLATE -1074395770 // Invalid golden template. | |
#define ERR_INVALID_EDGE_THICKNESS -1074395769 // Edge Thickness to Ignore must be greater than zero. | |
#define ERR_INVALID_SCALE -1074395768 // Scale must be greater than zero. | |
#define ERR_INVALID_ALIGNMENT -1074395767 // The supplied scale is invalid for your template. | |
#define ERR_DEPRECATED_FUNCTION -1074395766 // This backwards-compatibility function can not be used with this session. Use newer, supported functions instead. | |
#define ERR_INVALID_NORMALIZATION_METHOD -1074395763 // You must provide a valid normalization method. | |
#define ERR_INVALID_NIBLACK_DEVIATION_FACTOR -1074395762 // The deviation factor for Niblack local threshold must be between 0 and 1. | |
#define ERR_BOARD_NOT_FOUND -1074395760 // Board not found. | |
#define ERR_BOARD_NOT_OPEN -1074395758 // Board not opened. | |
#define ERR_DLL_NOT_FOUND -1074395757 // DLL not found. | |
#define ERR_DLL_FUNCTION_NOT_FOUND -1074395756 // DLL function not found. | |
#define ERR_TRIG_TIMEOUT -1074395754 // Trigger timeout. | |
#define ERR_CONTOUR_INVALID_REFINEMENTS -1074395746 // Invalid number specified for maximum contour refinements. | |
#define ERR_TOO_MANY_CURVES -1074395745 // Too many curves extracted from image. Raise the edge threshold or reduce the ROI. | |
#define ERR_CONTOUR_INVALID_KERNEL_FOR_SMOOTHING -1074395744 // Invalid kernel for contour smoothing. Zero indicates no smoothing, otherwise value must be odd. | |
#define ERR_CONTOUR_LINE_INVALID -1074395743 // The contour line fit is invalid. Line segment start and stop must differ. | |
#define ERR_CONTOUR_TEMPLATE_IMAGE_INVALID -1074395742 // The template image must be trained with IMAQ Learn Contour Pattern or be the same size as the target image. | |
#define ERR_CONTOUR_GPM_FAIL -1074395741 // Matching failed to align the template and target contours. | |
#define ERR_CONTOUR_OPENING_NEWER_VERSION -1074395740 // The contour you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_CONTOUR_CONNECT_DUPLICATE -1074395739 // Only one range is allowed per curve connection constraint type. | |
#define ERR_CONTOUR_CONNECT_TYPE -1074395738 // Invalid contour connection constraint type. | |
#define ERR_CONTOUR_MATCH_STR_NOT_APPLICABLE -1074395737 // In order to use contour matching, you must provide a template image that has been trained with IMAQ Learn Contour Pattern | |
#define ERR_CONTOUR_CURVATURE_KERNEL -1074395736 // Invalid kernel width for curvature calculation. Must be an odd value greater than 1. | |
#define ERR_CONTOUR_EXTRACT_SELECTION -1074395735 // Invalid Contour Selection method for contour extraction. | |
#define ERR_CONTOUR_EXTRACT_DIRECTION -1074395734 // Invalid Search Direction for contour extraction. | |
#define ERR_CONTOUR_EXTRACT_ROI -1074395733 // Invalid ROI for contour extraction. The ROI must contain an annulus, rectangle or rotated rectangle. | |
#define ERR_CONTOUR_NO_CURVES -1074395732 // No curves were found in the image. | |
#define ERR_CONTOUR_COMPARE_KERNEL -1074395731 // Invalid Smoothing Kernel width for contour comparison. Must be zero or an odd positive integer. | |
#define ERR_CONTOUR_COMPARE_SINGLE_IMAGE -1074395730 // If no template image is provided, the target image must contain both a contour with extracted points and a fitted equation. | |
#define ERR_CONTOUR_INVALID -1074395729 // Invalid contour image. | |
#define ERR_INVALID_2D_BARCODE_SEARCH_MODE -1074395728 // NI Vision does not support the search mode you provided. | |
#define ERR_UNSUPPORTED_2D_BARCODE_SEARCH_MODE -1074395727 // NI Vision does not support the search mode you provided for the type of 2D barcode for which you are searching. | |
#define ERR_MATCHFACTOR_OBSOLETE -1074395726 // matchFactor has been obsoleted. Instead, set the initialMatchListLength and matchListReductionFactor in the MatchPatternAdvancedOptions structure. | |
#define ERR_DATA_VERSION -1074395725 // The data was stored with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this data. | |
#define ERR_CUSTOMDATA_INVALID_SIZE -1074395724 // The size you specified is out of the valid range. | |
#define ERR_CUSTOMDATA_KEY_NOT_FOUND -1074395723 // The key you specified cannot be found in the image. | |
#define ERR_CLASSIFIER_CLASSIFY_IMAGE_WITH_CUSTOM_SESSION -1074395722 // Custom classifier sessions only classify feature vectors. They do not support classifying images. | |
#define ERR_INVALID_BIT_DEPTH -1074395721 // NI Vision does not support the bit depth you supplied for the image you supplied. | |
#define ERR_BAD_ROI -1074395720 // Invalid ROI. | |
#define ERR_BAD_ROI_BOX -1074395719 // Invalid ROI global rectangle. | |
#define ERR_LAB_VERSION -1074395718 // The version of LabVIEW or BridgeVIEW you are running does not support this operation. | |
#define ERR_INVALID_RANGE -1074395717 // The range you supplied is invalid. | |
#define ERR_INVALID_SCALING_METHOD -1074395716 // NI Vision does not support the scaling method you provided. | |
#define ERR_INVALID_CALIBRATION_UNIT -1074395715 // NI Vision does not support the calibration unit you supplied. | |
#define ERR_INVALID_AXIS_ORIENTATION -1074395714 // NI Vision does not support the axis orientation you supplied. | |
#define ERR_VALUE_NOT_IN_ENUM -1074395713 // Value not in enumeration. | |
#define ERR_WRONG_REGION_TYPE -1074395712 // You selected a region that is not of the right type. | |
#define ERR_NOT_ENOUGH_REGIONS -1074395711 // You specified a viewer that does not contain enough regions. | |
#define ERR_TOO_MANY_PARTICLES -1074395710 // The image has too many particles for this process. | |
#define ERR_AVI_UNOPENED_SESSION -1074395709 // The AVI session has not been opened. | |
#define ERR_AVI_READ_SESSION_REQUIRED -1074395708 // The AVI session is a write session, but this operation requires a read session. | |
#define ERR_AVI_WRITE_SESSION_REQUIRED -1074395707 // The AVI session is a read session, but this operation requires a write session. | |
#define ERR_AVI_SESSION_ALREADY_OPEN -1074395706 // This AVI session is already open. You must close it before calling the Create or Open functions. | |
#define ERR_DATA_CORRUPTED -1074395705 // The data is corrupted and cannot be read. | |
#define ERR_INVALID_COMPRESSION_TYPE -1074395704 // Invalid compression type. | |
#define ERR_INVALID_TYPE_OF_FLATTEN -1074395703 // Invalid type of flatten. | |
#define ERR_INVALID_LENGTH -1074395702 // The length of the edge detection line must be greater than zero. | |
#define ERR_INVALID_MATRIX_SIZE_RANGE -1074395701 // The maximum Data Matrix barcode size must be equal to or greater than the minimum Data Matrix barcode size. | |
#define ERR_REQUIRES_WIN2000_OR_NEWER -1074395700 // The function requires the operating system to be Microsoft Windows 2000 or newer. | |
#define ERR_INVALID_CALIBRATION_METHOD -1074395662 // Invalid calibration method requested | |
#define ERR_INVALID_OPERATION_ON_COMPACT_CALIBRATION_ATTEMPTED -1074395661 // This calibration is compact. Re-Learning calibration and retrieving thumbnails are not possible with this calibration | |
#define ERR_INVALID_POLYNOMIAL_MODEL_K_COUNT -1074395660 // Invalid number of K values | |
#define ERR_INVALID_DISTORTION_MODEL -1074395659 // Invalid distortion model type | |
#define ERR_CAMERA_MODEL_NOT_AVAILABLE -1074395658 // Camera Model is not learned | |
#define ERR_INVALID_THUMBNAIL_INDEX -1074395657 // Supplied thumbnail index is invalid | |
#define ERR_SMOOTH_CONTOURS_MUST_BE_SAME -1074395656 // You must specify the same value for the smooth contours advanced match option for all templates you want to match. | |
#define ERR_ENABLE_CALIBRATION_SUPPORT_MUST_BE_SAME -1074395655 // You must specify the same value for the enable calibration support advanced match option for all templates you want to match. | |
#define ERR_GRADING_INFORMATION_NOT_FOUND -1074395654 // The source image does not contain grading information. You must prepare the source image for grading when reading the Data Matrix, and you cannot change the contents of the source image between reading and grading the Data Matrix. | |
#define ERR_OPENING_NEWER_MULTIPLE_GEOMETRIC_TEMPLATE -1074395653 // The multiple geometric matching template you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_OPENING_NEWER_GEOMETRIC_MATCHING_TEMPLATE -1074395652 // The geometric matching template you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_EDGE_FILTER_SIZE_MUST_BE_SAME -1074395651 // You must specify the same edge filter size for all the templates you want to match. | |
#define ERR_CURVE_EXTRACTION_MODE_MUST_BE_SAME -1074395650 // You must specify the same curve extraction mode for all the templates you want to match. | |
#define ERR_INVALID_GEOMETRIC_FEATURE_TYPE -1074395649 // The geometric feature type specified is invalid. | |
#define ERR_TEMPLATE_NOT_LEARNED -1074395648 // You supplied a template that was not learned. | |
#define ERR_INVALID_MULTIPLE_GEOMETRIC_TEMPLATE -1074395647 // Invalid multiple geometric template. | |
#define ERR_NO_TEMPLATE_TO_LEARN -1074395646 // Need at least one template to learn. | |
#define ERR_INVALID_NUMBER_OF_LABELS -1074395645 // You supplied an invalid number of labels. | |
#define ERR_LABEL_TOO_LONG -1074395644 // Labels must be <= 255 characters. | |
#define ERR_INVALID_NUMBER_OF_MATCH_OPTIONS -1074395643 // You supplied an invalid number of match options. | |
#define ERR_LABEL_NOT_FOUND -1074395642 // Cannot find a label that matches the one you specified. | |
#define ERR_DUPLICATE_LABEL -1074395641 // Duplicate labels are not allowed. | |
#define ERR_TOO_MANY_ZONES -1074395640 // The number of zones found exceeded the capacity of the algorithm. | |
#define ERR_INVALID_HATCH_STYLE -1074395639 // The hatch style for the window background is invalid. | |
#define ERR_INVALID_FILL_STYLE -1074395638 // The fill style for the window background is invalid. | |
#define ERR_HARDWARE_DOESNT_SUPPORT_NONTEARING -1074395637 // Your hardware is not supported by DirectX and cannot be put into NonTearing mode. | |
#define ERR_DIRECTX_NOT_FOUND -1074395636 // DirectX is required for this feature. Please install the latest version.. | |
#define ERR_INVALID_SHAPE_DESCRIPTOR -1074395635 // The passed shape descriptor is invalid. | |
#define ERR_INVALID_MAX_MATCH_OVERLAP -1074395634 // Invalid max match overlap. Values must be between -1 and 100. | |
#define ERR_INVALID_MIN_MATCH_SEPARATION_SCALE -1074395633 // Invalid minimum match separation scale. Values must be greater than or equal to -1. | |
#define ERR_INVALID_MIN_MATCH_SEPARATION_ANGLE -1074395632 // Invalid minimum match separation angle. Values must be between -1 and 360. | |
#define ERR_INVALID_MIN_MATCH_SEPARATION_DISTANCE -1074395631 // Invalid minimum match separation distance. Values must be greater than or equal to -1. | |
#define ERR_INVALID_MAXIMUM_FEATURES_LEARNED -1074395630 // Invalid maximum number of features learn. Values must be integers greater than zero. | |
#define ERR_INVALID_MAXIMUM_PIXEL_DISTANCE_FROM_LINE -1074395629 // Invalid maximum pixel distance from line. Values must be positive real numbers. | |
#define ERR_INVALID_GEOMETRIC_MATCHING_TEMPLATE -1074395628 // Invalid geometric matching template image. | |
#define ERR_NOT_ENOUGH_TEMPLATE_FEATURES_1 -1074395627 // The template does not contain enough features for geometric matching. | |
#define ERR_NOT_ENOUGH_TEMPLATE_FEATURES -1074395626 // The template does not contain enough features for geometric matching. | |
#define ERR_INVALID_MATCH_CONSTRAINT_TYPE -1074395625 // You specified an invalid value for the match constraint value of the range settings. | |
#define ERR_INVALID_OCCLUSION_RANGE -1074395624 // Invalid occlusion range. Valid values for the bounds range from 0 to 100 and the upper bound must be greater than or equal to the lower bound. | |
#define ERR_INVALID_SCALE_RANGE -1074395623 // Invalid scale range. Values for the lower bound must be a positive real numbers and the upper bound must be greater than or equal to the lower bound. | |
#define ERR_INVALID_MATCH_GEOMETRIC_PATTERN_SETUP_DATA -1074395622 // Invalid match geometric pattern setup data. | |
#define ERR_INVALID_LEARN_GEOMETRIC_PATTERN_SETUP_DATA -1074395621 // Invalid learn geometric pattern setup data. | |
#define ERR_INVALID_CURVE_EXTRACTION_MODE -1074395620 // Invalid curve extraction mode. | |
#define ERR_TOO_MANY_OCCLUSION_RANGES -1074395619 // You can specify only one occlusion range. | |
#define ERR_TOO_MANY_SCALE_RANGES -1074395618 // You can specify only one scale range. | |
#define ERR_INVALID_NUMBER_OF_FEATURES_RANGE -1074395617 // The minimum number of features must be less than or equal to the maximum number of features. | |
#define ERR_INVALID_EDGE_FILTER_SIZE -1074395616 // Invalid edge filter size. | |
#define ERR_INVALID_MINIMUM_FEATURE_STRENGTH -1074395615 // Invalid minimum strength for features. Values must be positive real numbers. | |
#define ERR_INVALID_MINIMUM_FEATURE_ASPECT_RATIO -1074395614 // Invalid aspect ratio for rectangular features. Values must be positive real numbers in the range 0.01 to 1.0. | |
#define ERR_INVALID_MINIMUM_FEATURE_LENGTH -1074395613 // Invalid minimum length for linear features. Values must be integers greater than 0. | |
#define ERR_INVALID_MINIMUM_FEATURE_RADIUS -1074395612 // Invalid minimum radius for circular features. Values must be integers greater than 0. | |
#define ERR_INVALID_MINIMUM_RECTANGLE_DIMENSION -1074395611 // Invalid minimum rectangle dimension. Values must be integers greater than 0. | |
#define ERR_INVALID_INITIAL_MATCH_LIST_LENGTH -1074395610 // Invalid initial match list length. Values must be integers greater than 5. | |
#define ERR_INVALID_SUBPIXEL_TOLERANCE -1074395609 // Invalid subpixel tolerance. Values must be positive real numbers. | |
#define ERR_INVALID_SUBPIXEL_ITERATIONS -1074395608 // Invalid number of subpixel iterations. Values must be integers greater 10. | |
#define ERR_INVALID_MAXIMUM_FEATURES_PER_MATCH -1074395607 // Invalid maximum number of features used per match. Values must be integers greater than or equal to zero. | |
#define ERR_INVALID_MINIMUM_FEATURES_TO_MATCH -1074395606 // Invalid minimum number of features used for matching. Values must be integers greater than zero. | |
#define ERR_INVALID_MAXIMUM_END_POINT_GAP -1074395605 // Invalid maximum end point gap. Valid values range from 0 to 32767. | |
#define ERR_INVALID_COLUMN_STEP -1074395604 // Invalid column step. Valid range is 1 to 255. | |
#define ERR_INVALID_ROW_STEP -1074395603 // Invalid row step. Valid range is 1 to 255. | |
#define ERR_INVALID_MINIMUM_CURVE_LENGTH -1074395602 // Invalid minimum length. Valid values must be greater than or equal to zero. | |
#define ERR_INVALID_EDGE_THRESHOLD -1074395601 // Invalid edge threshold. Valid values range from 1 to 360. | |
#define ERR_INFO_NOT_FOUND -1074395600 // You must provide information about the subimage within the browser. | |
#define ERR_NIOCR_INVALID_ACCEPTANCE_LEVEL -1074395598 // The acceptance level is outside the valid range of 0 to 1000. | |
#define ERR_NIOCR_NOT_A_VALID_SESSION -1074395597 // Not a valid OCR session. | |
#define ERR_NIOCR_INVALID_CHARACTER_SIZE -1074395596 // Invalid character size. Character size must be >= 1. | |
#define ERR_NIOCR_INVALID_THRESHOLD_MODE -1074395595 // Invalid threshold mode value. | |
#define ERR_NIOCR_INVALID_SUBSTITUTION_CHARACTER -1074395594 // Invalid substitution character. Valid substitution characters are ASCII values that range from 1 to 254. | |
#define ERR_NIOCR_INVALID_NUMBER_OF_BLOCKS -1074395593 // Invalid number of blocks. Number of blocks must be >= 4 and <= 50. | |
#define ERR_NIOCR_INVALID_READ_STRATEGY -1074395592 // Invalid read strategy. | |
#define ERR_NIOCR_INVALID_CHARACTER_INDEX -1074395591 // Invalid character index. | |
#define ERR_NIOCR_INVALID_NUMBER_OF_VALID_CHARACTER_POSITIONS -1074395590 // Invalid number of character positions. Valid values range from 0 to 255. | |
#define ERR_NIOCR_INVALID_LOW_THRESHOLD_VALUE -1074395589 // Invalid low threshold value. Valid threshold values range from 0 to 255. | |
#define ERR_NIOCR_INVALID_HIGH_THRESHOLD_VALUE -1074395588 // Invalid high threshold value. Valid threshold values range from 0 to 255. | |
#define ERR_NIOCR_INVALID_THRESHOLD_RANGE -1074395587 // The low threshold must be less than the high threshold. | |
#define ERR_NIOCR_INVALID_LOWER_THRESHOLD_LIMIT -1074395586 // Invalid lower threshold limit. Valid lower threshold limits range from 0 to 255. | |
#define ERR_NIOCR_INVALID_UPPER_THRESHOLD_LIMIT -1074395585 // Invalid upper threshold limit. Valid upper threshold limits range from 0 to 255. | |
#define ERR_NIOCR_INVALID_THRESHOLD_LIMITS -1074395584 // The lower threshold limit must be less than the upper threshold limit. | |
#define ERR_NIOCR_INVALID_MIN_CHAR_SPACING -1074395583 // Invalid minimum character spacing value. Character spacing must be >= 1 pixel. | |
#define ERR_NIOCR_INVALID_MAX_HORIZ_ELEMENT_SPACING -1074395582 // Invalid maximum horizontal element spacing value. Maximum horizontal element spacing must be >= 0. | |
#define ERR_NIOCR_INVALID_MAX_VERT_ELEMENT_SPACING -1074395581 // Invalid maximum vertical element spacing value. Maximum vertical element spacing must be >= 0. | |
#define ERR_NIOCR_INVALID_MIN_BOUNDING_RECT_WIDTH -1074395580 // Invalid minimum bounding rectangle width. Minimum bounding rectangle width must be >= 1. | |
#define ERR_NIOCR_INVALID_ASPECT_RATIO -1074395579 // Invalid aspect ratio value. The aspect ratio must be zero or >= 100. | |
#define ERR_NIOCR_INVALID_CHARACTER_SET_FILE -1074395578 // Invalid or corrupt character set file. | |
#define ERR_NIOCR_CHARACTER_VALUE_CANNOT_BE_EMPTYSTRING -1074395577 // The character value must not be an empty string. | |
#define ERR_NIOCR_CHARACTER_VALUE_TOO_LONG -1074395576 // Character values must be <=255 characters. | |
#define ERR_NIOCR_INVALID_NUMBER_OF_EROSIONS -1074395575 // Invalid number of erosions. The number of erosions must be >= 0. | |
#define ERR_NIOCR_CHARACTER_SET_DESCRIPTION_TOO_LONG -1074395574 // The character set description must be <=255 characters. | |
#define ERR_NIOCR_INVALID_CHARACTER_SET_FILE_VERSION -1074395573 // The character set file was created by a newer version of NI Vision. Upgrade to the latest version of NI Vision to read the character set file. | |
#define ERR_NIOCR_INTEGER_VALUE_FOR_STRING_ATTRIBUTE -1074395572 // You must specify characters for a string. A string cannot contain integers. | |
#define ERR_NIOCR_GET_ONLY_ATTRIBUTE -1074395571 // This attribute is read-only. | |
#define ERR_NIOCR_INTEGER_VALUE_FOR_BOOLEAN_ATTRIBUTE -1074395570 // This attribute requires a Boolean value. | |
#define ERR_NIOCR_INVALID_ATTRIBUTE -1074395569 // Invalid attribute. | |
#define ERR_NIOCR_STRING_VALUE_FOR_INTEGER_ATTRIBUTE -1074395568 // This attribute requires integer values. | |
#define ERR_NIOCR_STRING_VALUE_FOR_BOOLEAN_ATTRIBUTE -1074395567 // String values are invalid for this attribute. Enter a boolean value. | |
#define ERR_NIOCR_BOOLEAN_VALUE_FOR_INTEGER_ATTRIBUTE -1074395566 // Boolean values are not valid for this attribute. Enter an integer value. | |
#define ERR_NIOCR_MUST_BE_SINGLE_CHARACTER -1074395565 // Requires a single-character string. | |
#define ERR_NIOCR_INVALID_PREDEFINED_CHARACTER -1074395564 // Invalid predefined character value. | |
#define ERR_NIOCR_UNLICENSED -1074395563 // This copy of NI OCR is unlicensed. | |
#define ERR_NIOCR_BOOLEAN_VALUE_FOR_STRING_ATTRIBUTE -1074395562 // String values are not valid for this attribute. Enter a Boolean value. | |
#define ERR_NIOCR_INVALID_NUMBER_OF_CHARACTERS -1074395561 // The number of characters in the character value must match the number of objects in the image. | |
#define ERR_NIOCR_INVALID_OBJECT_INDEX -1074395560 // Invalid object index. | |
#define ERR_NIOCR_INVALID_READ_OPTION -1074395559 // Invalid read option. | |
#define ERR_NIOCR_INVALID_CHARACTER_SIZE_RANGE -1074395558 // The minimum character size must be less than the maximum character size. | |
#define ERR_NIOCR_INVALID_BOUNDING_RECT_WIDTH_RANGE -1074395557 // The minimum character bounding rectangle width must be less than the maximum character bounding rectangle width. | |
#define ERR_NIOCR_INVALID_BOUNDING_RECT_HEIGHT_RANGE -1074395556 // The minimum character bounding rectangle height must be less than the maximum character bounding rectangle height. | |
#define ERR_NIOCR_INVALID_SPACING_RANGE -1074395555 // The maximum horizontal element spacing value must not exceed the minimum character spacing value. | |
#define ERR_NIOCR_INVALID_READ_RESOLUTION -1074395554 // Invalid read resolution. | |
#define ERR_NIOCR_INVALID_MIN_BOUNDING_RECT_HEIGHT -1074395553 // Invalid minimum bounding rectangle height. The minimum bounding rectangle height must be >= 1. | |
#define ERR_NIOCR_NOT_A_VALID_CHARACTER_SET -1074395552 // Not a valid character set. | |
#define ERR_NIOCR_RENAME_REFCHAR -1074395551 // A trained OCR character cannot be renamed while it is a reference character. | |
#define ERR_NIOCR_INVALID_CHARACTER_VALUE -1074395550 // A character cannot have an ASCII value of 255. | |
#define ERR_NIOCR_INVALID_NUMBER_OF_OBJECTS_TO_VERIFY -1074395549 // The number of objects found does not match the number of expected characters or patterns to verify. | |
#define ERR_INVALID_STEREO_BLOCKMATCHING_PREFILTER_CAP -1074395421 // The specified value for the filter cap for block matching is invalid. | |
#define ERR_INVALID_STEREO_BLOCKMATCHING_PREFILTER_SIZE -1074395420 // The specified prefilter size for block matching is invalid. | |
#define ERR_INVALID_STEREO_BLOCKMATCHING_PREFILTER_TYPE -1074395419 // The specified prefilter type for block matching is invalid. | |
#define ERR_INVALID_STEREO_BLOCKMATCHING_NUMDISPARITIES -1074395418 // The specifed value for number of disparities is invalid. | |
#define ERR_INVALID_STEREO_BLOCKMATCHING_WINDOW_SIZE -1074395417 // The specified window size for block matching is invalid. | |
#define ERR_3DVISION_INVALID_SESSION_TYPE -1074395416 // This 3D vision function cannot be called on this type of 3d vision session. | |
#define ERR_TOO_MANY_3DVISION_SESSIONS -1074395415 // There are too many 3D vision sessions open. You must close a session before you can open another one. | |
#define ERR_OPENING_NEWER_3DVISION_SESSION -1074395414 // The 3D vision session you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_INVALID_STEREO_BLOCKMATCHING_FILTERTYPE -1074395413 // You have specified an invalid filter type for block matching. | |
#define ERR_INVALID_STEREO_CAMERA_POSITION -1074395412 // You have requested results at an invalid camera position in the stereo setup. | |
#define ERR_INVALID_3DVISION_SESSION -1074395411 // Not a valid 3D Vision session. | |
#define ERR_INVALID_ICONS_PER_LINE -1074395410 // NI Vision does not support less than one icon per line. | |
#define ERR_INVALID_SUBPIXEL_DIVISIONS -1074395409 // Invalid subpixel divisions. | |
#define ERR_INVALID_DETECTION_MODE -1074395408 // Invalid detection mode. | |
#define ERR_INVALID_CONTRAST -1074395407 // Invalid contrast value. Valid contrast values range from 0 to 255. | |
#define ERR_COORDSYS_NOT_FOUND -1074395406 // The coordinate system could not be found on this image. | |
#define ERR_INVALID_TEXTORIENTATION -1074395405 // NI Vision does not support the text orientation value you supplied. | |
#define ERR_INVALID_INTERPOLATIONMETHOD_FOR_UNWRAP -1074395404 // UnwrapImage does not support the interpolation method value you supplied. Valid interpolation methods are zero order and bilinear. | |
#define ERR_EXTRAINFO_VERSION -1074395403 // The image was created in a newer version of NI Vision. Upgrade to the latest version of NI Vision to use this image. | |
#define ERR_INVALID_MAXPOINTS -1074395402 // The function does not support the maximum number of points that you specified. | |
#define ERR_INVALID_MATCHFACTOR -1074395401 // The function does not support the matchFactor that you specified. | |
#define ERR_MULTICORE_OPERATION -1074395400 // The operation you have given Multicore Options is invalid. Please see the available enumeration values for Multicore Operation. | |
#define ERR_MULTICORE_INVALID_ARGUMENT -1074395399 // You have given Multicore Options an invalid argument. | |
#define ERR_COMPLEX_IMAGE_REQUIRED -1074395397 // A complex image is required. | |
#define ERR_COLOR_IMAGE_REQUIRED -1074395395 // The input image must be a color image. | |
#define ERR_COLOR_SPECTRUM_MASK -1074395394 // The color mask removes too much color information. | |
#define ERR_COLOR_TEMPLATE_IMAGE_TOO_SMALL -1074395393 // The color template image is too small. | |
#define ERR_COLOR_TEMPLATE_IMAGE_TOO_LARGE -1074395392 // The color template image is too large. | |
#define ERR_COLOR_TEMPLATE_IMAGE_HUE_CONTRAST_TOO_LOW -1074395391 // The contrast in the hue plane of the image is too low for learning shape features. | |
#define ERR_COLOR_TEMPLATE_IMAGE_LUMINANCE_CONTRAST_TOO_LOW -1074395390 // The contrast in the luminance plane of the image is too low to learn shape features. | |
#define ERR_COLOR_LEARN_SETUP_DATA -1074395389 // Invalid color learn setup data. | |
#define ERR_COLOR_LEARN_SETUP_DATA_SHAPE -1074395388 // Invalid color learn setup data. | |
#define ERR_COLOR_MATCH_SETUP_DATA -1074395387 // Invalid color match setup data. | |
#define ERR_COLOR_MATCH_SETUP_DATA_SHAPE -1074395386 // Invalid color match setup data. | |
#define ERR_COLOR_ROTATION_REQUIRES_SHAPE_FEATURE -1074395385 // Rotation-invariant color pattern matching requires a feature mode including shape. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR -1074395384 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_1 -1074395383 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_2 -1074395382 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_3 -1074395381 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_4 -1074395380 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_5 -1074395379 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_6 -1074395378 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_SHIFT -1074395377 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_NOSHIFT -1074395376 // The color template image does not contain data required for shift-invariant color matching. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_SHIFT_1 -1074395375 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_SHIFT_2 -1074395374 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_ROTATION -1074395373 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_NOROTATION -1074395372 // The color template image does not contain data required for rotation-invariant color matching. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_ROTATION_1 -1074395371 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_ROTATION_2 -1074395370 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_ROTATION_3 -1074395369 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_ROTATION_4 -1074395368 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_ROTATION_5 -1074395367 // Invalid color template image. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_NOSHAPE -1074395366 // The color template image does not contain data required for color matching in shape feature mode. | |
#define ERR_COLOR_TEMPLATE_DESCRIPTOR_NOSPECTRUM -1074395365 // The color template image does not contain data required for color matching in color feature mode. | |
#define ERR_IGNORE_COLOR_SPECTRUM_SET -1074395364 // The ignore color spectra array is invalid. | |
#define ERR_INVALID_SUBSAMPLING_RATIO -1074395363 // Invalid subsampling ratio. | |
#define ERR_INVALID_WIDTH -1074395362 // Invalid pixel width. | |
#define ERR_INVALID_STEEPNESS -1074395361 // Invalid steepness. | |
#define ERR_COMPLEX_PLANE -1074395360 // Invalid complex plane. | |
#define ERR_INVALID_COLOR_IGNORE_MODE -1074395357 // Invalid color ignore mode. | |
#define ERR_INVALID_MIN_MATCH_SCORE -1074395356 // Invalid minimum match score. Acceptable values range from 0 to 1000. | |
#define ERR_INVALID_NUM_MATCHES_REQUESTED -1074395355 // Invalid number of matches requested. You must request a minimum of one match. | |
#define ERR_INVALID_COLOR_WEIGHT -1074395354 // Invalid color weight. Acceptable values range from 0 to 1000. | |
#define ERR_INVALID_SEARCH_STRATEGY -1074395353 // Invalid search strategy. | |
#define ERR_INVALID_FEATURE_MODE -1074395352 // Invalid feature mode. | |
#define ERR_INVALID_RECT -1074395351 // NI Vision does not support rectangles with negative widths or negative heights. | |
#define ERR_INVALID_VISION_INFO -1074395350 // NI Vision does not support the vision information type you supplied. | |
#define ERR_INVALID_SKELETONMETHOD -1074395349 // NI Vision does not support the SkeletonMethod value you supplied. | |
#define ERR_INVALID_3DPLANE -1074395348 // NI Vision does not support the 3DPlane value you supplied. | |
#define ERR_INVALID_3DDIRECTION -1074395347 // NI Vision does not support the 3DDirection value you supplied. | |
#define ERR_INVALID_INTERPOLATIONMETHOD_FOR_ROTATE -1074395346 // imaqRotate does not support the InterpolationMethod value you supplied. | |
#define ERR_INVALID_FLIPAXIS -1074395345 // NI Vision does not support the axis of symmetry you supplied. | |
#define ERR_FILE_FILENAME_NULL -1074395343 // You must pass a valid file name. Do not pass in NULL. | |
#define ERR_INVALID_SIZETYPE -1074395340 // NI Vision does not support the SizeType value you supplied. | |
#define ERR_UNKNOWN_ALGORITHM -1074395336 // You specified the dispatch status of an unknown algorithm. | |
#define ERR_DISPATCH_STATUS_CONFLICT -1074395335 // You are attempting to set the same algorithm to dispatch and to not dispatch. Remove one of the conflicting settings. | |
#define ERR_INVALID_CONVERSIONSTYLE -1074395334 // NI Vision does not support the Conversion Method value you supplied. | |
#define ERR_INVALID_VERTICAL_TEXT_ALIGNMENT -1074395333 // NI Vision does not support the VerticalTextAlignment value you supplied. | |
#define ERR_INVALID_COMPAREFUNCTION -1074395332 // NI Vision does not support the CompareFunction value you supplied. | |
#define ERR_INVALID_BORDERMETHOD -1074395331 // NI Vision does not support the BorderMethod value you supplied. | |
#define ERR_INVALID_BORDER_SIZE -1074395330 // Invalid border size. Acceptable values range from 0 to 50. | |
#define ERR_INVALID_OUTLINEMETHOD -1074395329 // NI Vision does not support the OutlineMethod value you supplied. | |
#define ERR_INVALID_INTERPOLATIONMETHOD -1074395328 // NI Vision does not support the InterpolationMethod value you supplied. | |
#define ERR_INVALID_SCALINGMODE -1074395327 // NI Vision does not support the ScalingMode value you supplied. | |
#define ERR_INVALID_DRAWMODE_FOR_LINE -1074395326 // imaqDrawLineOnImage does not support the DrawMode value you supplied. | |
#define ERR_INVALID_DRAWMODE -1074395325 // NI Vision does not support the DrawMode value you supplied. | |
#define ERR_INVALID_SHAPEMODE -1074395324 // NI Vision does not support the ShapeMode value you supplied. | |
#define ERR_INVALID_FONTCOLOR -1074395323 // NI Vision does not support the FontColor value you supplied. | |
#define ERR_INVALID_TEXTALIGNMENT -1074395322 // NI Vision does not support the TextAlignment value you supplied. | |
#define ERR_INVALID_MORPHOLOGYMETHOD -1074395321 // NI Vision does not support the MorphologyMethod value you supplied. | |
#define ERR_TEMPLATE_EMPTY -1074395320 // The template image is empty. | |
#define ERR_INVALID_SUBPIX_TYPE -1074395319 // NI Vision does not support the interpolation type you supplied. | |
#define ERR_INSF_POINTS -1074395318 // You supplied an insufficient number of points to perform this operation. | |
#define ERR_UNDEF_POINT -1074395317 // You specified a point that lies outside the image. | |
#define ERR_INVALID_KERNEL_CODE -1074395316 // Invalid kernel code. | |
#define ERR_INEFFICIENT_POINTS -1074395315 // You supplied an inefficient set of points to match the minimum score. | |
#define ERR_WRITE_FILE_NOT_SUPPORTED -1074395313 // Writing files is not supported on this device. | |
#define ERR_LCD_CALIBRATE -1074395312 // The input image does not seem to be a valid LCD or LED calibration image. | |
#define ERR_INVALID_COLOR_SPECTRUM -1074395311 // The color spectrum array you provided has an invalid number of elements or contains an element set to not-a-number (NaN). | |
#define ERR_INVALID_PALETTE_TYPE -1074395310 // NI Vision does not support the PaletteType value you supplied. | |
#define ERR_INVALID_WINDOW_THREAD_POLICY -1074395309 // NI Vision does not support the WindowThreadPolicy value you supplied. | |
#define ERR_INVALID_COLORSENSITIVITY -1074395308 // NI Vision does not support the ColorSensitivity value you supplied. | |
#define ERR_PRECISION_NOT_GTR_THAN_0 -1074395307 // The precision parameter must be greater than 0. | |
#define ERR_INVALID_TOOL -1074395306 // NI Vision does not support the Tool value you supplied. | |
#define ERR_INVALID_REFERENCEMODE -1074395305 // NI Vision does not support the ReferenceMode value you supplied. | |
#define ERR_INVALID_MATHTRANSFORMMETHOD -1074395304 // NI Vision does not support the MathTransformMethod value you supplied. | |
#define ERR_INVALID_NUM_OF_CLASSES -1074395303 // Invalid number of classes for auto threshold. Acceptable values range from 2 to 256. | |
#define ERR_INVALID_THRESHOLDMETHOD -1074395302 // NI Vision does not support the threshold method value you supplied. | |
#define ERR_ROI_NOT_2_LINES -1074395301 // The ROI you passed into imaqGetMeterArc must consist of two lines. | |
#define ERR_INVALID_METERARCMODE -1074395300 // NI Vision does not support the MeterArcMode value you supplied. | |
#define ERR_INVALID_COMPLEXPLANE -1074395299 // NI Vision does not support the ComplexPlane value you supplied. | |
#define ERR_COMPLEXPLANE_NOT_REAL_OR_IMAGINARY -1074395298 // You can perform this operation on a real or an imaginary ComplexPlane only. | |
#define ERR_INVALID_PARTICLEINFOMODE -1074395297 // NI Vision does not support the ParticleInfoMode value you supplied. | |
#define ERR_INVALID_BARCODETYPE -1074395296 // NI Vision does not support the BarcodeType value you supplied. | |
#define ERR_INVALID_INTERPOLATIONMETHOD_INTERPOLATEPOINTS -1074395295 // imaqInterpolatePoints does not support the InterpolationMethod value you supplied. | |
#define ERR_CONTOUR_INDEX_OUT_OF_RANGE -1074395294 // The contour index you supplied is larger than the number of contours in the ROI. | |
#define ERR_CONTOURID_NOT_FOUND -1074395293 // The supplied ContourID did not correlate to a contour inside the ROI. | |
#define ERR_POINTS_ARE_COLLINEAR -1074395292 // Do not supply collinear points for this operation. | |
#define ERR_SHAPEMATCH_BADIMAGEDATA -1074395291 // Shape Match requires the image to contain only pixel values of 0 or 1. | |
#define ERR_SHAPEMATCH_BADTEMPLATE -1074395290 // The template you supplied for ShapeMatch contains no shape information. | |
#define ERR_CONTAINER_CAPACITY_EXCEEDED_UINT_MAX -1074395289 // The operation would have exceeded the capacity of an internal container, which is limited to 4294967296 unique elements. | |
#define ERR_CONTAINER_CAPACITY_EXCEEDED_INT_MAX -1074395288 // The operation would have exceeded the capacity of an internal container, which is limited to 2147483648 unique elements. | |
#define ERR_INVALID_LINE -1074395287 // The line you provided contains two identical points, or one of the coordinate locations for the line is not a number (NaN). | |
#define ERR_INVALID_CONCENTRIC_RAKE_DIRECTION -1074395286 // Invalid concentric rake direction. | |
#define ERR_INVALID_SPOKE_DIRECTION -1074395285 // Invalid spoke direction. | |
#define ERR_INVALID_EDGE_PROCESS -1074395284 // Invalid edge process. | |
#define ERR_INVALID_RAKE_DIRECTION -1074395283 // Invalid rake direction. | |
#define ERR_CANT_DRAW_INTO_VIEWER -1074395282 // Unable to draw to viewer. You must have the latest version of the control. | |
#define ERR_IMAGE_SMALLER_THAN_BORDER -1074395281 // Your image must be larger than its border size for this operation. | |
#define ERR_ROI_NOT_RECT -1074395280 // The ROI must only have a single Rectangle contour. | |
#define ERR_ROI_NOT_POLYGON -1074395279 // ROI is not a polygon. | |
#define ERR_LCD_NOT_NUMERIC -1074395278 // LCD image is not a number. | |
#define ERR_BARCODE_CHECKSUM -1074395277 // The decoded barcode information did not pass the checksum test. | |
#define ERR_LINES_PARALLEL -1074395276 // You specified parallel lines for the meter ROI. | |
#define ERR_INVALID_BROWSER_IMAGE -1074395275 // Invalid browser image. | |
#define ERR_DIV_BY_ZERO -1074395270 // Cannot divide by zero. | |
#define ERR_NULL_POINTER -1074395269 // Null pointer. | |
#define ERR_LINEAR_COEFF -1074395268 // The linear equations are not independent. | |
#define ERR_COMPLEX_ROOT -1074395267 // The roots of the equation are complex. | |
#define ERR_BARCODE -1074395265 // The barcode does not match the type you specified. | |
#define ERR_LCD_NO_SEGMENTS -1074395263 // No lit segment. | |
#define ERR_LCD_BAD_MATCH -1074395262 // The LCD does not form a known digit. | |
#define ERR_GIP_RANGE -1074395261 // An internal error occurred while attempting to access an invalid coordinate on an image. | |
#define ERR_HEAP_TRASHED -1074395260 // An internal memory error occurred. | |
#define ERR_BAD_FILTER_WIDTH -1074395258 // The filter width must be odd for the Canny operator. | |
#define ERR_INVALID_EDGE_DIR -1074395257 // You supplied an invalid edge direction in the Canny operator. | |
#define ERR_EVEN_WINDOW_SIZE -1074395256 // The window size must be odd for the Canny operator. | |
#define ERR_INVALID_LEARN_MODE -1074395253 // Invalid learn mode. | |
#define ERR_LEARN_SETUP_DATA -1074395252 // Invalid learn setup data. | |
#define ERR_INVALID_MATCH_MODE -1074395251 // Invalid match mode. | |
#define ERR_MATCH_SETUP_DATA -1074395250 // Invalid match setup data. | |
#define ERR_ROTATION_ANGLE_RANGE_TOO_LARGE -1074395249 // At least one range in the array of rotation angle ranges exceeds 360 degrees. | |
#define ERR_TOO_MANY_ROTATION_ANGLE_RANGES -1074395248 // The array of rotation angle ranges contains too many ranges. | |
#define ERR_TEMPLATE_DESCRIPTOR -1074395247 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_1 -1074395246 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_2 -1074395245 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_3 -1074395244 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_4 -1074395243 // The template descriptor was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to use this template. | |
#define ERR_TEMPLATE_DESCRIPTOR_ROTATION -1074395242 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_NOROTATION -1074395241 // The template descriptor does not contain data required for rotation-invariant matching. | |
#define ERR_TEMPLATE_DESCRIPTOR_ROTATION_1 -1074395240 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_SHIFT -1074395239 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_NOSHIFT -1074395238 // The template descriptor does not contain data required for shift-invariant matching. | |
#define ERR_TEMPLATE_DESCRIPTOR_SHIFT_1 -1074395237 // Invalid template descriptor. | |
#define ERR_TEMPLATE_DESCRIPTOR_NOSCALE -1074395236 // The template descriptor does not contain data required for scale-invariant matching. | |
#define ERR_TEMPLATE_IMAGE_CONTRAST_TOO_LOW -1074395235 // The template image does not contain enough contrast. | |
#define ERR_TEMPLATE_IMAGE_TOO_SMALL -1074395234 // The template image is too small. | |
#define ERR_TEMPLATE_IMAGE_TOO_LARGE -1074395233 // The template image is too large. | |
#define ERR_TOO_MANY_OCR_SESSIONS -1074395214 // There are too many OCR sessions open. You must close a session before you can open another one. | |
#define ERR_OCR_TEMPLATE_WRONG_SIZE -1074395212 // The size of the template string must match the size of the string you are trying to correct. | |
#define ERR_OCR_BAD_TEXT_TEMPLATE -1074395211 // The supplied text template contains nonstandard characters that cannot be generated by OCR. | |
#define ERR_OCR_CANNOT_MATCH_TEXT_TEMPLATE -1074395210 // At least one character in the text template was of a lexical class that did not match the supplied character reports. | |
#define ERR_OCR_LIB_INIT -1074395203 // The OCR library cannot be initialized correctly. | |
#define ERR_OCR_LOAD_LIBRARY -1074395201 // There was a failure when loading one of the internal OCR engine or LabView libraries. | |
#define ERR_OCR_INVALID_PARAMETER -1074395200 // One of the parameters supplied to the OCR function that generated this error is invalid. | |
#define ERR_MARKER_INFORMATION_NOT_SUPPLIED -1074395199 // Marker image and points are not supplied | |
#define ERR_INCOMPATIBLE_MARKER_IMAGE_SIZE -1074395198 // Source Image and Marker Image should be of same size. | |
#define ERR_BOTH_MARKER_INPUTS_SUPPLIED -1074395197 // Both Marker Image and Points are supplied. | |
#define ERR_INVALID_MORPHOLOGICAL_OPERATION -1074395196 // Invalid Morphological Operation. | |
#define ERR_IMAGE_CONTAINS_NAN_VALUES -1074395195 // Float image contains NaN values | |
#define ERR_OVERLAY_EXTRAINFO_OPENING_NEW_VERSION -1074395194 // The overlay information you tried to open was created with a newer version of NI Vision. Upgrade to the latest version of NI Vision to read this file. | |
#define ERR_NO_CLAMP_FOUND -1074395193 // No valid clamp was found with the current configuration | |
#define ERR_NO_CLAMP_WITHIN_ANGLE_RANGE -1074395192 // Supplied angle range for clamp is insufficient | |
#define ERR_GHT_INVALID_USE_ALL_CURVES_VALUE -1074395188 // The use all curves advanced option specified during learn is not supported | |
#define ERR_INVALID_GAUSS_SIGMA_VALUE -1074395187 // The sigma value specified for the Gaussian filter is too small. | |
#define ERR_INVALID_GAUSS_FILTER_TYPE -1074395186 // The specified Gaussian filter type is not supported. | |
#define ERR_INVALID_CONTRAST_REVERSAL_MODE -1074395185 // The contrast reversal mode specified during matching is invalid. | |
#define ERR_INVALID_ROTATION_RANGE -1074395184 // Invalid roation angle range. The upper bound must be greater than or equal to the lower bound. | |
#define ERR_GHT_INVALID_MINIMUM_LEARN_ANGLE_VALUE -1074395183 // The minimum rotation angle value specifed during learning of the template is not supported. | |
#define ERR_GHT_INVALID_MAXIMUM_LEARN_ANGLE_VALUE -1074395182 // The maximum rotation angle value specifed during learning of the template is not supported. | |
#define ERR_GHT_INVALID_MAXIMUM_LEARN_SCALE_FACTOR -1074395181 // The maximum scale factor specifed during learning of the template is not supported. | |
#define ERR_GHT_INVALID_MINIMUM_LEARN_SCALE_FACTOR -1074395180 // The minimum scale factor specifed during learning of the template is not supported. | |
#define ERR_OCR_PREPROCESSING_FAILED -1074395179 // The OCR engine failed during the preprocessing stage. | |
#define ERR_OCR_RECOGNITION_FAILED -1074395178 // The OCR engine failed during the recognition stage. | |
#define ERR_OCR_BAD_USER_DICTIONARY -1074395175 // The provided filename is not valid user dictionary filename. | |
#define ERR_OCR_INVALID_AUTOORIENTMODE -1074395174 // NI Vision does not support the AutoOrientMode value you supplied. | |
#define ERR_OCR_INVALID_LANGUAGE -1074395173 // NI Vision does not support the Language value you supplied. | |
#define ERR_OCR_INVALID_CHARACTERSET -1074395172 // NI Vision does not support the CharacterSet value you supplied. | |
#define ERR_OCR_INI_FILE_NOT_FOUND -1074395171 // The system could not locate the initialization file required for OCR initialization. | |
#define ERR_OCR_INVALID_CHARACTERTYPE -1074395170 // NI Vision does not support the CharacterType value you supplied. | |
#define ERR_OCR_INVALID_RECOGNITIONMODE -1074395169 // NI Vision does not support the RecognitionMode value you supplied. | |
#define ERR_OCR_INVALID_AUTOCORRECTIONMODE -1074395168 // NI Vision does not support the AutoCorrectionMode value you supplied. | |
#define ERR_OCR_INVALID_OUTPUTDELIMITER -1074395167 // NI Vision does not support the OutputDelimiter value you supplied. | |
#define ERR_OCR_BIN_DIR_NOT_FOUND -1074395166 // The system could not locate the OCR binary directory required for OCR initialization. | |
#define ERR_OCR_WTS_DIR_NOT_FOUND -1074395165 // The system could not locate the OCR weights directory required for OCR initialization. | |
#define ERR_OCR_ADD_WORD_FAILED -1074395164 // The supplied word could not be added to the user dictionary. | |
#define ERR_OCR_INVALID_CHARACTERPREFERENCE -1074395163 // NI Vision does not support the CharacterPreference value you supplied. | |
#define ERR_OCR_INVALID_CORRECTIONMODE -1074395162 // NI Vision does not support the CorrectionMethod value you supplied. | |
#define ERR_OCR_INVALID_CORRECTIONLEVEL -1074395161 // NI Vision does not support the CorrectionLevel value you supplied. | |
#define ERR_OCR_INVALID_MAXPOINTSIZE -1074395160 // NI Vision does not support the maximum point size you supplied. Valid values range from 4 to 72. | |
#define ERR_OCR_INVALID_TOLERANCE -1074395159 // NI Vision does not support the tolerance value you supplied. Valid values are non-negative. | |
#define ERR_OCR_INVALID_CONTRASTMODE -1074395158 // NI Vision does not support the ContrastMode value you supplied. | |
#define ERR_OCR_SKEW_DETECT_FAILED -1074395156 // The OCR attempted to detected the text skew and failed. | |
#define ERR_OCR_ORIENT_DETECT_FAILED -1074395155 // The OCR attempted to detected the text orientation and failed. | |
#define ERR_FONT_FILE_FORMAT -1074395153 // Invalid font file format. | |
#define ERR_FONT_FILE_NOT_FOUND -1074395152 // Font file not found. | |
#define ERR_OCR_CORRECTION_FAILED -1074395151 // The OCR engine failed during the correction stage. | |
#define ERR_INVALID_ROUNDING_MODE -1074395150 // NI Vision does not support the RoundingMode value you supplied. | |
#define ERR_DUPLICATE_TRANSFORM_TYPE -1074395149 // Found a duplicate transform type in the properties array. Each properties array may only contain one behavior for each transform type. | |
#define ERR_OVERLAY_GROUP_NOT_FOUND -1074395148 // Overlay Group Not Found. | |
#define ERR_BARCODE_RSSLIMITED -1074395147 // The barcode is not a valid RSS Limited symbol | |
#define ERR_QR_DETECTION_VERSION -1074395146 // Couldn't determine the correct version of the QR code. | |
#define ERR_QR_INVALID_READ -1074395145 // Invalid read of the QR code. | |
#define ERR_QR_INVALID_BARCODE -1074395144 // The barcode that was read contains invalid parameters. | |
#define ERR_QR_DETECTION_MODE -1074395143 // The data stream that was demodulated could not be read because the mode was not detected. | |
#define ERR_QR_DETECTION_MODELTYPE -1074395142 // Couldn't determine the correct model of the QR code. | |
#define ERR_OCR_NO_TEXT_FOUND -1074395141 // The OCR engine could not find any text in the supplied region. | |
#define ERR_OCR_CHAR_REPORT_CORRUPTED -1074395140 // One of the character reports is no longer usable by the system. | |
#define ERR_IMAQ_QR_DIMENSION_INVALID -1074395139 // Invalid Dimensions. | |
#define ERR_OCR_REGION_TOO_SMALL -1074395138 // The OCR region provided was too small to have contained any characters. | |
#define _FIRST_ERR ERR_SYSTEM_ERROR | |
#define _LAST_ERR ERR_OCR_REGION_TOO_SMALL | |
//============================================================================ | |
// Enumerated Types | |
//============================================================================ | |
typedef enum PointSymbol_enum { | |
IMAQ_POINT_AS_PIXEL = 0, //A single pixel represents a point in the overlay. | |
IMAQ_POINT_AS_CROSS = 1, //A cross represents a point in the overlay. | |
IMAQ_POINT_USER_DEFINED = 2, //The pattern supplied by the user represents a point in the overlay. | |
IMAQ_POINT_SYMBOL_SIZE_GUARD = 0xFFFFFFFF | |
} PointSymbol; | |
typedef enum MeasurementValue_enum { | |
IMAQ_AREA = 0, //Surface area of the particle in pixels. | |
IMAQ_AREA_CALIBRATED = 1, //Surface area of the particle in calibrated units. | |
IMAQ_NUM_HOLES = 2, //Number of holes in the particle. | |
IMAQ_AREA_OF_HOLES = 3, //Surface area of the holes in calibrated units. | |
IMAQ_TOTAL_AREA = 4, //Total surface area (holes and particle) in calibrated units. | |
IMAQ_IMAGE_AREA = 5, //Surface area of the entire image in calibrated units. | |
IMAQ_PARTICLE_TO_IMAGE = 6, //Ratio, expressed as a percentage, of the surface area of a particle in relation to the total area of the particle. | |
IMAQ_PARTICLE_TO_TOTAL = 7, //Ratio, expressed as a percentage, of the surface area of a particle in relation to the total area of the particle. | |
IMAQ_CENTER_MASS_X = 8, //X-coordinate of the center of mass. | |
IMAQ_CENTER_MASS_Y = 9, //Y-coordinate of the center of mass. | |
IMAQ_LEFT_COLUMN = 10, //Left edge of the bounding rectangle. | |
IMAQ_TOP_ROW = 11, //Top edge of the bounding rectangle. | |
IMAQ_RIGHT_COLUMN = 12, //Right edge of the bounding rectangle. | |
IMAQ_BOTTOM_ROW = 13, //Bottom edge of bounding rectangle. | |
IMAQ_WIDTH = 14, //Width of bounding rectangle in calibrated units. | |
IMAQ_HEIGHT = 15, //Height of bounding rectangle in calibrated units. | |
IMAQ_MAX_SEGMENT_LENGTH = 16, //Length of longest horizontal line segment. | |
IMAQ_MAX_SEGMENT_LEFT_COLUMN = 17, //Leftmost x-coordinate of longest horizontal line segment. | |
IMAQ_MAX_SEGMENT_TOP_ROW = 18, //Y-coordinate of longest horizontal line segment. | |
IMAQ_PERIMETER = 19, //Outer perimeter of the particle. | |
IMAQ_PERIMETER_OF_HOLES = 20, //Perimeter of all holes within the particle. | |
IMAQ_SIGMA_X = 21, //Sum of the particle pixels on the x-axis. | |
IMAQ_SIGMA_Y = 22, //Sum of the particle pixels on the y-axis. | |
IMAQ_SIGMA_XX = 23, //Sum of the particle pixels on the x-axis squared. | |
IMAQ_SIGMA_YY = 24, //Sum of the particle pixels on the y-axis squared. | |
IMAQ_SIGMA_XY = 25, //Sum of the particle pixels on the x-axis and y-axis. | |
IMAQ_PROJ_X = 26, //Projection corrected in X. | |
IMAQ_PROJ_Y = 27, //Projection corrected in Y. | |
IMAQ_INERTIA_XX = 28, //Inertia matrix coefficient in XX. | |
IMAQ_INERTIA_YY = 29, //Inertia matrix coefficient in YY. | |
IMAQ_INERTIA_XY = 30, //Inertia matrix coefficient in XY. | |
IMAQ_MEAN_H = 31, //Mean length of horizontal segments. | |
IMAQ_MEAN_V = 32, //Mean length of vertical segments. | |
IMAQ_MAX_INTERCEPT = 33, //Length of longest segment of the convex hull. | |
IMAQ_MEAN_INTERCEPT = 34, //Mean length of the chords in an object perpendicular to its max intercept. | |
IMAQ_ORIENTATION = 35, //The orientation based on the inertia of the pixels in the particle. | |
IMAQ_EQUIV_ELLIPSE_MINOR = 36, //Total length of the axis of the ellipse having the same area as the particle and a major axis equal to half the max intercept. | |
IMAQ_ELLIPSE_MAJOR = 37, //Total length of major axis having the same area and perimeter as the particle in calibrated units. | |
IMAQ_ELLIPSE_MINOR = 38, //Total length of minor axis having the same area and perimeter as the particle in calibrated units. | |
IMAQ_ELLIPSE_RATIO = 39, //Fraction of major axis to minor axis. | |
IMAQ_RECT_LONG_SIDE = 40, //Length of the long side of a rectangle having the same area and perimeter as the particle in calibrated units. | |
IMAQ_RECT_SHORT_SIDE = 41, //Length of the short side of a rectangle having the same area and perimeter as the particle in calibrated units. | |
IMAQ_RECT_RATIO = 42, //Ratio of rectangle long side to rectangle short side. | |
IMAQ_ELONGATION = 43, //Max intercept/mean perpendicular intercept. | |
IMAQ_COMPACTNESS = 44, //Particle area/(height x width). | |
IMAQ_HEYWOOD = 45, //Particle perimeter/perimeter of the circle having the same area as the particle. | |
IMAQ_TYPE_FACTOR = 46, //A complex factor relating the surface area to the moment of inertia. | |
IMAQ_HYDRAULIC = 47, //Particle area/particle perimeter. | |
IMAQ_WADDLE_DISK = 48, //Diameter of the disk having the same area as the particle in user units. | |
IMAQ_DIAGONAL = 49, //Diagonal of an equivalent rectangle in user units. | |
IMAQ_MEASUREMENT_VALUE_SIZE_GUARD = 0xFFFFFFFF | |
} MeasurementValue; | |
typedef enum ScalingMode_enum { | |
IMAQ_SCALE_LARGER = 0, //The function duplicates pixels to make the image larger. | |
IMAQ_SCALE_SMALLER = 1, //The function subsamples pixels to make the image smaller. | |
IMAQ_SCALING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ScalingMode; | |
typedef enum ScalingMethod_enum { | |
IMAQ_SCALE_TO_PRESERVE_AREA = 0, //Correction functions scale the image such that the features in the corrected image have the same area as the features in the input image. | |
IMAQ_SCALE_TO_FIT = 1, //Correction functions scale the image such that the corrected image is the same size as the input image. | |
IMAQ_SCALING_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} ScalingMethod; | |
typedef enum ReferenceMode_enum { | |
IMAQ_COORD_X_Y = 0, //This method requires three elements in the points array. | |
IMAQ_COORD_ORIGIN_X = 1, //This method requires two elements in the points array. | |
IMAQ_REFERENCE_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ReferenceMode; | |
typedef enum RectOrientation_enum { | |
IMAQ_BASE_INSIDE = 0, //Specifies that the base of the rectangular image lies along the inside edge of the annulus. | |
IMAQ_BASE_OUTSIDE = 1, //Specifies that the base of the rectangular image lies along the outside edge of the annulus. | |
IMAQ_TEXT_ORIENTATION_SIZE_GUARD = 0xFFFFFFFF | |
} RectOrientation; | |
typedef enum ShapeMode_enum { | |
IMAQ_SHAPE_RECT = 1, //The function draws a rectangle. | |
IMAQ_SHAPE_OVAL = 2, //The function draws an oval. | |
IMAQ_SHAPE_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ShapeMode; | |
typedef enum PolarityType_enum { | |
IMAQ_EDGE_RISING = 1, //The edge is a rising edge. | |
IMAQ_EDGE_FALLING = -1, //The edge is a falling edge. | |
IMAQ_POLARITY_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} PolarityType; | |
typedef enum SizeType_enum { | |
IMAQ_KEEP_LARGE = 0, //The function keeps large particles remaining after the erosion. | |
IMAQ_KEEP_SMALL = 1, //The function keeps small particles eliminated by the erosion. | |
IMAQ_SIZE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} SizeType; | |
typedef enum Plane3D_enum { | |
IMAQ_3D_REAL = 0, //The function shows the real part of complex images. | |
IMAQ_3D_IMAGINARY = 1, //The function shows the imaginary part of complex images. | |
IMAQ_3D_MAGNITUDE = 2, //The function shows the magnitude part of complex images. | |
IMAQ_3D_PHASE = 3, //The function shows the phase part of complex images. | |
IMAQ_PLANE_3D_SIZE_GUARD = 0xFFFFFFFF | |
} Plane3D; | |
typedef enum PhotometricMode_enum { | |
IMAQ_WHITE_IS_ZERO = 0, //The function interprets zero-value pixels as white. | |
IMAQ_BLACK_IS_ZERO = 1, //The function interprets zero-value pixels as black. | |
IMAQ_PHOTOMETRIC_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} PhotometricMode; | |
typedef enum ParticleInfoMode_enum { | |
IMAQ_BASIC_INFO = 0, //The function returns only the following elements of each report: area, calibratedArea, boundingRect. | |
IMAQ_ALL_INFO = 1, //The function returns all the information about each particle. | |
IMAQ_PARTICLE_INFO_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ParticleInfoMode; | |
typedef enum OutlineMethod_enum { | |
IMAQ_EDGE_DIFFERENCE = 0, //The function uses a method that produces continuous contours by highlighting each pixel where an intensity variation occurs between itself and its three upper-left neighbors. | |
IMAQ_EDGE_GRADIENT = 1, //The function uses a method that outlines contours where an intensity variation occurs along the vertical axis. | |
IMAQ_EDGE_PREWITT = 2, //The function uses a method that extracts the outer contours of objects. | |
IMAQ_EDGE_ROBERTS = 3, //The function uses a method that outlines the contours that highlight pixels where an intensity variation occurs along the diagonal axes. | |
IMAQ_EDGE_SIGMA = 4, //The function uses a method that outlines contours and details by setting pixels to the mean value found in their neighborhood, if their deviation from this value is not significant. | |
IMAQ_EDGE_SOBEL = 5, //The function uses a method that extracts the outer contours of objects. | |
IMAQ_OUTLINE_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} OutlineMethod; | |
typedef enum MorphologyMethod_enum { | |
IMAQ_AUTOM = 0, //The function uses a transformation that generates simpler particles that contain fewer details. | |
IMAQ_CLOSE = 1, //The function uses a transformation that fills tiny holes and smooths boundaries. | |
IMAQ_DILATE = 2, //The function uses a transformation that eliminates tiny holes isolated in particles and expands the contour of the particles according to the template defined by the structuring element. | |
IMAQ_ERODE = 3, //The function uses a transformation that eliminates pixels isolated in the background and erodes the contour of particles according to the template defined by the structuring element. | |
IMAQ_GRADIENT = 4, //The function uses a transformation that leaves only the pixels that would be added by the dilation process or eliminated by the erosion process. | |
IMAQ_GRADIENTOUT = 5, //The function uses a transformation that leaves only the pixels that would be added by the dilation process. | |
IMAQ_GRADIENTIN = 6, //The function uses a transformation that leaves only the pixels that would be eliminated by the erosion process. | |
IMAQ_HITMISS = 7, //The function uses a transformation that extracts each pixel located in a neighborhood exactly matching the template defined by the structuring element. | |
IMAQ_OPEN = 8, //The function uses a transformation that removes small particles and smooths boundaries. | |
IMAQ_PCLOSE = 9, //The function uses a transformation that fills tiny holes and smooths the inner contour of particles according to the template defined by the structuring element. | |
IMAQ_POPEN = 10, //The function uses a transformation that removes small particles and smooths the contour of particles according to the template defined by the structuring element. | |
IMAQ_THICK = 11, //The function uses a transformation that adds to an image those pixels located in a neighborhood that matches a template specified by the structuring element. | |
IMAQ_THIN = 12, //The function uses a transformation that eliminates pixels that are located in a neighborhood matching a template specified by the structuring element. | |
IMAQ_MORPHOLOGY_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} MorphologyMethod; | |
typedef enum MeterArcMode_enum { | |
IMAQ_METER_ARC_ROI = 0, //The function uses the roi parameter and ignores the base, start, and end parameters. | |
IMAQ_METER_ARC_POINTS = 1, //The function uses the base,start, and end parameters and ignores the roi parameter. | |
IMAQ_METER_ARC_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} MeterArcMode; | |
typedef enum RakeDirection_enum { | |
IMAQ_LEFT_TO_RIGHT = 0, //The function searches from the left side of the search area to the right side of the search area. | |
IMAQ_RIGHT_TO_LEFT = 1, //The function searches from the right side of the search area to the left side of the search area. | |
IMAQ_TOP_TO_BOTTOM = 2, //The function searches from the top side of the search area to the bottom side of the search area. | |
IMAQ_BOTTOM_TO_TOP = 3, //The function searches from the bottom side of the search area to the top side of the search area. | |
IMAQ_RAKE_DIRECTION_SIZE_GUARD = 0xFFFFFFFF | |
} RakeDirection; | |
typedef enum TruncateMode_enum { | |
IMAQ_TRUNCATE_LOW = 0, //The function truncates low frequencies. | |
IMAQ_TRUNCATE_HIGH = 1, //The function truncates high frequencies. | |
IMAQ_TRUNCATE_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} TruncateMode; | |
typedef enum AttenuateMode_enum { | |
IMAQ_ATTENUATE_LOW = 0, //The function attenuates low frequencies. | |
IMAQ_ATTENUATE_HIGH = 1, //The function attenuates high frequencies. | |
IMAQ_ATTENUATE_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} AttenuateMode; | |
typedef enum WindowThreadPolicy_enum { | |
IMAQ_CALLING_THREAD = 0, //Using this policy, NI Vision creates windows in the thread that makes the first display function call for a given window number. | |
IMAQ_SEPARATE_THREAD = 1, //Using this policy, NI Vision creates windows in a separate thread and processes messages for the windows automatically. | |
IMAQ_WINDOW_THREAD_POLICY_SIZE_GUARD = 0xFFFFFFFF | |
} WindowThreadPolicy; | |
typedef enum WindowOptions_enum { | |
IMAQ_WIND_RESIZABLE = 1, //When present, the user may resize the window interactively. | |
IMAQ_WIND_TITLEBAR = 2, //When present, the title bar on the window is visible. | |
IMAQ_WIND_CLOSEABLE = 4, //When present, the close box is available. | |
IMAQ_WIND_TOPMOST = 8, //When present, the window is always on top. | |
IMAQ_WINDOW_OPTIONS_SIZE_GUARD = 0xFFFFFFFF | |
} WindowOptions; | |
typedef enum WindowEventType_enum { | |
IMAQ_NO_EVENT = 0, //No event occurred since the last call to imaqGetLastEvent(). | |
IMAQ_CLICK_EVENT = 1, //The user clicked on a window. | |
IMAQ_DRAW_EVENT = 2, //The user drew an ROI in a window. | |
IMAQ_MOVE_EVENT = 3, //The user moved a window. | |
IMAQ_SIZE_EVENT = 4, //The user sized a window. | |
IMAQ_SCROLL_EVENT = 5, //The user scrolled a window. | |
IMAQ_ACTIVATE_EVENT = 6, //The user activated a window. | |
IMAQ_CLOSE_EVENT = 7, //The user closed a window. | |
IMAQ_DOUBLE_CLICK_EVENT = 8, //The user double-clicked in a window. | |
IMAQ_WINDOW_EVENT_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} WindowEventType; | |
typedef enum VisionInfoType_enum { | |
IMAQ_ANY_VISION_INFO = 0, //The function checks if any extra vision information is associated with the image. | |
IMAQ_PATTERN_MATCHING_INFO = 1, //The function checks if any pattern matching template information is associated with the image. | |
IMAQ_CALIBRATION_INFO = 2, //The function checks if any calibration information is associated with the image. | |
IMAQ_OVERLAY_INFO = 3, //The function checks if any overlay information is associated with the image. | |
IMAQ_VISION_INFO_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} VisionInfoType; | |
typedef enum SearchStrategy_enum { | |
IMAQ_CONSERVATIVE = 1, //Instructs the pattern matching algorithm to use the largest possible amount of information from the image at the expense of slowing down the speed of the algorithm. | |
IMAQ_BALANCED = 2, //Instructs the pattern matching algorithm to balance the amount of information from the image it uses with the speed of the algorithm. | |
IMAQ_AGGRESSIVE = 3, //Instructs the pattern matching algorithm to use a lower amount of information from the image, which allows the algorithm to run quickly but at the expense of accuracy. | |
IMAQ_VERY_AGGRESSIVE = 4, //Instructs the pattern matching algorithm to use the smallest possible amount of information from the image, which allows the algorithm to run at the highest speed possible but at the expense of accuracy. | |
IMAQ_SEARCH_STRATEGY_SIZE_GUARD = 0xFFFFFFFF | |
} SearchStrategy; | |
typedef enum TwoEdgePolarityType_enum { | |
IMAQ_NONE = 0, //The function ignores the polarity of the edges. | |
IMAQ_RISING_FALLING = 1, //The polarity of the first edge is rising (dark to light) and the polarity of the second edge is falling (light to dark). | |
IMAQ_FALLING_RISING = 2, //The polarity of the first edge is falling (light to dark) and the polarity of the second edge is rising (dark to light). | |
IMAQ_RISING_RISING = 3, //The polarity of the first edge is rising (dark to light) and the polarity of the second edge is rising (dark to light). | |
IMAQ_FALLING_FALLING = 4, //The polarity of the first edge is falling (light to dark) and the polarity of the second edge is falling (light to dark). | |
IMAQ_TWO_EDGE_POLARITY_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} TwoEdgePolarityType; | |
typedef enum ObjectType_enum { | |
IMAQ_BRIGHT_OBJECTS = 0, //The function detects bright objects. | |
IMAQ_DARK_OBJECTS = 1, //The function detects dark objects. | |
IMAQ_OBJECT_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ObjectType; | |
typedef enum Tool_enum { | |
IMAQ_NO_TOOL = -1, //No tool is in the selected state. | |
IMAQ_SELECTION_TOOL = 0, //The selection tool selects an existing ROI in an image. | |
IMAQ_POINT_TOOL = 1, //The point tool draws a point on the image. | |
IMAQ_LINE_TOOL = 2, //The line tool draws a line on the image. | |
IMAQ_RECTANGLE_TOOL = 3, //The rectangle tool draws a rectangle on the image. | |
IMAQ_OVAL_TOOL = 4, //The oval tool draws an oval on the image. | |
IMAQ_POLYGON_TOOL = 5, //The polygon tool draws a polygon on the image. | |
IMAQ_CLOSED_FREEHAND_TOOL = 6, //The closed freehand tool draws closed freehand shapes on the image. | |
IMAQ_ANNULUS_TOOL = 7, //The annulus tool draws annuluses on the image. | |
IMAQ_ZOOM_TOOL = 8, //The zoom tool controls the zoom of an image. | |
IMAQ_PAN_TOOL = 9, //The pan tool shifts the view of the image. | |
IMAQ_POLYLINE_TOOL = 10, //The polyline tool draws a series of connected straight lines on the image. | |
IMAQ_FREEHAND_TOOL = 11, //The freehand tool draws freehand lines on the image. | |
IMAQ_ROTATED_RECT_TOOL = 12, //The rotated rectangle tool draws rotated rectangles on the image. | |
IMAQ_ZOOM_OUT_TOOL = 13, //The zoom out tool controls the zoom of an image. | |
IMAQ_TOOL_SIZE_GUARD = 0xFFFFFFFF | |
} Tool; | |
typedef enum TIFFCompressionType_enum { | |
IMAQ_NO_COMPRESSION = 0, //The function does not compress the TIFF file. | |
IMAQ_JPEG = 1, //The function uses the JPEG compression algorithm to compress the TIFF file. | |
IMAQ_RUN_LENGTH = 2, //The function uses a run length compression algorithm to compress the TIFF file. | |
IMAQ_ZIP = 3, //The function uses the ZIP compression algorithm to compress the TIFF file. | |
IMAQ_TIFF_COMPRESSION_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} TIFFCompressionType; | |
typedef enum ThresholdMethod_enum { | |
IMAQ_THRESH_CLUSTERING = 0, //The function uses a method that sorts the histogram of the image within a discrete number of classes corresponding to the number of phases perceived in an image. | |
IMAQ_THRESH_ENTROPY = 1, //The function uses a method that is best for detecting particles that are present in minuscule proportions on the image. | |
IMAQ_THRESH_METRIC = 2, //The function uses a method that is well-suited for images in which classes are not too disproportionate. | |
IMAQ_THRESH_MOMENTS = 3, //The function uses a method that is suited for images that have poor contrast. | |
IMAQ_THRESH_INTERCLASS = 4, //The function uses a method that is well-suited for images in which classes have well separated pixel value distributions. | |
IMAQ_THRESHOLD_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} ThresholdMethod; | |
typedef enum TextAlignment_enum { | |
IMAQ_LEFT = 0, //Left aligns the text at the reference point. | |
IMAQ_CENTER = 1, //Centers the text around the reference point. | |
IMAQ_RIGHT = 2, //Right aligns the text at the reference point. | |
IMAQ_TEXT_ALIGNMENT_SIZE_GUARD = 0xFFFFFFFF | |
} TextAlignment; | |
typedef enum SpokeDirection_enum { | |
IMAQ_OUTSIDE_TO_INSIDE = 0, //The function searches from the outside of the search area to the inside of the search area. | |
IMAQ_INSIDE_TO_OUTSIDE = 1, //The function searches from the inside of the search area to the outside of the search area. | |
IMAQ_SPOKE_DIRECTION_SIZE_GUARD = 0xFFFFFFFF | |
} SpokeDirection; | |
typedef enum SkeletonMethod_enum { | |
IMAQ_SKELETON_L = 0, //Uses an L-shaped structuring element in the skeleton function. | |
IMAQ_SKELETON_M = 1, //Uses an M-shaped structuring element in the skeleton function. | |
IMAQ_SKELETON_INVERSE = 2, //Uses an L-shaped structuring element on an inverse of the image in the skeleton function. | |
IMAQ_SKELETON_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} SkeletonMethod; | |
typedef enum VerticalTextAlignment_enum { | |
IMAQ_BOTTOM = 0, //Aligns the bottom of the text at the reference point. | |
IMAQ_TOP = 1, //Aligns the top of the text at the reference point. | |
IMAQ_BASELINE = 2, //Aligns the baseline of the text at the reference point. | |
IMAQ_VERTICAL_TEXT_ALIGNMENT_SIZE_GUARD = 0xFFFFFFFF | |
} VerticalTextAlignment; | |
typedef enum CalibrationROI_enum { | |
IMAQ_FULL_IMAGE = 0, //The correction function corrects the whole image, regardless of the user-defined or calibration-defined ROIs. | |
IMAQ_CALIBRATION_ROI = 1, //The correction function corrects the area defined by the calibration ROI. | |
IMAQ_USER_ROI = 2, //The correction function corrects the area defined by the user-defined ROI. | |
IMAQ_CALIBRATION_AND_USER_ROI = 3, //The correction function corrects the area defined by the intersection of the user-defined ROI and the calibration ROI. | |
IMAQ_CALIBRATION_OR_USER_ROI = 4, //The correction function corrects the area defined by the union of the user-defined ROI and the calibration ROI. | |
IMAQ_CALIBRATION_ROI_SIZE_GUARD = 0xFFFFFFFF | |
} CalibrationROI; | |
typedef enum ContourType_enum { | |
IMAQ_EMPTY_CONTOUR = 0, //The contour is empty. | |
IMAQ_POINT = 1, //The contour represents a point. | |
IMAQ_LINE = 2, //The contour represents a line. | |
IMAQ_RECT = 3, //The contour represents a rectangle. | |
IMAQ_OVAL = 4, //The contour represents an oval. | |
IMAQ_CLOSED_CONTOUR = 5, //The contour represents a series of connected points where the last point connects to the first. | |
IMAQ_OPEN_CONTOUR = 6, //The contour represents a series of connected points where the last point does not connect to the first. | |
IMAQ_ANNULUS = 7, //The contour represents an annulus. | |
IMAQ_ROTATED_RECT = 8, //The contour represents a rotated rectangle. | |
IMAQ_CONTOUR_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ContourType; | |
typedef enum MathTransformMethod_enum { | |
IMAQ_TRANSFORM_LINEAR = 0, //The function uses linear remapping. | |
IMAQ_TRANSFORM_LOG = 1, //The function uses logarithmic remapping. | |
IMAQ_TRANSFORM_EXP = 2, //The function uses exponential remapping. | |
IMAQ_TRANSFORM_SQR = 3, //The function uses square remapping. | |
IMAQ_TRANSFORM_SQRT = 4, //The function uses square root remapping. | |
IMAQ_TRANSFORM_POWX = 5, //The function uses power X remapping. | |
IMAQ_TRANSFORM_POW1X = 6, //The function uses power 1/X remapping. | |
IMAQ_MATH_TRANSFORM_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} MathTransformMethod; | |
typedef enum ComplexPlane_enum { | |
IMAQ_REAL = 0, //The function operates on the real plane of the complex image. | |
IMAQ_IMAGINARY = 1, //The function operates on the imaginary plane of the complex image. | |
IMAQ_MAGNITUDE = 2, //The function operates on the magnitude plane of the complex image. | |
IMAQ_PHASE = 3, //The function operates on the phase plane of the complex image. | |
IMAQ_COMPLEX_PLANE_SIZE_GUARD = 0xFFFFFFFF | |
} ComplexPlane; | |
typedef enum PaletteType_enum { | |
IMAQ_PALETTE_GRAY = 0, //The function uses a palette that has a gradual gray-level variation from black to white. | |
IMAQ_PALETTE_BINARY = 1, //The function uses a palette of 16 cycles of 16 different colors that is useful with binary images. | |
IMAQ_PALETTE_GRADIENT = 2, //The function uses a palette that has a gradation from red to white with a prominent range of light blue in the upper value range. | |
IMAQ_PALETTE_RAINBOW = 3, //The function uses a palette that has a gradation from blue to red with a prominent range of greens in the middle value range. | |
IMAQ_PALETTE_TEMPERATURE = 4, //The function uses a palette that has a gradation from light brown to dark brown. | |
IMAQ_PALETTE_USER = 5, //The function uses a palette defined by the user. | |
IMAQ_PALETTE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} PaletteType; | |
typedef enum ColorSensitivity_enum { | |
IMAQ_SENSITIVITY_LOW = 0, //Instructs the algorithm to divide the hue plane into a low number of sectors, allowing for simple color analysis. | |
IMAQ_SENSITIVITY_MED = 1, //Instructs the algorithm to divide the hue plane into a medium number of sectors, allowing for color analysis that balances sensitivity and complexity. | |
IMAQ_SENSITIVITY_HIGH = 2, //Instructs the algorithm to divide the hue plane into a high number of sectors, allowing for complex, sensitive color analysis. | |
IMAQ_COLOR_SENSITIVITY_SIZE_GUARD = 0xFFFFFFFF | |
} ColorSensitivity; | |
typedef enum ColorMode_enum { | |
IMAQ_RGB = 0, //The function operates in the RGB (Red, Blue, Green) color space. | |
IMAQ_HSL = 1, //The function operates in the HSL (Hue, Saturation, Luminance) color space. | |
IMAQ_HSV = 2, //The function operates in the HSV (Hue, Saturation, Value) color space. | |
IMAQ_HSI = 3, //The function operates in the HSI (Hue, Saturation, Intensity) color space. | |
IMAQ_CIE = 4, //The function operates in the CIE L*a*b* color space. | |
IMAQ_CIEXYZ = 5, //The function operates in the CIE XYZ color space. | |
IMAQ_COLOR_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ColorMode; | |
typedef enum DetectionMode_enum { | |
IMAQ_DETECT_PEAKS = 0, //The function detects peaks. | |
IMAQ_DETECT_VALLEYS = 1, //The function detects valleys. | |
IMAQ_DETECTION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DetectionMode; | |
typedef enum CalibrationUnit_enum { | |
IMAQ_UNDEFINED = 0, //The image does not have a defined unit of measurement. | |
IMAQ_ANGSTROM = 1, //The unit of measure for the image is angstroms. | |
IMAQ_MICROMETER = 2, //The unit of measure for the image is micrometers. | |
IMAQ_MILLIMETER = 3, //The unit of measure for the image is millimeters. | |
IMAQ_CENTIMETER = 4, //The unit of measure for the image is centimeters. | |
IMAQ_METER = 5, //The unit of measure for the image is meters. | |
IMAQ_KILOMETER = 6, //The unit of measure for the image is kilometers. | |
IMAQ_MICROINCH = 7, //The unit of measure for the image is microinches. | |
IMAQ_INCH = 8, //The unit of measure for the image is inches. | |
IMAQ_FOOT = 9, //The unit of measure for the image is feet. | |
IMAQ_NAUTICMILE = 10, //The unit of measure for the image is nautical miles. | |
IMAQ_GROUNDMILE = 11, //The unit of measure for the image is ground miles. | |
IMAQ_STEP = 12, //The unit of measure for the image is steps. | |
IMAQ_CALIBRATION_UNIT_SIZE_GUARD = 0xFFFFFFFF | |
} CalibrationUnit; | |
typedef enum ConcentricRakeDirection_enum { | |
IMAQ_COUNTER_CLOCKWISE = 0, //The function searches the search area in a counter-clockwise direction. | |
IMAQ_CLOCKWISE = 1, //The function searches the search area in a clockwise direction. | |
IMAQ_CONCENTRIC_RAKE_DIRECTION_SIZE_GUARD = 0xFFFFFFFF | |
} ConcentricRakeDirection; | |
typedef enum CalibrationMode_enum { | |
IMAQ_PERSPECTIVE = 0, //Functions correct for distortion caused by the camera's perspective. | |
IMAQ_NONLINEAR = 1, //Functions correct for distortion caused by the camera's lens. | |
IMAQ_SIMPLE_CALIBRATION = 2, //Functions do not correct for distortion. | |
IMAQ_CORRECTED_IMAGE = 3, //The image is already corrected. | |
IMAQ_CALIBRATION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} CalibrationMode; | |
typedef enum BrowserLocation_enum { | |
IMAQ_INSERT_FIRST_FREE = 0, //Inserts the thumbnail in the first available cell. | |
IMAQ_INSERT_END = 1, //Inserts the thumbnail after the last occupied cell. | |
IMAQ_BROWSER_LOCATION_SIZE_GUARD = 0xFFFFFFFF | |
} BrowserLocation; | |
typedef enum BrowserFrameStyle_enum { | |
IMAQ_RAISED_FRAME = 0, //Each thumbnail has a raised frame. | |
IMAQ_BEVELLED_FRAME = 1, //Each thumbnail has a beveled frame. | |
IMAQ_OUTLINE_FRAME = 2, //Each thumbnail has an outlined frame. | |
IMAQ_HIDDEN_FRAME = 3, //Each thumbnail has a hidden frame. | |
IMAQ_STEP_FRAME = 4, //Each thumbnail has a stepped frame. | |
IMAQ_RAISED_OUTLINE_FRAME = 5, //Each thumbnail has a raised, outlined frame. | |
IMAQ_BROWSER_FRAME_STYLE_SIZE_GUARD = 0xFFFFFFFF | |
} BrowserFrameStyle; | |
typedef enum BorderMethod_enum { | |
IMAQ_BORDER_MIRROR = 0, //Symmetrically copies pixel values from the image into the border. | |
IMAQ_BORDER_COPY = 1, //Copies the value of the pixel closest to the edge of the image into the border. | |
IMAQ_BORDER_CLEAR = 2, //Sets all pixels in the border to 0. | |
IMAQ_BORDER_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} BorderMethod; | |
typedef enum BarcodeType_enum { | |
IMAQ_INVALID = -1, //The barcode is not of a type known by NI Vision. | |
IMAQ_CODABAR = 1, //The barcode is of type Codabar. | |
IMAQ_CODE39 = 2, //The barcode is of type Code 39. | |
IMAQ_CODE93 = 4, //The barcode is of type Code 93. | |
IMAQ_CODE128 = 8, //The barcode is of type Code 128. | |
IMAQ_EAN8 = 16, //The barcode is of type EAN 8. | |
IMAQ_EAN13 = 32, //The barcode is of type EAN 13. | |
IMAQ_I2_OF_5 = 64, //The barcode is of type Code 25. | |
IMAQ_MSI = 128, //The barcode is of type MSI code. | |
IMAQ_UPCA = 256, //The barcode is of type UPC A. | |
IMAQ_PHARMACODE = 512, //The barcode is of type Pharmacode. | |
IMAQ_RSS_LIMITED = 1024, //The barcode is of type RSS Limited. | |
IMAQ_BARCODE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} BarcodeType; | |
typedef enum AxisOrientation_enum { | |
IMAQ_DIRECT = 0, //The y-axis direction corresponds to the y-axis direction of the Cartesian coordinate system. | |
IMAQ_INDIRECT = 1, //The y-axis direction corresponds to the y-axis direction of an image. | |
IMAQ_AXIS_ORIENTATION_SIZE_GUARD = 0xFFFFFFFF | |
} AxisOrientation; | |
typedef enum ColorIgnoreMode_enum { | |
IMAQ_IGNORE_NONE = 0, //Specifies that the function does not ignore any pixels. | |
IMAQ_IGNORE_BLACK = 1, //Specifies that the function ignores black pixels. | |
IMAQ_IGNORE_WHITE = 2, //Specifies that the function ignores white pixels. | |
IMAQ_IGNORE_BLACK_AND_WHITE = 3, //Specifies that the function ignores black pixels and white pixels. | |
IMAQ_BLACK_WHITE_IGNORE_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ColorIgnoreMode; | |
typedef enum LevelType_enum { | |
IMAQ_ABSOLUTE = 0, //The function evaluates the threshold and hysteresis values as absolute values. | |
IMAQ_RELATIVE = 1, //The function evaluates the threshold and hysteresis values relative to the dynamic range of the given path. | |
IMAQ_LEVEL_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} LevelType; | |
typedef enum MatchingMode_enum { | |
IMAQ_MATCH_SHIFT_INVARIANT = 1, //Searches for occurrences of the template image anywhere in the searchRect, assuming that the pattern is not rotated more than plus or minus 4 degrees. | |
IMAQ_MATCH_ROTATION_INVARIANT = 2, //Searches for occurrences of the pattern in the image with no restriction on the rotation of the pattern. | |
IMAQ_MATCHING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} MatchingMode; | |
typedef enum MappingMethod_enum { | |
IMAQ_FULL_DYNAMIC = 0, //(Obsolete) When the image bit depth is 0, the function maps the full dynamic range of the 16-bit image to an 8-bit scale. | |
IMAQ_DOWNSHIFT = 1, //(Obsolete) When the image bit depth is 0, the function shifts the 16-bit image pixels to the right the number of times specified by the shiftCount element of the DisplayMapping structure. | |
IMAQ_RANGE = 2, //(Obsolete) When the image bit depth is 0, the function maps the pixel values in the range specified by the minimumValue and maximumValue elements of the DisplayMapping structure to an 8-bit scale. | |
IMAQ_90_PCT_DYNAMIC = 3, //(Obsolete) When the image bit depth to 0, the function maps the dynamic range containing the middle 90 percent of the cumulated histogram of the image to an 8-bit (256 grayscale values) scale. | |
IMAQ_PERCENT_RANGE = 4, //(Obsolete) When the image bit depth is 0, the function maps the pixel values in the relative percentage range (0 to 100) of the cumulated histogram specified by minimumValue and maximumValue to an 8-bit scale. | |
IMAQ_DEFAULT_MAPPING = 10, //If the bit depth is 0, the function maps the 16-bit image to 8 bits by following the IMAQ_FULL_DYNAMIC_ALWAYS behavior; otherwise, the function shifts the image data to the right according to the IMAQ_MOST_SIGNIFICANT behavior. | |
IMAQ_MOST_SIGNIFICANT = 11, //The function shifts the 16-bit image pixels to the right until the 8 most significant bits of the image data are remaining. | |
IMAQ_FULL_DYNAMIC_ALWAYS = 12, //The function maps the full dynamic range of the 16-bit image to an 8-bit scale. | |
IMAQ_DOWNSHIFT_ALWAYS = 13, //The function shifts the 16-bit image pixels to the right the number of times specified by the shiftCount element of the DisplayMapping structure. | |
IMAQ_RANGE_ALWAYS = 14, //The function maps the pixel values in the range specified by the minimumValue and maximumValue elements of the DisplayMapping structure to an 8-bit scale. | |
IMAQ_90_PCT_DYNAMIC_ALWAYS = 15, //The function maps the dynamic range containing the middle 90 percent of the cumulated histogram of the image to an 8-bit (256 grayscale values) scale. | |
IMAQ_PERCENT_RANGE_ALWAYS = 16, //The function maps the pixel values in the relative percentage range (0 to 100) of the cumulated histogram specified by minimumValue and maximumValue to an 8-bit scale. | |
IMAQ_MAPPING_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} MappingMethod; | |
typedef enum ComparisonFunction_enum { | |
IMAQ_CLEAR_LESS = 0, //The comparison is true if the source pixel value is less than the comparison image pixel value. | |
IMAQ_CLEAR_LESS_OR_EQUAL = 1, //The comparison is true if the source pixel value is less than or equal to the comparison image pixel value. | |
IMAQ_CLEAR_EQUAL = 2, //The comparison is true if the source pixel value is equal to the comparison image pixel value. | |
IMAQ_CLEAR_GREATER_OR_EQUAL = 3, //The comparison is true if the source pixel value is greater than or equal to the comparison image pixel value. | |
IMAQ_CLEAR_GREATER = 4, //The comparison is true if the source pixel value is greater than the comparison image pixel value. | |
IMAQ_COMPARE_FUNCTION_SIZE_GUARD = 0xFFFFFFFF | |
} ComparisonFunction; | |
typedef enum LineGaugeMethod_enum { | |
IMAQ_EDGE_TO_EDGE = 0, //Measures from the first edge on the line to the last edge on the line. | |
IMAQ_EDGE_TO_POINT = 1, //Measures from the first edge on the line to the end point of the line. | |
IMAQ_POINT_TO_EDGE = 2, //Measures from the start point of the line to the first edge on the line. | |
IMAQ_POINT_TO_POINT = 3, //Measures from the start point of the line to the end point of the line. | |
IMAQ_LINE_GAUGE_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} LineGaugeMethod; | |
typedef enum Direction3D_enum { | |
IMAQ_3D_NW = 0, //The viewing angle for the 3D image is from the northwest. | |
IMAQ_3D_SW = 1, //The viewing angle for the 3D image is from the southwest. | |
IMAQ_3D_SE = 2, //The viewing angle for the 3D image is from the southeast. | |
IMAQ_3D_NE = 3, //The viewing angle for the 3D image is from the northeast. | |
IMAQ_DIRECTION_3D_SIZE_GUARD = 0xFFFFFFFF | |
} Direction3D; | |
typedef enum LearningMode_enum { | |
IMAQ_LEARN_ALL = 0, //The function extracts information for shift- and rotation-invariant matching. | |
IMAQ_LEARN_SHIFT_INFORMATION = 1, //The function extracts information for shift-invariant matching. | |
IMAQ_LEARN_ROTATION_INFORMATION = 2, //The function extracts information for rotation-invariant matching. | |
IMAQ_LEARNING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} LearningMode; | |
typedef enum KernelFamily_enum { | |
IMAQ_GRADIENT_FAMILY = 0, //The kernel is in the gradient family. | |
IMAQ_LAPLACIAN_FAMILY = 1, //The kernel is in the Laplacian family. | |
IMAQ_SMOOTHING_FAMILY = 2, //The kernel is in the smoothing family. | |
IMAQ_GAUSSIAN_FAMILY = 3, //The kernel is in the Gaussian family. | |
IMAQ_KERNEL_FAMILY_SIZE_GUARD = 0xFFFFFFFF | |
} KernelFamily; | |
typedef enum InterpolationMethod_enum { | |
IMAQ_ZERO_ORDER = 0, //The function uses an interpolation method that interpolates new pixel values using the nearest valid neighboring pixel. | |
IMAQ_BILINEAR = 1, //The function uses an interpolation method that interpolates new pixel values using a bidirectional average of the neighboring pixels. | |
IMAQ_QUADRATIC = 2, //The function uses an interpolation method that interpolates new pixel values using a quadratic approximating polynomial. | |
IMAQ_CUBIC_SPLINE = 3, //The function uses an interpolation method that interpolates new pixel values by fitting them to a cubic spline curve, where the curve is based on known pixel values from the image. | |
IMAQ_BILINEAR_FIXED = 4, //The function uses an interpolation method that interpolates new pixel values using a bidirectional average of the neighboring pixels. | |
IMAQ_INTERPOLATION_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} InterpolationMethod; | |
typedef enum ImageType_enum { | |
IMAQ_IMAGE_U8 = 0, //The image type is 8-bit unsigned integer grayscale. | |
IMAQ_IMAGE_U16 = 7, //The image type is 16-bit unsigned integer grayscale. | |
IMAQ_IMAGE_I16 = 1, //The image type is 16-bit signed integer grayscale. | |
IMAQ_IMAGE_SGL = 2, //The image type is 32-bit floating-point grayscale. | |
IMAQ_IMAGE_COMPLEX = 3, //The image type is complex. | |
IMAQ_IMAGE_RGB = 4, //The image type is RGB color. | |
IMAQ_IMAGE_HSL = 5, //The image type is HSL color. | |
IMAQ_IMAGE_RGB_U64 = 6, //The image type is 64-bit unsigned RGB color. | |
IMAQ_IMAGE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ImageType; | |
typedef enum ImageFeatureMode_enum { | |
IMAQ_COLOR_AND_SHAPE_FEATURES = 0, //Instructs the function to use the color and the shape features of the color pattern. | |
IMAQ_COLOR_FEATURES = 1, //Instructs the function to use the color features of the color pattern. | |
IMAQ_SHAPE_FEATURES = 2, //Instructs the function to use the shape features of the color pattern. | |
IMAQ_FEATURE_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ImageFeatureMode; | |
typedef enum FontColor_enum { | |
IMAQ_WHITE = 0, //Draws text in white. | |
IMAQ_BLACK = 1, //Draws text in black. | |
IMAQ_INVERT = 2, //Inverts the text pixels. | |
IMAQ_BLACK_ON_WHITE = 3, //Draws text in black with a white background. | |
IMAQ_WHITE_ON_BLACK = 4, //Draws text in white with a black background. | |
IMAQ_FONT_COLOR_SIZE_GUARD = 0xFFFFFFFF | |
} FontColor; | |
typedef enum FlipAxis_enum { | |
IMAQ_HORIZONTAL_AXIS = 0, //Flips the image over the central horizontal axis. | |
IMAQ_VERTICAL_AXIS = 1, //Flips the image over the central vertical axis. | |
IMAQ_CENTER_AXIS = 2, //Flips the image over both the central vertical and horizontal axes. | |
IMAQ_DIAG_L_TO_R_AXIS = 3, //Flips the image over an axis from the upper left corner to lower right corner. | |
IMAQ_DIAG_R_TO_L_AXIS = 4, //Flips the image over an axis from the upper right corner to lower left corner. | |
IMAQ_FLIP_AXIS_SIZE_GUARD = 0xFFFFFFFF | |
} FlipAxis; | |
typedef enum EdgeProcess_enum { | |
IMAQ_FIRST = 0, //The function looks for the first edge. | |
IMAQ_FIRST_AND_LAST = 1, //The function looks for the first and last edge. | |
IMAQ_ALL = 2, //The function looks for all edges. | |
IMAQ_BEST = 3, //The function looks for the best edge. | |
IMAQ_EDGE_PROCESS_SIZE_GUARD = 0xFFFFFFFF | |
} EdgeProcess; | |
typedef enum DrawMode_enum { | |
IMAQ_DRAW_VALUE = 0, //Draws the boundary of the object with the specified pixel value. | |
IMAQ_DRAW_INVERT = 2, //Inverts the pixel values of the boundary of the object. | |
IMAQ_PAINT_VALUE = 1, //Fills the object with the given pixel value. | |
IMAQ_PAINT_INVERT = 3, //Inverts the pixel values of the object. | |
IMAQ_HIGHLIGHT_VALUE = 4, //The function fills the object by highlighting the enclosed pixels with the color of the object. | |
IMAQ_DRAW_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DrawMode; | |
typedef enum NearestNeighborMetric_enum { | |
IMAQ_METRIC_MAXIMUM = 0, //The maximum metric. | |
IMAQ_METRIC_SUM = 1, //The sum metric. | |
IMAQ_METRIC_EUCLIDEAN = 2, //The Euclidean metric. | |
IMAQ_NEAREST_NEIGHBOR_METRIC_SIZE_GUARD = 0xFFFFFFFF | |
} NearestNeighborMetric; | |
typedef enum ReadResolution_enum { | |
IMAQ_LOW_RESOLUTION = 0, //Configures NI Vision to use low resolution during the read process. | |
IMAQ_MEDIUM_RESOLUTION = 1, //Configures NI Vision to use medium resolution during the read process. | |
IMAQ_HIGH_RESOLUTION = 2, //Configures NI Vision to use high resolution during the read process. | |
IMAQ_READ_RESOLUTION_SIZE_GUARD = 0xFFFFFFFF | |
} ReadResolution; | |
typedef enum ThresholdMode_enum { | |
IMAQ_FIXED_RANGE = 0, //Performs thresholding using the values you provide in the lowThreshold and highThreshold elements of OCRProcessingOptions. | |
IMAQ_COMPUTED_UNIFORM = 1, //Calculates a single threshold value for the entire ROI. | |
IMAQ_COMPUTED_LINEAR = 2, //Calculates a value on the left side of the ROI, calculates a value on the right side of the ROI, and linearly fills the middle values from left to right. | |
IMAQ_COMPUTED_NONLINEAR = 3, //Divides the ROI into the number of blocks specified by the blockCount element of OCRProcessingOptions and calculates a threshold value for each block. | |
IMAQ_THRESHOLD_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ThresholdMode; | |
typedef enum ReadStrategy_enum { | |
IMAQ_READ_AGGRESSIVE = 0, //Configures NI Vision to perform fewer checks when analyzing objects to determine if they match trained characters. | |
IMAQ_READ_CONSERVATIVE = 1, //Configures NI Vision to perform more checks to determine if an object matches a trained character. | |
IMAQ_READ_STRATEGY_SIZE_GUARD = 0xFFFFFFFF | |
} ReadStrategy; | |
typedef enum MeasurementType_enum { | |
IMAQ_MT_CENTER_OF_MASS_X = 0, //X-coordinate of the point representing the average position of the total particle mass, assuming every point in the particle has a constant density. | |
IMAQ_MT_CENTER_OF_MASS_Y = 1, //Y-coordinate of the point representing the average position of the total particle mass, assuming every point in the particle has a constant density. | |
IMAQ_MT_FIRST_PIXEL_X = 2, //X-coordinate of the highest, leftmost particle pixel. | |
IMAQ_MT_FIRST_PIXEL_Y = 3, //Y-coordinate of the highest, leftmost particle pixel. | |
IMAQ_MT_BOUNDING_RECT_LEFT = 4, //X-coordinate of the leftmost particle point. | |
IMAQ_MT_BOUNDING_RECT_TOP = 5, //Y-coordinate of highest particle point. | |
IMAQ_MT_BOUNDING_RECT_RIGHT = 6, //X-coordinate of the rightmost particle point. | |
IMAQ_MT_BOUNDING_RECT_BOTTOM = 7, //Y-coordinate of the lowest particle point. | |
IMAQ_MT_MAX_FERET_DIAMETER_START_X = 8, //X-coordinate of the start of the line segment connecting the two perimeter points that are the furthest apart. | |
IMAQ_MT_MAX_FERET_DIAMETER_START_Y = 9, //Y-coordinate of the start of the line segment connecting the two perimeter points that are the furthest apart. | |
IMAQ_MT_MAX_FERET_DIAMETER_END_X = 10, //X-coordinate of the end of the line segment connecting the two perimeter points that are the furthest apart. | |
IMAQ_MT_MAX_FERET_DIAMETER_END_Y = 11, //Y-coordinate of the end of the line segment connecting the two perimeter points that are the furthest apart. | |
IMAQ_MT_MAX_HORIZ_SEGMENT_LENGTH_LEFT = 12, //X-coordinate of the leftmost pixel in the longest row of contiguous pixels in the particle. | |
IMAQ_MT_MAX_HORIZ_SEGMENT_LENGTH_RIGHT = 13, //X-coordinate of the rightmost pixel in the longest row of contiguous pixels in the particle. | |
IMAQ_MT_MAX_HORIZ_SEGMENT_LENGTH_ROW = 14, //Y-coordinate of all of the pixels in the longest row of contiguous pixels in the particle. | |
IMAQ_MT_BOUNDING_RECT_WIDTH = 16, //Distance between the x-coordinate of the leftmost particle point and the x-coordinate of the rightmost particle point. | |
IMAQ_MT_BOUNDING_RECT_HEIGHT = 17, //Distance between the y-coordinate of highest particle point and the y-coordinate of the lowest particle point. | |
IMAQ_MT_BOUNDING_RECT_DIAGONAL = 18, //Distance between opposite corners of the bounding rectangle. | |
IMAQ_MT_PERIMETER = 19, //Length of the outer boundary of the particle. | |
IMAQ_MT_CONVEX_HULL_PERIMETER = 20, //Perimeter of the smallest convex polygon containing all points in the particle. | |
IMAQ_MT_HOLES_PERIMETER = 21, //Sum of the perimeters of each hole in the particle. | |
IMAQ_MT_MAX_FERET_DIAMETER = 22, //Distance between the start and end of the line segment connecting the two perimeter points that are the furthest apart. | |
IMAQ_MT_EQUIVALENT_ELLIPSE_MAJOR_AXIS = 23, //Length of the major axis of the ellipse with the same perimeter and area as the particle. | |
IMAQ_MT_EQUIVALENT_ELLIPSE_MINOR_AXIS = 24, //Length of the minor axis of the ellipse with the same perimeter and area as the particle. | |
IMAQ_MT_EQUIVALENT_ELLIPSE_MINOR_AXIS_FERET = 25, //Length of the minor axis of the ellipse with the same area as the particle, and Major Axis equal in length to the Max Feret Diameter. | |
IMAQ_MT_EQUIVALENT_RECT_LONG_SIDE = 26, //Longest side of the rectangle with the same perimeter and area as the particle. | |
IMAQ_MT_EQUIVALENT_RECT_SHORT_SIDE = 27, //Shortest side of the rectangle with the same perimeter and area as the particle. | |
IMAQ_MT_EQUIVALENT_RECT_DIAGONAL = 28, //Distance between opposite corners of the rectangle with the same perimeter and area as the particle. | |
IMAQ_MT_EQUIVALENT_RECT_SHORT_SIDE_FERET = 29, //Shortest side of the rectangle with the same area as the particle, and longest side equal in length to the Max Feret Diameter. | |
IMAQ_MT_AVERAGE_HORIZ_SEGMENT_LENGTH = 30, //Average length of a horizontal segment in the particle. | |
IMAQ_MT_AVERAGE_VERT_SEGMENT_LENGTH = 31, //Average length of a vertical segment in the particle. | |
IMAQ_MT_HYDRAULIC_RADIUS = 32, //The particle area divided by the particle perimeter. | |
IMAQ_MT_WADDEL_DISK_DIAMETER = 33, //Diameter of a disk with the same area as the particle. | |
IMAQ_MT_AREA = 35, //Area of the particle. | |
IMAQ_MT_HOLES_AREA = 36, //Sum of the areas of each hole in the particle. | |
IMAQ_MT_PARTICLE_AND_HOLES_AREA = 37, //Area of a particle that completely covers the image. | |
IMAQ_MT_CONVEX_HULL_AREA = 38, //Area of the smallest convex polygon containing all points in the particle. | |
IMAQ_MT_IMAGE_AREA = 39, //Area of the image. | |
IMAQ_MT_NUMBER_OF_HOLES = 41, //Number of holes in the particle. | |
IMAQ_MT_NUMBER_OF_HORIZ_SEGMENTS = 42, //Number of horizontal segments in the particle. | |
IMAQ_MT_NUMBER_OF_VERT_SEGMENTS = 43, //Number of vertical segments in the particle. | |
IMAQ_MT_ORIENTATION = 45, //The angle of the line that passes through the particle Center of Mass about which the particle has the lowest moment of inertia. | |
IMAQ_MT_MAX_FERET_DIAMETER_ORIENTATION = 46, //The angle of the line segment connecting the two perimeter points that are the furthest apart. | |
IMAQ_MT_AREA_BY_IMAGE_AREA = 48, //Percentage of the particle Area covering the Image Area. | |
IMAQ_MT_AREA_BY_PARTICLE_AND_HOLES_AREA = 49, //Percentage of the particle Area in relation to its Particle and Holes Area. | |
IMAQ_MT_RATIO_OF_EQUIVALENT_ELLIPSE_AXES = 50, //Equivalent Ellipse Major Axis divided by Equivalent Ellipse Minor Axis. | |
IMAQ_MT_RATIO_OF_EQUIVALENT_RECT_SIDES = 51, //Equivalent Rect Long Side divided by Equivalent Rect Short Side. | |
IMAQ_MT_ELONGATION_FACTOR = 53, //Max Feret Diameter divided by Equivalent Rect Short Side (Feret). | |
IMAQ_MT_COMPACTNESS_FACTOR = 54, //Area divided by the product of Bounding Rect Width and Bounding Rect Height. | |
IMAQ_MT_HEYWOOD_CIRCULARITY_FACTOR = 55, //Perimeter divided by the circumference of a circle with the same area. | |
IMAQ_MT_TYPE_FACTOR = 56, //Factor relating area to moment of inertia. | |
IMAQ_MT_SUM_X = 58, //The sum of all x-coordinates in the particle. | |
IMAQ_MT_SUM_Y = 59, //The sum of all y-coordinates in the particle. | |
IMAQ_MT_SUM_XX = 60, //The sum of all x-coordinates squared in the particle. | |
IMAQ_MT_SUM_XY = 61, //The sum of all x-coordinates times y-coordinates in the particle. | |
IMAQ_MT_SUM_YY = 62, //The sum of all y-coordinates squared in the particle. | |
IMAQ_MT_SUM_XXX = 63, //The sum of all x-coordinates cubed in the particle. | |
IMAQ_MT_SUM_XXY = 64, //The sum of all x-coordinates squared times y-coordinates in the particle. | |
IMAQ_MT_SUM_XYY = 65, //The sum of all x-coordinates times y-coordinates squared in the particle. | |
IMAQ_MT_SUM_YYY = 66, //The sum of all y-coordinates cubed in the particle. | |
IMAQ_MT_MOMENT_OF_INERTIA_XX = 68, //The moment of inertia in the x-direction twice. | |
IMAQ_MT_MOMENT_OF_INERTIA_XY = 69, //The moment of inertia in the x and y directions. | |
IMAQ_MT_MOMENT_OF_INERTIA_YY = 70, //The moment of inertia in the y-direction twice. | |
IMAQ_MT_MOMENT_OF_INERTIA_XXX = 71, //The moment of inertia in the x-direction three times. | |
IMAQ_MT_MOMENT_OF_INERTIA_XXY = 72, //The moment of inertia in the x-direction twice and the y-direction once. | |
IMAQ_MT_MOMENT_OF_INERTIA_XYY = 73, //The moment of inertia in the x-direction once and the y-direction twice. | |
IMAQ_MT_MOMENT_OF_INERTIA_YYY = 74, //The moment of inertia in the y-direction three times. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_XX = 75, //The normalized moment of inertia in the x-direction twice. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_XY = 76, //The normalized moment of inertia in the x- and y-directions. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_YY = 77, //The normalized moment of inertia in the y-direction twice. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_XXX = 78, //The normalized moment of inertia in the x-direction three times. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_XXY = 79, //The normalized moment of inertia in the x-direction twice and the y-direction once. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_XYY = 80, //The normalized moment of inertia in the x-direction once and the y-direction twice. | |
IMAQ_MT_NORM_MOMENT_OF_INERTIA_YYY = 81, //The normalized moment of inertia in the y-direction three times. | |
IMAQ_MT_HU_MOMENT_1 = 82, //The first Hu moment. | |
IMAQ_MT_HU_MOMENT_2 = 83, //The second Hu moment. | |
IMAQ_MT_HU_MOMENT_3 = 84, //The third Hu moment. | |
IMAQ_MT_HU_MOMENT_4 = 85, //The fourth Hu moment. | |
IMAQ_MT_HU_MOMENT_5 = 86, //The fifth Hu moment. | |
IMAQ_MT_HU_MOMENT_6 = 87, //The sixth Hu moment. | |
IMAQ_MT_HU_MOMENT_7 = 88, //The seventh Hu moment. | |
IMAQ_MEASUREMENT_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} MeasurementType; | |
typedef enum GeometricMatchingMode_enum { | |
IMAQ_GEOMETRIC_MATCH_SHIFT_INVARIANT = 0, //Searches for occurrences of the pattern in the image, assuming that the pattern is not rotated more than plus or minus 5 degrees. | |
IMAQ_GEOMETRIC_MATCH_ROTATION_INVARIANT = 1, //Searches for occurrences of the pattern in the image with reduced restriction on the rotation of the pattern. | |
IMAQ_GEOMETRIC_MATCH_SCALE_INVARIANT = 2, //Searches for occurrences of the pattern in the image with reduced restriction on the size of the pattern. | |
IMAQ_GEOMETRIC_MATCH_OCCLUSION_INVARIANT = 4, //Searches for occurrences of the pattern in the image, allowing for a specified percentage of the pattern to be occluded. | |
IMAQ_GEOMETRIC_MATCHING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} GeometricMatchingMode; | |
typedef enum ButtonLabel_enum { | |
IMAQ_BUTTON_OK = 0, //The label "OK". | |
IMAQ_BUTTON_SAVE = 1, //The label "Save". | |
IMAQ_BUTTON_SELECT = 2, //The label "Select". | |
IMAQ_BUTTON_LOAD = 3, //The label "Load". | |
IMAQ_BUTTON_LABEL_SIZE_GUARD = 0xFFFFFFFF | |
} ButtonLabel; | |
typedef enum NearestNeighborMethod_enum { | |
IMAQ_MINIMUM_MEAN_DISTANCE = 0, //The minimum mean distance method. | |
IMAQ_K_NEAREST_NEIGHBOR = 1, //The k-nearest neighbor method. | |
IMAQ_NEAREST_PROTOTYPE = 2, //The nearest prototype method. | |
IMAQ_NEAREST_NEIGHBOR_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} NearestNeighborMethod; | |
typedef enum QRMirrorMode_enum { | |
IMAQ_QR_MIRROR_MODE_AUTO_DETECT = -2, //The function should determine if the QR code is mirrored. | |
IMAQ_QR_MIRROR_MODE_MIRRORED = 1, //The function should expect the QR code to appear mirrored. | |
IMAQ_QR_MIRROR_MODE_NORMAL = 0, //The function should expect the QR code to appear normal. | |
IMAQ_QR_MIRROR_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRMirrorMode; | |
typedef enum ColumnProcessingMode_enum { | |
IMAQ_AVERAGE_COLUMNS = 0, //Averages the data extracted for edge detection. | |
IMAQ_MEDIAN_COLUMNS = 1, //Takes the median of the data extracted for edge detection. | |
IMAQ_COLUMN_PROCESSING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ColumnProcessingMode; | |
typedef enum FindReferenceDirection_enum { | |
IMAQ_LEFT_TO_RIGHT_DIRECT = 0, //Searches from the left side of the search area to the right side of the search area for a direct axis. | |
IMAQ_LEFT_TO_RIGHT_INDIRECT = 1, //Searches from the left side of the search area to the right side of the search area for an indirect axis. | |
IMAQ_TOP_TO_BOTTOM_DIRECT = 2, //Searches from the top of the search area to the bottom of the search area for a direct axis. | |
IMAQ_TOP_TO_BOTTOM_INDIRECT = 3, //Searches from the top of the search area to the bottom of the search area for an indirect axis. | |
IMAQ_RIGHT_TO_LEFT_DIRECT = 4, //Searches from the right side of the search area to the left side of the search area for a direct axis. | |
IMAQ_RIGHT_TO_LEFT_INDIRECT = 5, //Searches from the right side of the search area to the left side of the search area for an indirect axis. | |
IMAQ_BOTTOM_TO_TOP_DIRECT = 6, //Searches from the bottom of the search area to the top of the search area for a direct axis. | |
IMAQ_BOTTOM_TO_TOP_INDIRECT = 7, //Searches from the bottom of the search area to the top of the search area for an indirect axis. | |
IMAQ_FIND_COORD_SYS_DIR_SIZE_GUARD = 0xFFFFFFFF | |
} FindReferenceDirection; | |
typedef enum MulticoreOperation_enum { | |
IMAQ_GET_CORES = 0, //The number of processor cores NI Vision is currently using. | |
IMAQ_SET_CORES = 1, //The number of processor cores for NI Vision to use. | |
IMAQ_USE_MAX_AVAILABLE = 2, //Use the maximum number of available processor cores. | |
IMAQ_MULTICORE_OPERATION_SIZE_GUARD = 0xFFFFFFFF | |
} MulticoreOperation; | |
typedef enum GroupBehavior_enum { | |
IMAQ_GROUP_CLEAR = 0, //Sets the behavior of the overlay group to clear the current settings when an image is transformed. | |
IMAQ_GROUP_KEEP = 1, //Sets the behavior of the overlay group to keep the current settings when an image is transformed. | |
IMAQ_GROUP_TRANSFORM = 2, //Sets the behavior of the overlay group to transform with the image. | |
IMAQ_GROUP_BEHAVIOR_SIZE_GUARD = 0xFFFFFFFF | |
} GroupBehavior; | |
typedef enum QRDimensions_enum { | |
IMAQ_QR_DIMENSIONS_AUTO_DETECT = 0, //The function will automatically determine the dimensions of the QR code. | |
IMAQ_QR_DIMENSIONS_11x11 = 11, //Specifies the dimensions of the QR code as 11 x 11. | |
IMAQ_QR_DIMENSIONS_13x13 = 13, //Specifies the dimensions of the QR code as 13 x 13. | |
IMAQ_QR_DIMENSIONS_15x15 = 15, //Specifies the dimensions of the QR code as 15 x 15. | |
IMAQ_QR_DIMENSIONS_17x17 = 17, //Specifies the dimensions of the QR code as 17 x 17. | |
IMAQ_QR_DIMENSIONS_21x21 = 21, //Specifies the dimensions of the QR code as 21 x 21. | |
IMAQ_QR_DIMENSIONS_25x25 = 25, //Specifies the dimensions of the QR code as 25 x 25. | |
IMAQ_QR_DIMENSIONS_29x29 = 29, //Specifies the dimensions of the QR code as 29 x 29. | |
IMAQ_QR_DIMENSIONS_33x33 = 33, //Specifies the dimensions of the QR code as 33 x 33. | |
IMAQ_QR_DIMENSIONS_37x37 = 37, //Specifies the dimensions of the QR code as 37 x 37. | |
IMAQ_QR_DIMENSIONS_41x41 = 41, //Specifies the dimensions of the QR code as 41 x 41. | |
IMAQ_QR_DIMENSIONS_45x45 = 45, //Specifies the dimensions of the QR code as 45 x 45. | |
IMAQ_QR_DIMENSIONS_49x49 = 49, //Specifies the dimensions of the QR code as 49 x 49. | |
IMAQ_QR_DIMENSIONS_53x53 = 53, //Specifies the dimensions of the QR code as 53 x 53. | |
IMAQ_QR_DIMENSIONS_57x57 = 57, //Specifies the dimensions of the QR code as 57 x 57. | |
IMAQ_QR_DIMENSIONS_61x61 = 61, //Specifies the dimensions of the QR code as 61 x 61. | |
IMAQ_QR_DIMENSIONS_65x65 = 65, //Specifies the dimensions of the QR code as 65 x 65. | |
IMAQ_QR_DIMENSIONS_69x69 = 69, //Specifies the dimensions of the QR code as 69 x 69. | |
IMAQ_QR_DIMENSIONS_73x73 = 73, //Specifies the dimensions of the QR code as 73 x 73. | |
IMAQ_QR_DIMENSIONS_77x77 = 77, //Specifies the dimensions of the QR code as 77 x 77. | |
IMAQ_QR_DIMENSIONS_81x81 = 81, //Specifies the dimensions of the QR code as 81 x 81. | |
IMAQ_QR_DIMENSIONS_85x85 = 85, //Specifies the dimensions of the QR code as 85 x 85. | |
IMAQ_QR_DIMENSIONS_89x89 = 89, //Specifies the dimensions of the QR code as 89 x 89. | |
IMAQ_QR_DIMENSIONS_93x93 = 93, //Specifies the dimensions of the QR code as 93 x 93. | |
IMAQ_QR_DIMENSIONS_97x97 = 97, //Specifies the dimensions of the QR code as 97 x 97. | |
IMAQ_QR_DIMENSIONS_101x101 = 101, //Specifies the dimensions of the QR code as 101 x 101. | |
IMAQ_QR_DIMENSIONS_105x105 = 105, //Specifies the dimensions of the QR code as 105 x 105. | |
IMAQ_QR_DIMENSIONS_109x109 = 109, //Specifies the dimensions of the QR code as 109 x 109. | |
IMAQ_QR_DIMENSIONS_113x113 = 113, //Specifies the dimensions of the QR code as 113 x 113. | |
IMAQ_QR_DIMENSIONS_117x117 = 117, //Specifies the dimensions of the QR code as 117 x 117. | |
IMAQ_QR_DIMENSIONS_121x121 = 121, //Specifies the dimensions of the QR code as 121 x 121. | |
IMAQ_QR_DIMENSIONS_125x125 = 125, //Specifies the dimensions of the QR code as 125 x 125. | |
IMAQ_QR_DIMENSIONS_129x129 = 129, //Specifies the dimensions of the QR code as 129 x 129. | |
IMAQ_QR_DIMENSIONS_133x133 = 133, //Specifies the dimensions of the QR code as 133 x 133. | |
IMAQ_QR_DIMENSIONS_137x137 = 137, //Specifies the dimensions of the QR code as 137 x 137. | |
IMAQ_QR_DIMENSIONS_141x141 = 141, //Specifies the dimensions of the QR code as 141 x 141. | |
IMAQ_QR_DIMENSIONS_145x145 = 145, //Specifies the dimensions of the QR code as 145 x 145. | |
IMAQ_QR_DIMENSIONS_149x149 = 149, //Specifies the dimensions of the QR code as 149 x 149. | |
IMAQ_QR_DIMENSIONS_153x153 = 153, //Specifies the dimensions of the QR code as 153 x 153. | |
IMAQ_QR_DIMENSIONS_157x157 = 157, //Specifies the dimensions of the QR code as 157 x 1537. | |
IMAQ_QR_DIMENSIONS_161x161 = 161, //Specifies the dimensions of the QR code as 161 x 161. | |
IMAQ_QR_DIMENSIONS_165x165 = 165, //Specifies the dimensions of the QR code as 165 x 165. | |
IMAQ_QR_DIMENSIONS_169x169 = 169, //Specifies the dimensions of the QR code as 169 x 169. | |
IMAQ_QR_DIMENSIONS_173x173 = 173, //Specifies the dimensions of the QR code as 173 x 173. | |
IMAQ_QR_DIMENSIONS_177x177 = 177, //Specifies the dimensions of the QR code as 177 x 177. | |
IMAQ_QR_DIMENSIONS_SIZE_GUARD = 0xFFFFFFFF | |
} QRDimensions; | |
typedef enum QRCellFilterMode_enum { | |
IMAQ_QR_CELL_FILTER_MODE_AUTO_DETECT = -2, //The function will try all filter modes and uses the one that decodes the QR code within the fewest iterations and utilizing the least amount of error correction. | |
IMAQ_QR_CELL_FILTER_MODE_AVERAGE = 0, //The function sets the pixel value for the cell to the average of the sampled pixels. | |
IMAQ_QR_CELL_FILTER_MODE_MEDIAN = 1, //The function sets the pixel value for the cell to the median of the sampled pixels. | |
IMAQ_QR_CELL_FILTER_MODE_CENTRAL_AVERAGE = 2, //The function sets the pixel value for the cell to the average of the pixels in the center of the cell sample. | |
IMAQ_QR_CELL_FILTER_MODE_HIGH_AVERAGE = 3, //The function sets the pixel value for the cell to the average value of the half of the sampled pixels with the highest pixel values. | |
IMAQ_QR_CELL_FILTER_MODE_LOW_AVERAGE = 4, //The function sets the pixel value for the cell to the average value of the half of the sampled pixels with the lowest pixel values. | |
IMAQ_QR_CELL_FILTER_MODE_VERY_HIGH_AVERAGE = 5, //The function sets the pixel value for the cell to the average value of the ninth of the sampled pixels with the highest pixel values. | |
IMAQ_QR_CELL_FILTER_MODE_VERY_LOW_AVERAGE = 6, //The function sets the pixel value for the cell to the average value of the ninth of the sampled pixels with the lowest pixel values. | |
IMAQ_QR_CELL_FILTER_MODE_ALL = 8, //The function tries each filter mode, starting with IMAQ_QR_CELL_FILTER_MODE_AVERAGE and ending with IMAQ_QR_CELL_FILTER_MODE_VERY_LOW_AVERAGE, stopping once a filter mode decodes correctly. | |
IMAQ_QR_CELL_FILTER_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRCellFilterMode; | |
typedef enum RoundingMode_enum { | |
IMAQ_ROUNDING_MODE_OPTIMIZE = 0, //Rounds the result of a division using the best available method. | |
IMAQ_ROUNDING_MODE_TRUNCATE = 1, //Truncates the result of a division. | |
IMAQ_ROUNDING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} RoundingMode; | |
typedef enum QRDemodulationMode_enum { | |
IMAQ_QR_DEMODULATION_MODE_AUTO_DETECT = -2, //The function will try each demodulation mode and use the one which decodes the QR code within the fewest iterations and utilizing the least amount of error correction. | |
IMAQ_QR_DEMODULATION_MODE_HISTOGRAM = 0, //The function uses a histogram of all of the QR cells to calculate a threshold. | |
IMAQ_QR_DEMODULATION_MODE_LOCAL_CONTRAST = 1, //The function examines each of the cell's neighbors to determine if the cell is on or off. | |
IMAQ_QR_DEMODULATION_MODE_COMBINED = 2, //The function uses the histogram of the QR code to calculate a threshold. | |
IMAQ_QR_DEMODULATION_MODE_ALL = 3, //The function tries IMAQ_QR_DEMODULATION_MODE_HISTOGRAM, then IMAQ_QR_DEMODULATION_MODE_LOCAL_CONTRAST and then IMAQ_QR_DEMODULATION_MODE_COMBINED, stopping once one mode is successful. | |
IMAQ_QR_DEMODULATION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRDemodulationMode; | |
typedef enum ContrastMode_enum { | |
IMAQ_ORIGINAL_CONTRAST = 0, //Instructs the geometric matching algorithm to find matches with the same contrast as the template. | |
IMAQ_REVERSED_CONTRAST = 1, //Instructs the geometric matching algorithm to find matches with the inverted contrast of the template. | |
IMAQ_BOTH_CONTRASTS = 2, //Instructs the geometric matching algorithm to find matches with the same and inverted contrast of the template. | |
} ContrastMode; | |
typedef enum QRPolarities_enum { | |
IMAQ_QR_POLARITY_AUTO_DETECT = -2, //The function should determine the polarity of the QR code. | |
IMAQ_QR_POLARITY_BLACK_ON_WHITE = 0, //The function should search for a QR code with dark data on a bright background. | |
IMAQ_QR_POLARITY_WHITE_ON_BLACK = 1, //The function should search for a QR code with bright data on a dark background. | |
IMAQ_QR_POLARITY_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRPolarities; | |
typedef enum QRRotationMode_enum { | |
IMAQ_QR_ROTATION_MODE_UNLIMITED = 0, //The function allows for unlimited rotation. | |
IMAQ_QR_ROTATION_MODE_0_DEGREES = 1, //The function allows for ??? 5 degrees of rotation. | |
IMAQ_QR_ROTATION_MODE_90_DEGREES = 2, //The function allows for between 85 and 95 degrees of rotation. | |
IMAQ_QR_ROTATION_MODE_180_DEGREES = 3, //The function allows for between 175 and 185 degrees of rotation. | |
IMAQ_QR_ROTATION_MODE_270_DEGREES = 4, //The function allows for between 265 and 275 degrees of rotation. | |
IMAQ_QR_ROTATION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRRotationMode; | |
typedef enum QRGradingMode_enum { | |
IMAQ_QR_NO_GRADING = 0, //The function does not make any preparatory calculations. | |
IMAQ_QR_GRADING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRGradingMode; | |
typedef enum StraightEdgeSearchMode_enum { | |
IMAQ_USE_FIRST_RAKE_EDGES = 0, //Fits a straight edge on the first points detected using a rake. | |
IMAQ_USE_BEST_RAKE_EDGES = 1, //Fits a straight edge on the best points detected using a rake. | |
IMAQ_USE_BEST_HOUGH_LINE = 2, //Finds the strongest straight edge using all points detected on a rake. | |
IMAQ_USE_FIRST_PROJECTION_EDGE = 3, //Uses the location of the first projected edge as the straight edge. | |
IMAQ_USE_BEST_PROJECTION_EDGE = 4, //Finds the strongest projected edge location to determine the straight edge. | |
IMAQ_STRAIGHT_EDGE_SEARCH_SIZE_GUARD = 0xFFFFFFFF | |
} StraightEdgeSearchMode; | |
typedef enum SearchDirection_enum { | |
IMAQ_SEARCH_DIRECTION_LEFT_TO_RIGHT = 0, //Searches from the left side of the search area to the right side of the search area. | |
IMAQ_SEARCH_DIRECTION_RIGHT_TO_LEFT = 1, //Searches from the right side of the search area to the left side of the search area. | |
IMAQ_SEARCH_DIRECTION_TOP_TO_BOTTOM = 2, //Searches from the top side of the search area to the bottom side of the search area. | |
IMAQ_SEARCH_DIRECTION_BOTTOM_TO_TOP = 3, //Searches from the bottom side of the search area to the top side of the search area. | |
IMAQ_SEARCH_DIRECTION_SIZE_GUARD = 0xFFFFFFFF | |
} SearchDirection; | |
typedef enum QRStreamMode_enum { | |
IMAQ_QR_MODE_NUMERIC = 0, //Specifies that the data was encoded using numeric mode. | |
IMAQ_QR_MODE_ALPHANUMERIC = 1, //Specifies that the data was encoded using alpha-numeric mode. | |
IMAQ_QR_MODE_RAW_BYTE = 2, //Specifies that the data was not encoded but is only raw binary bytes, or encoded in JIS-8. | |
IMAQ_QR_MODE_EAN128_TOKEN = 3, //Specifies that the data has a special meaning represented by the application ID. | |
IMAQ_QR_MODE_EAN128_DATA = 4, //Specifies that the data has a special meaning represented by the application ID. | |
IMAQ_QR_MODE_ECI = 5, //Specifies that the data was meant to be read using the language represented in the language ID. | |
IMAQ_QR_MODE_KANJI = 6, //Specifies that the data was encoded in Shift-JIS16 Japanese. | |
IMAQ_QR_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} QRStreamMode; | |
typedef enum ParticleClassifierType_enum { | |
IMAQ_PARTICLE_LARGEST = 0, //Use only the largest particle in the image. | |
IMAQ_PARTICLE_ALL = 1, //Use all particles in the image. | |
IMAQ_PARTICLE_CLASSIFIER_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ParticleClassifierType; | |
typedef enum QRCellSampleSize_enum { | |
IMAQ_QR_CELL_SAMPLE_SIZE_AUTO_DETECT = -2, //The function will try each sample size and use the one which decodes the QR code within the fewest iterations and utilizing the least amount of error correction. | |
IMAQ_QR_CELL_SAMPLE_SIZE1X1 = 1, //The function will use a 1x1 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_SIZE2X2 = 2, //The function will use a 2x2 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_SIZE3X3 = 3, //The function will use a 3x3 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_SIZE4X4 = 4, //The function will use a 4x4 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_SIZE5X5 = 5, //The function will use a 5x5 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_SIZE6X6 = 6, //The function will use a 6x6 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_SIZE7X7 = 7, //The function will use a 7x7 sized sample from each cell. | |
IMAQ_QR_CELL_SAMPLE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} QRCellSampleSize; | |
typedef enum RakeProcessType_enum { | |
IMAQ_GET_FIRST_EDGES = 0, | |
IMAQ_GET_FIRST_AND_LAST_EDGES = 1, | |
IMAQ_GET_ALL_EDGES = 2, | |
IMAQ_GET_BEST_EDGES = 3, | |
IMAQ_RAKE_PROCESS_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} RakeProcessType; | |
typedef enum GeometricSetupDataItem_enum { | |
IMAQ_CURVE_EXTRACTION_MODE = 0, //Specifies how the function identifies curves in the image. | |
IMAQ_CURVE_EDGE_THRSHOLD = 1, //Specifies the minimum contrast an edge pixel must have for it to be considered part of a curve. | |
IMAQ_CURVE_EDGE_FILTER = 2, //Specifies the width of the edge filter that the function uses to identify curves in the image. | |
IMAQ_MINIMUM_CURVE_LENGTH = 3, //Specifies the length, in pixels, of the smallest curve that you want the function to identify. | |
IMAQ_CURVE_ROW_SEARCH_STEP_SIZE = 4, //Specifies the distance, in the y direction, between the image rows that the algorithm inspects for curve seed points. | |
IMAQ_CURVE_COL_SEARCH_STEP_SIZE = 5, //Specifies the distance, in the x direction, between the image columns that the algorithm inspects for curve seed points. | |
IMAQ_CURVE_MAX_END_POINT_GAP = 6, //Specifies the maximum gap, in pixels, between the endpoints of a curve that the function identifies as a closed curve. | |
IMAQ_EXTRACT_CLOSED_CURVES = 7, //Specifies whether to identify only closed curves in the image. | |
IMAQ_ENABLE_SUBPIXEL_CURVE_EXTRACTION = 8, //The function ignores this option. | |
IMAQ_ENABLE_CORRELATION_SCORE = 9, //Specifies that the function should calculate the Correlation Score and return it for each match result. | |
IMAQ_ENABLE_SUBPIXEL_ACCURACY = 10, //Determines whether to return the match results with subpixel accuracy. | |
IMAQ_SUBPIXEL_ITERATIONS = 11, //Specifies the maximum number of incremental improvements used to refine matches using subpixel information. | |
IMAQ_SUBPIXEL_TOLERANCE = 12, //Specifies the maximum amount of change, in pixels, between consecutive incremental improvements in the match position before the function stops refining the match position. | |
IMAQ_INITIAL_MATCH_LIST_LENGTH = 13, //Specifies the maximum size of the match list. | |
IMAQ_ENABLE_TARGET_TEMPLATE_CURVESCORE = 14, //Specifies whether the function should calculate the match curve to template curve score and return it for each match result. | |
IMAQ_MINIMUM_MATCH_SEPARATION_DISTANCE = 15, //Specifies the minimum separation distance, in pixels, between the origins of two matches that have unique positions. | |
IMAQ_MINIMUM_MATCH_SEPARATION_ANGLE = 16, //Specifies the minimum angular difference, in degrees, between two matches that have unique angles. | |
IMAQ_MINIMUM_MATCH_SEPARATION_SCALE = 17, //Specifies the minimum difference in scale, expressed as a percentage, between two matches that have unique scales. | |
IMAQ_MAXIMUM_MATCH_OVERLAP = 18, //Specifies whether you want the algorithm to spend less time accurately estimating the location of a match. | |
IMAQ_ENABLE_COARSE_RESULT = 19, //Specifies whether you want the algorithm to spend less time accurately estimating the location of a match. | |
IMAQ_ENABLE_CALIBRATION_SUPPORT = 20, //Specifies whether or not the algorithm treat the inspection image as a calibrated image. | |
IMAQ_ENABLE_CONTRAST_REVERSAL = 21, //Specifies the contrast of the matches to search for. | |
IMAQ_SEARCH_STRATEGY = 22, //Specifies the aggressiveness of the strategy used to find matches in the image. | |
IMAQ_REFINEMENT_MATCH_FACTOR = 23, //Specifies the factor applied to the number of matches requested to determine how many matches are refined in the pyramid stage. | |
IMAQ_SUBPIXEL_MATCH_FACTOR = 24, //Specifies the factor applied to the number for matches requested to determine how many matches are used for the final (subpixel) stage. | |
IMAQ_MAX_REFINEMENT_ITERATIONS = 25, //Specifies maximum refinement iteration. | |
} GeometricSetupDataItem; | |
typedef enum DistortionModel_enum { | |
IMAQ_POLYNOMIAL_MODEL = 0, //Polynomial model. | |
IMAQ_DIVISION_MODEL = 1, //Division Model. | |
IMAQ_NO_DISTORTION_MODEL = -1, //Not a distortion model. | |
} DistortionModel; | |
typedef enum CalibrationThumbnailType_enum { | |
IMAQ_CAMARA_MODEL_TYPE = 0, //Camara model thumbnail type. | |
IMAQ_PERSPECTIVE_TYPE = 1, //Perspective thumbnail type. | |
IMAQ_MICRO_PLANE_TYPE = 2, //Micro Plane thumbnail type. | |
IMAQ_CALIBRATION_THUMBNAIL_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} CalibrationThumbnailType; | |
typedef enum SettingType_enum { | |
IMAQ_ROTATION_ANGLE_RANGE = 0, //Set a range for this option to specify the angles at which you expect the Function to find template matches in the inspection image. | |
IMAQ_SCALE_RANGE = 1, //Set a range for this option to specify the sizes at which you expect the Function to find template matches in the inspection image. | |
IMAQ_OCCLUSION_RANGE = 2, //Set a range for this option to specify the amount of occlusion you expect for a match in the inspection image. | |
IMAQ_SETTING_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} SettingType; | |
typedef enum SegmentationDistanceLevel_enum { | |
IMAQ_SEGMENTATION_LEVEL_CONSERVATIVE = 0, //Uses extensive criteria to determine the Maximum Distance. | |
IMAQ_SEGMENTATION_LEVEL_AGGRESSIVE = 1, //Uses few criteria to determine the Maximum Distance. | |
IMAQ_SEGMENTATION_LEVEL_SIZE_GUARD = 0xFFFFFFFF | |
} SegmentationDistanceLevel; | |
typedef enum ExtractContourSelection_enum { | |
IMAQ_CLOSEST = 0, //Selects the curve closest to the ROI. | |
IMAQ_LONGEST = 1, //Selects the longest curve. | |
IMAQ_STRONGEST = 2, //Selects the curve with the highest edge strength averaged from each point on the curve. | |
IMAQ_EXTRACT_CONTOUR_SELECTION_SIZE_GUARD = 0xFFFFFFFF | |
} ExtractContourSelection; | |
typedef enum FindTransformMode_enum { | |
IMAQ_FIND_REFERENCE = 0, //Update both parts of the coordinate system. | |
IMAQ_UPDATE_TRANSFORM = 1, //Update only the new reference system. | |
IMAQ_FIND_TRANSFORM_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} FindTransformMode; | |
typedef enum ExtractContourDirection_enum { | |
IMAQ_RECT_LEFT_RIGHT = 0, //Searches the ROI from left to right. | |
IMAQ_RECT_RIGHT_LEFT = 1, //Searches the ROI from right to left. | |
IMAQ_RECT_TOP_BOTTOM = 2, //Searches the ROI from top to bottom. | |
IMAQ_RECT_BOTTOM_TOP = 3, //Searches the ROI from bottom to top. | |
IMAQ_ANNULUS_INNER_OUTER = 4, //Searches the ROI from the inner radius to the outer radius. | |
IMAQ_ANNULUS_OUTER_INNER = 5, //Searches the ROI from the outer radius to the inner radius. | |
IMAQ_ANNULUS_START_STOP = 6, //Searches the ROI from start angle to end angle. | |
IMAQ_ANNULUS_STOP_START = 7, //Searches the ROI from end angle to start angle. | |
IMAQ_EXTRACT_CONTOUR_DIRECTION_SIZE_GUARD = 0xFFFFFFFF | |
} ExtractContourDirection; | |
typedef enum EdgePolaritySearchMode_enum { | |
IMAQ_SEARCH_FOR_ALL_EDGES = 0, //Searches for all edges. | |
IMAQ_SEARCH_FOR_RISING_EDGES = 1, //Searches for rising edges only. | |
IMAQ_SEARCH_FOR_FALLING_EDGES = 2, //Searches for falling edges only. | |
IMAQ_EDGE_POLARITY_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} EdgePolaritySearchMode; | |
typedef enum Connectivity_enum { | |
IMAQ_FOUR_CONNECTED = 0, //Morphological reconstruction is performed in connectivity mode 4. | |
IMAQ_EIGHT_CONNECTED = 1, //Morphological reconstruction is performed in connectivity mode 8. | |
IMAQ_CONNECTIVITY_SIZE_GUARD = 0xFFFFFFFF | |
} Connectivity; | |
typedef enum MorphologyReconstructOperation_enum { | |
IMAQ_DILATE_RECONSTRUCT = 0, //Performs Reconstruction by dilation. | |
IMAQ_ERODE_RECONSTRUCT = 1, //Performs Reconstruction by erosion. | |
IMAQ_MORPHOLOGY_RECONSTRUCT_OPERATION_SIZE_GUARD = 0xFFFFFFFF | |
} MorphologyReconstructOperation; | |
typedef enum WaveletType_enum { | |
IMAQ_DB02 = 0, | |
IMAQ_DB03 = 1, | |
IMAQ_DB04 = 2, //Specifies the Wavelet Type as DB02. | |
IMAQ_DB05 = 3, | |
IMAQ_DB06 = 4, | |
IMAQ_DB07 = 5, | |
IMAQ_DB08 = 6, | |
IMAQ_DB09 = 7, | |
IMAQ_DB10 = 8, | |
IMAQ_DB11 = 9, | |
IMAQ_DB12 = 10, | |
IMAQ_DB13 = 11, | |
IMAQ_DB14 = 12, | |
IMAQ_HAAR = 13, | |
IMAQ_BIOR1_3 = 14, | |
IMAQ_BIOR1_5 = 15, | |
IMAQ_BIOR2_2 = 16, | |
IMAQ_BIOR2_4 = 17, | |
IMAQ_BIOR2_6 = 18, | |
IMAQ_BIOR2_8 = 19, | |
IMAQ_BIOR3_1 = 20, | |
IMAQ_BIOR3_3 = 21, | |
IMAQ_BIOR3_5 = 22, | |
IMAQ_BIOR3_7 = 23, | |
IMAQ_BIOR3_9 = 24, | |
IMAQ_BIOR4_4 = 25, | |
IMAQ_COIF1 = 26, | |
IMAQ_COIF2 = 27, | |
IMAQ_COIF3 = 28, | |
IMAQ_COIF4 = 29, | |
IMAQ_COIF5 = 30, | |
IMAQ_SYM2 = 31, | |
IMAQ_SYM3 = 32, | |
IMAQ_SYM4 = 33, | |
IMAQ_SYM5 = 34, | |
IMAQ_SYM6 = 35, | |
IMAQ_SYM7 = 36, | |
IMAQ_SYM8 = 37, | |
IMAQ_BIOR5_5 = 38, | |
IMAQ_BIOR6_8 = 39, | |
IMAQ_WAVE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} WaveletType; | |
typedef enum ParticleClassifierThresholdType_enum { | |
IMAQ_THRESHOLD_MANUAL = 0, //The classifier performs a manual threshold on the image during preprocessing. | |
IMAQ_THRESHOLD_AUTO = 1, //The classifier performs an auto threshold on the image during preprocessing. | |
IMAQ_THRESHOLD_LOCAL = 2, //The classifier performs a local threshold on the image during preprocessing. | |
} ParticleClassifierThresholdType; | |
typedef enum MeasureParticlesCalibrationMode_enum { | |
IMAQ_CALIBRATION_MODE_PIXEL = 0, //The function takes only pixel measurements on the particles in the image. | |
IMAQ_CALIBRATION_MODE_CALIBRATED = 1, //The function takes only calibrated measurements on the particles in the image. | |
IMAQ_CALIBRATION_MODE_BOTH = 2, //The function takes both pixel and calibrated measurements on the particles in the image. | |
IMAQ_MEASURE_PARTICLES_CALIBRATION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} MeasureParticlesCalibrationMode; | |
typedef enum GeometricMatchingSearchStrategy_enum { | |
IMAQ_GEOMETRIC_MATCHING_CONSERVATIVE = 0, //Instructs the pattern matching algorithm to use the largest possible amount of information from the image at the expense of slowing down the speed of the algorithm. | |
IMAQ_GEOMETRIC_MATCHING_BALANCED = 1, //Instructs the pattern matching algorithm to balance the amount of information from the image it uses with the speed of the algorithm. | |
IMAQ_GEOMETRIC_MATCHING_AGGRESSIVE = 2, //Instructs the pattern matching algorithm to use a lower amount of information from the image, which allows the algorithm to run quickly but at the expense of accuracy. | |
IMAQ_GEOMETRIC_MATCHING_SEARCH_STRATEGY_SIZE_GUARD = 0xFFFFFFFF | |
} GeometricMatchingSearchStrategy; | |
typedef enum ColorClassificationResolution_enum { | |
IMAQ_CLASSIFIER_LOW_RESOLUTION = 0, //Low resolution version of the color classifier. | |
IMAQ_CLASSIFIER_MEDIUM_RESOLUTION = 1, //Medium resolution version of the color classifier. | |
IMAQ_CLASSIFIER_HIGH_RESOLUTION = 2, //High resolution version of the color classifier. | |
IMAQ_CLASSIFIER_RESOLUTION_SIZE_GUARD = 0xFFFFFFFF | |
} ColorClassificationResolution; | |
typedef enum ConnectionConstraintType_enum { | |
IMAQ_DISTANCE_CONSTRAINT = 0, //Specifies the distance, in pixels, within which the end points of two curves must lie in order to be considered part of a contour. | |
IMAQ_ANGLE_CONSTRAINT = 1, //Specifies the range, in degrees, within which the difference between the angle of two curves, measured at the end points, must lie in order for the two curves to be considered part of a contour. | |
IMAQ_CONNECTIVITY_CONSTRAINT = 2, //Specifies the distance, in pixels, within which a line extended from the end point of a curve must pass the end point of another curve in order for the two curves to be considered part of a contour. | |
IMAQ_GRADIENT_CONSTRAINT = 3, //Specifies the range, in degrees, within which the gradient angles of two curves, measured at the end points, must lie in order for the two curves to be considered part of a contour. | |
IMAQ_NUM_CONNECTION_CONSTRAINT_TYPES = 4, //. | |
IMAQ_CONNECTION_CONSTRAINT_SIZE_GUARD = 0xFFFFFFFF | |
} ConnectionConstraintType; | |
typedef enum Barcode2DContrast_enum { | |
IMAQ_ALL_BARCODE_2D_CONTRASTS = 0, //The function searches for barcodes of each contrast type. | |
IMAQ_BLACK_ON_WHITE_BARCODE_2D = 1, //The function searches for 2D barcodes containing black data on a white background. | |
IMAQ_WHITE_ON_BLACK_BARCODE_2D = 2, //The function searches for 2D barcodes containing white data on a black background. | |
IMAQ_BARCODE_2D_CONTRAST_SIZE_GUARD = 0xFFFFFFFF | |
} Barcode2DContrast; | |
typedef enum QRModelType_enum { | |
IMAQ_QR_MODELTYPE_AUTO_DETECT = 0, //Specifies that the function will auto-detect the type of QR code. | |
IMAQ_QR_MODELTYPE_MICRO = 1, //Specifies the QR code is of a micro type. | |
IMAQ_QR_MODELTYPE_MODEL1 = 2, //Specifies the QR code is of a model1 type. | |
IMAQ_QR_MODELTYPE_MODEL2 = 3, //Specifies the QR code is of a model2 type. | |
IMAQ_QR_MODEL_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} QRModelType; | |
typedef enum WindowBackgroundFillStyle_enum { | |
IMAQ_FILL_STYLE_SOLID = 0, //Fill the display window with a solid color. | |
IMAQ_FILL_STYLE_HATCH = 2, //Fill the display window with a pattern defined by WindowBackgroundHatchStyle. | |
IMAQ_FILL_STYLE_DEFAULT = 3, //Fill the display window with the NI Vision default pattern. | |
IMAQ_FILL_STYLE_SIZE_GUARD = 0xFFFFFFFF | |
} WindowBackgroundFillStyle; | |
typedef enum ExtractionMode_enum { | |
IMAQ_NORMAL_IMAGE = 0, //Specifies that the function makes no assumptions about the uniformity of objects in the image or the image background. | |
IMAQ_UNIFORM_REGIONS = 1, //Specifies that the function assumes that either the objects in the image or the image background consists of uniform pixel values. | |
IMAQ_EXTRACTION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} ExtractionMode; | |
typedef enum EdgeFilterSize_enum { | |
IMAQ_FINE = 0, //Specifies that the function uses a fine (narrow) edge filter. | |
IMAQ_NORMAL = 1, //Specifies that the function uses a normal edge filter. | |
IMAQ_CONTOUR_TRACING = 2, //Sets the Edge Filter Size to contour tracing, which provides the best results for contour extraction but increases the time required to process the image. | |
IMAQ_EDGE_FILTER_SIZE_SIZE_GUARD = 0xFFFFFFFF | |
} EdgeFilterSize; | |
typedef enum Barcode2DSearchMode_enum { | |
IMAQ_SEARCH_MULTIPLE = 0, //The function searches for multiple 2D barcodes. | |
IMAQ_SEARCH_SINGLE_CONSERVATIVE = 1, //The function searches for 2D barcodes using the same searching algorithm as IMAQ_SEARCH_MULTIPLE but stops searching after locating one valid barcode. | |
IMAQ_SEARCH_SINGLE_AGGRESSIVE = 2, //The function searches for a single 2D barcode using a method that assumes the barcode occupies a majority of the search region. | |
IMAQ_BARCODE_2D_SEARCH_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} Barcode2DSearchMode; | |
typedef enum DataMatrixSubtype_enum { | |
IMAQ_ALL_DATA_MATRIX_SUBTYPES = 0, //The function searches for Data Matrix barcodes of all subtypes. | |
IMAQ_DATA_MATRIX_SUBTYPES_ECC_000_ECC_140 = 1, //The function searches for Data Matrix barcodes of subtypes ECC 000, ECC 050, ECC 080, ECC 100 and ECC 140. | |
IMAQ_DATA_MATRIX_SUBTYPE_ECC_200 = 2, //The function searches for Data Matrix ECC 200 barcodes. | |
IMAQ_DATA_MATRIX_SUBTYPE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixSubtype; | |
typedef enum FeatureType_enum { | |
IMAQ_NOT_FOUND_FEATURE = 0, //Specifies the feature is not found. | |
IMAQ_CIRCLE_FEATURE = 1, //Specifies the feature is a circle. | |
IMAQ_ELLIPSE_FEATURE = 2, //Specifies the feature is an ellipse. | |
IMAQ_CONST_CURVE_FEATURE = 3, //Specifies the features is a constant curve. | |
IMAQ_RECTANGLE_FEATURE = 4, //Specifies the feature is a rectangle. | |
IMAQ_LEG_FEATURE = 5, //Specifies the feature is a leg. | |
IMAQ_CORNER_FEATURE = 6, //Specifies the feature is a corner. | |
IMAQ_PARALLEL_LINE_PAIR_FEATURE = 7, //Specifies the feature is a parallel line pair. | |
IMAQ_PAIR_OF_PARALLEL_LINE_PAIRS_FEATURE = 8, //Specifies the feature is a pair of parallel line pairs. | |
IMAQ_LINE_FEATURE = 9, //Specifies the feature is a line. | |
IMAQ_CLOSED_CURVE_FEATURE = 10, //Specifies the feature is a closed curve. | |
IMAQ_FEATURE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} FeatureType; | |
typedef enum Barcode2DCellShape_enum { | |
IMAQ_SQUARE_CELLS = 0, //The function uses an algorithm for decoding the 2D barcode that works with square data cells. | |
IMAQ_ROUND_CELLS = 1, //The function uses an algorithm for decoding the 2D barcode that works with round data cells. | |
IMAQ_BARCODE_2D_CELL_SHAPE_SIZE_GUARD = 0xFFFFFFFF | |
} Barcode2DCellShape; | |
typedef enum LocalThresholdMethod_enum { | |
IMAQ_NIBLACK = 0, //The function computes thresholds for each pixel based on its local statistics using the Niblack local thresholding algorithm. | |
IMAQ_BACKGROUND_CORRECTION = 1, //The function performs background correction first to eliminate non-uniform lighting effects, then performs thresholding using the Otsu thresholding algorithm. | |
IMAQ_LOCAL_THRESHOLD_METHOD_SIZE_GUARD = 0xFFFFFFFF | |
} LocalThresholdMethod; | |
typedef enum Barcode2DType_enum { | |
IMAQ_PDF417 = 0, //The 2D barcode is of type PDF417. | |
IMAQ_DATA_MATRIX_ECC_000 = 1, //The 2D barcode is of type Data Matrix ECC 000. | |
IMAQ_DATA_MATRIX_ECC_050 = 2, //The 2D barcode is of type Data Matrix ECC 050. | |
IMAQ_DATA_MATRIX_ECC_080 = 3, //The 2D barcode is of type Data Matrix ECC 080. | |
IMAQ_DATA_MATRIX_ECC_100 = 4, //The 2D barcode is of type Data Matrix ECC 100. | |
IMAQ_DATA_MATRIX_ECC_140 = 5, //The 2D barcode is of type Data Matrix ECC 140. | |
IMAQ_DATA_MATRIX_ECC_200 = 6, //The 2D barcode is of type Data Matrix ECC 200. | |
IMAQ_BARCODE_2D_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} Barcode2DType; | |
typedef enum ClassifierEngineType_enum { | |
IMAQ_ENGINE_NONE = 0, //No engine has been set on this classifier session. | |
IMAQ_ENGINE_NEAREST_NEIGHBOR = 1, //Nearest neighbor engine. | |
IMAQ_ENGINE_SUPPORT_VECTOR_MACHINE = 2, | |
IMAQ_CLASSIFIER_ENGINE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ClassifierEngineType; | |
typedef enum ClassifierType_enum { | |
IMAQ_CLASSIFIER_CUSTOM = 0, //The classifier session classifies vectors of doubles. | |
IMAQ_CLASSIFIER_PARTICLE = 1, //The classifier session classifies particles in binary images. | |
IMAQ_CLASSIFIER_COLOR = 2, //The classifier session classifies an image based on its color. | |
IMAQ_CLASSIFIER_TEXTURE = 3, //The classifier session classifies an image based on its texture. | |
IMAQ_CLASSIFIER_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ClassifierType; | |
typedef enum ParticleType_enum { | |
IMAQ_PARTICLE_BRIGHT = 0, //Bright particles. | |
IMAQ_PARTICLE_DARK = 1, //Dark particles. | |
IMAQ_PARTICLE_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} ParticleType; | |
typedef enum VisionInfoType2_enum { | |
IMAQ_VISIONINFO_CALIBRATION = 0x01, //Used to indicate interaction with the Calibration information in an image. | |
IMAQ_VISIONINFO_OVERLAY = 0x02, //Used to indicate interaction with the Overlay information in an image. | |
IMAQ_VISIONINFO_GRAYTEMPLATE = 0x04, //Used to indicate interaction with the grayscale template information in an image. | |
IMAQ_VISIONINFO_COLORTEMPLATE = 0x08, //Used to indicate interaction with the color template information in an image. | |
IMAQ_VISIONINFO_GEOMETRICTEMPLATE = 0x10, //Used to indicate interaction with the geometric template information in an image. | |
IMAQ_VISIONINFO_CUSTOMDATA = 0x20, //Used to indicate interaction with the binary or text Custom Data in an image. | |
IMAQ_VISIONINFO_GOLDENTEMPLATE = 0x40, //Used to indicate interaction with the golden template information in an image. | |
IMAQ_VISIONINFO_GEOMETRICTEMPLATE2 = 0x80, //Used to indicate interaction with the geometric template 2 information in an image. | |
IMAQ_VISIONINFO_ALL = 0xFFFFFFFF, //Removes, checks for, or indicates the presence of all types of extra information in an image. | |
} VisionInfoType2; | |
typedef enum ReadClassifierFileMode_enum { | |
IMAQ_CLASSIFIER_READ_ALL = 0, //Read all information from the classifier file. | |
IMAQ_CLASSIFIER_READ_SAMPLES = 1, //Read only the samples from the classifier file. | |
IMAQ_CLASSIFIER_READ_PROPERTIES = 2, //Read only the properties from the classifier file. | |
IMAQ_READ_CLASSIFIER_FILE_MODES_SIZE_GUARD = 0xFFFFFFFF | |
} ReadClassifierFileMode; | |
typedef enum WriteClassifierFileMode_enum { | |
IMAQ_CLASSIFIER_WRITE_ALL = 0, //Writes all information to the classifier file. | |
IMAQ_CLASSIFIER_WRITE_CLASSIFY_ONLY = 1, //Write only the information needed to classify to the classifier file. | |
IMAQ_WRITE_CLASSIFIER_FILE_MODES_SIZE_GUARD = 0xFFFFFFFF | |
} WriteClassifierFileMode; | |
typedef enum Barcode2DShape_enum { | |
IMAQ_SQUARE_BARCODE_2D = 0, //The function searches for square 2D barcodes. | |
IMAQ_RECTANGULAR_BARCODE_2D = 1, //The function searches for rectangular 2D barcodes. | |
IMAQ_BARCODE_2D_SHAPE_SIZE_GUARD = 0xFFFFFFFF | |
} Barcode2DShape; | |
typedef enum DataMatrixRotationMode_enum { | |
IMAQ_UNLIMITED_ROTATION = 0, //The function allows for unlimited rotation. | |
IMAQ_0_DEGREES = 1, //The function allows for between -5 and 5 degrees of rotation. | |
IMAQ_90_DEGREES = 2, //The function allows for between 85 and 95 degrees of rotation. | |
IMAQ_180_DEGREES = 3, //The function allows for between 175 and 185 degrees of rotation. | |
IMAQ_270_DEGREES = 4, //The function allows for between 265 and 275 degrees of rotation. | |
IMAQ_DATA_MATRIX_ROTATION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixRotationMode; | |
typedef enum AIMGrade_enum { | |
IMAQ_AIM_GRADE_F = 0, //The Data Matrix barcode received a grade of F. | |
IMAQ_AIM_GRADE_D = 1, //The Data Matrix barcode received a grade of D. | |
IMAQ_AIM_GRADE_C = 2, //The Data Matrix barcode received a grade of C. | |
IMAQ_AIM_GRADE_B = 3, //The Data Matrix barcode received a grade of B. | |
IMAQ_AIM_GRADE_A = 4, //The Data Matrix barcode received a grade of A. | |
IMAQ_DATA_MATRIX_AIM_GRADE_SIZE_GUARD = 0xFFFFFFFF | |
} AIMGrade; | |
typedef enum DataMatrixCellFillMode_enum { | |
IMAQ_AUTO_DETECT_CELL_FILL_MODE = -2, //Sets the function to determine the Data Matrix barcode cell fill percentage automatically. | |
IMAQ_LOW_FILL = 0, //Sets the function to read Data Matrix barcodes with a cell fill percentage of less than 30 percent. | |
IMAQ_NORMAL_FILL = 1, //Sets the function to read Data Matrix barcodes with a cell fill percentage greater than or equal to 30 percent. | |
IMAQ_DATA_MATRIX_CELL_FILL_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixCellFillMode; | |
typedef enum DataMatrixDemodulationMode_enum { | |
IMAQ_AUTO_DETECT_DEMODULATION_MODE = -2, //The function will try each demodulation mode and use the one which decodes the Data Matrix barcode within the fewest iterations and utilizing the least amount of error correction. | |
IMAQ_HISTOGRAM = 0, //The function uses a histogram of all of the Data Matrix cells to calculate a threshold. | |
IMAQ_LOCAL_CONTRAST = 1, //The function examines each of the cell's neighbors to determine if the cell is on or off. | |
IMAQ_COMBINED = 2, //The function uses the histogram of the Data Matrix barcode to calculate a threshold. | |
IMAQ_ALL_DEMODULATION_MODES = 3, //The function tries IMAQ_HISTOGRAM, then IMAQ_LOCAL_CONTRAST and then IMAQ_COMBINATION, stopping once one mode is successful. | |
IMAQ_DATA_MATRIX_DEMODULATION_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixDemodulationMode; | |
typedef enum DataMatrixECC_enum { | |
IMAQ_AUTO_DETECT_ECC = -2, //Sets the function to determine the Data Matrix barcode ECC automatically. | |
IMAQ_ECC_000 = 0, //Sets the function to read Data Matrix barcodes of ECC 000 only. | |
IMAQ_ECC_050 = 50, //Sets the function to read Data Matrix barcodes of ECC 050 only. | |
IMAQ_ECC_080 = 80, //Sets the function to read Data Matrix barcodes of ECC 080 only. | |
IMAQ_ECC_100 = 100, //Sets the function to read Data Matrix barcodes of ECC 100 only. | |
IMAQ_ECC_140 = 140, //Sets the function to read Data Matrix barcodes of ECC 140 only. | |
IMAQ_ECC_000_140 = 190, //Sets the function to read Data Matrix barcodes of ECC 000, ECC 050, ECC 080, ECC 100, and ECC 140 only. | |
IMAQ_ECC_200 = 200, //Sets the function to read Data Matrix barcodes of ECC 200 only. | |
IMAQ_DATA_MATRIX_ECC_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixECC; | |
typedef enum DataMatrixPolarity_enum { | |
IMAQ_AUTO_DETECT_POLARITY = -2, //Sets the function to determine the Data Matrix barcode polarity automatically. | |
IMAQ_BLACK_DATA_ON_WHITE_BACKGROUND = 0, //Sets the function to read Data Matrix barcodes with dark data on a bright background. | |
IMAQ_WHITE_DATA_ON_BLACK_BACKGROUND = 1, //Sets the function to read Data Matrix barcodes with bright data on a dark background. | |
IMAQ_DATA_MATRIX_POLARITY_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixPolarity; | |
typedef enum DataMatrixCellFilterMode_enum { | |
IMAQ_AUTO_DETECT_CELL_FILTER_MODE = -2, //The function will try all filter modes and uses the one that decodes the Data Matrix barcode within the fewest iterations and utilizing the least amount of error correction. | |
IMAQ_AVERAGE_FILTER = 0, //The function sets the pixel value for the cell to the average of the sampled pixels. | |
IMAQ_MEDIAN_FILTER = 1, //The function sets the pixel value for the cell to the median of the sampled pixels. | |
IMAQ_CENTRAL_AVERAGE_FILTER = 2, //The function sets the pixel value for the cell to the average of the pixels in the center of the cell sample. | |
IMAQ_HIGH_AVERAGE_FILTER = 3, //The function sets the pixel value for the cell to the average value of the half of the sampled pixels with the highest pixel values. | |
IMAQ_LOW_AVERAGE_FILTER = 4, //The function sets the pixel value for the cell to the average value of the half of the sampled pixels with the lowest pixel values. | |
IMAQ_VERY_HIGH_AVERAGE_FILTER = 5, //The function sets the pixel value for the cell to the average value of the ninth of the sampled pixels with the highest pixel values. | |
IMAQ_VERY_LOW_AVERAGE_FILTER = 6, //The function sets the pixel value for the cell to the average value of the ninth of the sampled pixels with the lowest pixel values. | |
IMAQ_ALL_CELL_FILTERS = 8, //The function tries each filter mode, starting with IMAQ_AVERAGE_FILTER and ending with IMAQ_VERY_LOW_AVERAGE_FILTER, stopping once a filter mode decodes correctly. | |
IMAQ_DATA_MATRIX_CELL_FILTER_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixCellFilterMode; | |
typedef enum WindowBackgroundHatchStyle_enum { | |
IMAQ_HATCH_STYLE_HORIZONTAL = 0, //The background of the display window will be horizontal bars. | |
IMAQ_HATCH_STYLE_VERTICAL = 1, //The background of the display window will be vertical bars. | |
IMAQ_HATCH_STYLE_FORWARD_DIAGONAL = 2, //The background of the display window will be diagonal bars. | |
IMAQ_HATCH_STYLE_BACKWARD_DIAGONAL = 3, //The background of the display window will be diagonal bars. | |
IMAQ_HATCH_STYLE_CROSS = 4, //The background of the display window will be intersecting horizontal and vertical bars. | |
IMAQ_HATCH_STYLE_CROSS_HATCH = 5, //The background of the display window will be intersecting forward and backward diagonal bars. | |
IMAQ_HATCH_STYLE_SIZE_GUARD = 0xFFFFFFFF | |
} WindowBackgroundHatchStyle; | |
typedef enum DataMatrixMirrorMode_enum { | |
IMAQ_AUTO_DETECT_MIRROR = -2, //Specifies that the function should determine if the Data Matrix barcode is mirrored. | |
IMAQ_APPEARS_NORMAL = 0, //Specifies that the function should expect the Data Matrix barcode to appear normal. | |
IMAQ_APPEARS_MIRRORED = 1, //Specifies that the function should expect the Data Matrix barcode to appear mirrored. | |
IMAQ_DATA_MATRIX_MIRROR_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixMirrorMode; | |
typedef enum CalibrationMode2_enum { | |
IMAQ_PERSPECTIVE_MODE = 0, //Functions correct for distortion caused by the camera's perspective. | |
IMAQ_MICROPLANE_MODE = 1, //Functions correct for distortion caused by the camera's lens. | |
IMAQ_SIMPLE_CALIBRATION_MODE = 2, //Functions do not correct for distortion. | |
IMAQ_CORRECTED_IMAGE_MODE = 3, //The image is already corrected. | |
IMAQ_NO_CALIBRATION_MODE = 4, //Image with No calibration. | |
IMAQ_CALIBRATION_MODE2_SIZE_GUARD = 0xFFFFFFFF | |
} CalibrationMode2; | |
typedef enum DataMatrixGradingMode_enum { | |
IMAQ_NO_GRADING = 0, //The function does not make any preparatory calculations. | |
IMAQ_PREPARE_FOR_AIM = 1, //The function prepares the image for grading using the AIM Print Quality metrics. | |
IMAQ_DATA_MATRIX_GRADING_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixGradingMode; | |
typedef enum WaveletTransformMode_enum { | |
IMAQ_WAVELET_TRANSFORM_INTEGER = 0, //Uses a 5-3 reversible integer transform. | |
IMAQ_WAVELET_TRANSFORM_FLOATING_POINT = 1, //Performs a 9-7 irreversible floating-point transform. | |
IMAQ_WAVELET_TRANSFORM_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} WaveletTransformMode; | |
typedef enum NormalizationMethod_enum { | |
IMAQ_NORMALIZATION_NONE = 0, //No normalization. | |
IMAQ_NORMALIZATION_HISTOGRAM_MATCHING = 1, //Adjust image so its histogram is similar to the golden template's histogram. | |
IMAQ_NORMALIZATION_AVERAGE_MATCHING = 2, //Adjust image so its mean pixel value equals the golden template's mean pixel value. | |
IMAQ_NORMALIZATION_SIZE_GUARD = 0xFFFFFFFF | |
} NormalizationMethod; | |
typedef enum RegistrationMethod_enum { | |
IMAQ_REGISTRATION_NONE = 0, //No registration. | |
IMAQ_REGISTRATION_PERSPECTIVE = 1, //Adjust image to correct for minor variations in alignment or perspective. | |
IMAQ_REGISTRATION_SIZE_GUARD = 0xFFFFFFFF | |
} RegistrationMethod; | |
typedef enum LinearAveragesMode_enum { | |
IMAQ_COLUMN_AVERAGES = 1, //Specifies that the function calculates the mean pixel value of each column. | |
IMAQ_ROW_AVERAGES = 2, //Specifies that the function calculates the mean pixel value of each row. | |
IMAQ_RISING_DIAGONAL_AVERAGES = 4, //Specifies that the function calculates the mean pixel value of each diagonal running from the lower left to the upper right of the inspected area of the image. | |
IMAQ_FALLING_DIAGONAL_AVERAGES = 8, //Specifies that the function calculates the mean pixel value of each diagonal running from the upper left to the lower right of the inspected area of the image. | |
IMAQ_ALL_LINEAR_AVERAGES = 15, //Specifies that the function calculates all four linear mean pixel values. | |
IMAQ_LINEAR_AVERAGES_MODE_SIZE_GUARD = 0xFFFFFFFF | |
} LinearAveragesMode; | |
typedef enum CompressionType_enum { | |
IMAQ_COMPRESSION_NONE = 0, //Specifies that the function should not compress the image. | |
IMAQ_COMPRESSION_JPEG = 1, //Specifies that the function should use lossy JPEG compression on the image. | |
IMAQ_COMPRESSION_PACKED_BINARY = 2, //Specifies that the function should use lossless binary packing on the image. | |
IMAQ_COMPRESSION_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} CompressionType; | |
typedef enum FlattenType_enum { | |
IMAQ_FLATTEN_IMAGE = 0, //Flattens just the image data. | |
IMAQ_FLATTEN_IMAGE_AND_VISION_INFO = 1, //Flattens the image data and any Vision information associated with the image. | |
IMAQ_FLATTEN_TYPE_SIZE_GUARD = 0xFFFFFFFF | |
} FlattenType; | |
typedef enum DataMatrixCellSampleSize_enum { | |
IMAQ_AUTO_DETECT_CELL_SAMPLE_SIZE = -2, //The function will try each sample size and use the one which decodes the Data Matrix barcode within the fewest iterations and utilizing the least amount of error correction. | |
IMAQ_1x1 = 1, //The function will use a 1x1 sized sample from each cell. | |
IMAQ_2x2 = 2, //The function will use a 2x2 sized sample from each cell. | |
IMAQ_3x3 = 3, //The function will use a 3x3 sized sample from each cell. | |
IMAQ_4x4 = 4, //The function will use a 4x4 sized sample from each cell. | |
IMAQ_5x5 = 5, //The function will use a 5x5 sized sample from each cell. | |
IMAQ_6x6 = 6, //The function will use a 6x6 sized sample from each cell. | |
IMAQ_7x7 = 7, //The function will use a 7x7 sized sample from each cell. | |
IMAQ_DATA_MATRIX_CELL_SAMPLE_SIZE_SIZE_GUARD = 0xFFFFFFFF | |
} DataMatrixCellSampleSize; | |
//============================================================================ | |
// Forward Declare Data Structures | |
//============================================================================ | |
typedef struct Image_struct Image; | |
typedef struct ROI_struct ROI; | |
typedef struct Overlay_struct Overlay; | |
typedef struct ClassifierSession_struct ClassifierSession; | |
typedef struct MultipleGeometricPattern_struct MultipleGeometricPattern; | |
typedef int ContourID; | |
typedef unsigned long SESSION_ID; | |
typedef int AVISession; | |
typedef char* FilterName; | |
typedef char String255[256]; | |
typedef struct CharSet_struct CharSet; | |
typedef struct OCRSpacingOptions_struct OCRSpacingOptions; | |
typedef struct OCRProcessingOptions_struct OCRProcessingOptions; | |
typedef struct ReadTextOptions_struct ReadTextOptions; | |
typedef struct CharInfo_struct CharInfo; | |
typedef struct CharReport_struct CharReport; | |
typedef struct ReadTextReport_struct ReadTextReport; | |
typedef struct DivisionModel_struct DivisionModel; | |
typedef struct FocalLength_struct FocalLength; | |
typedef struct PolyModel_struct PolyModel; | |
typedef struct DistortionModelParams_struct DistortionModelParams; | |
typedef struct PointFloat_struct PointFloat; | |
typedef struct InternalParameters_struct InternalParameters; | |
typedef struct MaxGridSize_struct MaxGridSize; | |
typedef struct ImageSize_struct ImageSize; | |
typedef struct CalibrationReferencePoints_struct CalibrationReferencePoints; | |
typedef struct GetCameraParametersReport_struct GetCameraParametersReport; | |
typedef struct CalibrationAxisInfo_struct CalibrationAxisInfo; | |
typedef struct CalibrationLearnSetupInfo_struct CalibrationLearnSetupInfo; | |
typedef struct GridDescriptor_struct GridDescriptor; | |
typedef struct ErrorStatistics_struct ErrorStatistics; | |
typedef struct GetCalibrationInfoReport_struct GetCalibrationInfoReport; | |
typedef struct EdgePolarity_struct EdgePolarity; | |
typedef struct ClampSettings_struct ClampSettings; | |
typedef struct PointDouble_struct PointDouble; | |
typedef struct PointDoublePair_struct PointDoublePair; | |
typedef struct ClampResults_struct ClampResults; | |
typedef struct ClampPoints_struct ClampPoints; | |
typedef struct RGBValue_struct RGBValue; | |
typedef struct ClampOverlaySettings_struct ClampOverlaySettings; | |
typedef struct ClampMax2Report_struct ClampMax2Report; | |
typedef struct ContourFitSplineReport_struct ContourFitSplineReport; | |
typedef struct LineFloat_struct LineFloat; | |
typedef struct LineEquation_struct LineEquation; | |
typedef struct ContourFitLineReport_struct ContourFitLineReport; | |
typedef struct ContourFitPolynomialReport_struct ContourFitPolynomialReport; | |
typedef struct PartialCircle_struct PartialCircle; | |
typedef struct PartialEllipse_struct PartialEllipse; | |
typedef struct SetupMatchPatternData_struct SetupMatchPatternData; | |
typedef struct RangeSettingDouble_struct RangeSettingDouble; | |
typedef struct GeometricAdvancedSetupDataOption_struct GeometricAdvancedSetupDataOption; | |
typedef struct ContourInfoReport_struct ContourInfoReport; | |
typedef struct ROILabel_struct ROILabel; | |
typedef struct SupervisedColorSegmentationReport_struct SupervisedColorSegmentationReport; | |
typedef struct LabelToROIReport_struct LabelToROIReport; | |
typedef struct ColorSegmenationOptions_struct ColorSegmenationOptions; | |
typedef struct ClassifiedCurve_struct ClassifiedCurve; | |
typedef struct RangeDouble_struct RangeDouble; | |
typedef struct RangeLabel_struct RangeLabel; | |
typedef struct CurvatureAnalysisReport_struct CurvatureAnalysisReport; | |
typedef struct Disparity_struct Disparity; | |
typedef struct ComputeDistancesReport_struct ComputeDistancesReport; | |
typedef struct MatchMode_struct MatchMode; | |
typedef struct ClassifiedDisparity_struct ClassifiedDisparity; | |
typedef struct ClassifyDistancesReport_struct ClassifyDistancesReport; | |
typedef struct ContourComputeCurvatureReport_struct ContourComputeCurvatureReport; | |
typedef struct ContourOverlaySettings_struct ContourOverlaySettings; | |
typedef struct CurveParameters_struct CurveParameters; | |
typedef struct ExtractContourReport_struct ExtractContourReport; | |
typedef struct ConnectionConstraint_struct ConnectionConstraint; | |
typedef struct ExtractTextureFeaturesReport_struct ExtractTextureFeaturesReport; | |
typedef struct WaveletBandsReport_struct WaveletBandsReport; | |
typedef struct CircleFitOptions_struct CircleFitOptions; | |
typedef struct EdgeOptions2_struct EdgeOptions2; | |
typedef struct FindCircularEdgeOptions_struct FindCircularEdgeOptions; | |
typedef struct FindConcentricEdgeOptions_struct FindConcentricEdgeOptions; | |
typedef struct ConcentricEdgeFitOptions_struct ConcentricEdgeFitOptions; | |
typedef struct FindConcentricEdgeReport_struct FindConcentricEdgeReport; | |
typedef struct FindCircularEdgeReport_struct FindCircularEdgeReport; | |
typedef struct WindowSize_struct WindowSize; | |
typedef struct DisplacementVector_struct DisplacementVector; | |
typedef struct WaveletOptions_struct WaveletOptions; | |
typedef struct CooccurrenceOptions_struct CooccurrenceOptions; | |
typedef struct ParticleClassifierLocalThresholdOptions_struct ParticleClassifierLocalThresholdOptions; | |
typedef struct RangeFloat_struct RangeFloat; | |
typedef struct ParticleClassifierAutoThresholdOptions_struct ParticleClassifierAutoThresholdOptions; | |
typedef struct ParticleClassifierPreprocessingOptions2_struct ParticleClassifierPreprocessingOptions2; | |
typedef struct MeasureParticlesReport_struct MeasureParticlesReport; | |
typedef struct GeometricPatternMatch3_struct GeometricPatternMatch3; | |
typedef struct MatchGeometricPatternAdvancedOptions3_struct MatchGeometricPatternAdvancedOptions3; | |
typedef struct ColorOptions_struct ColorOptions; | |
typedef struct SampleScore_struct SampleScore; | |
typedef struct ClassifierReportAdvanced_struct ClassifierReportAdvanced; | |
typedef struct LearnGeometricPatternAdvancedOptions2_struct LearnGeometricPatternAdvancedOptions2; | |
typedef struct ParticleFilterOptions2_struct ParticleFilterOptions2; | |
typedef struct FindEdgeOptions2_struct FindEdgeOptions2; | |
typedef struct FindEdgeReport_struct FindEdgeReport; | |
typedef struct FindTransformRectOptions2_struct FindTransformRectOptions2; | |
typedef struct FindTransformRectsOptions2_struct FindTransformRectsOptions2; | |
typedef struct ReadTextReport3_struct ReadTextReport3; | |
typedef struct CharacterStatistics_struct CharacterStatistics; | |
typedef struct CharReport3_struct CharReport3; | |
typedef struct ArcInfo2_struct ArcInfo2; | |
typedef struct EdgeReport2_struct EdgeReport2; | |
typedef struct SearchArcInfo_struct SearchArcInfo; | |
typedef struct ConcentricRakeReport2_struct ConcentricRakeReport2; | |
typedef struct SpokeReport2_struct SpokeReport2; | |
typedef struct EdgeInfo_struct EdgeInfo; | |
typedef struct SearchLineInfo_struct SearchLineInfo; | |
typedef struct RakeReport2_struct RakeReport2; | |
typedef struct TransformBehaviors_struct TransformBehaviors; | |
typedef struct QRCodeDataToken_struct QRCodeDataToken; | |
typedef struct ParticleFilterOptions_struct ParticleFilterOptions; | |
typedef struct StraightEdgeReport2_struct StraightEdgeReport2; | |
typedef struct StraightEdgeOptions_struct StraightEdgeOptions; | |
typedef struct StraightEdge_struct StraightEdge; | |
typedef struct QRCodeSearchOptions_struct QRCodeSearchOptions; | |
typedef struct QRCodeSizeOptions_struct QRCodeSizeOptions; | |
typedef struct QRCodeDescriptionOptions_struct QRCodeDescriptionOptions; | |
typedef struct QRCodeReport_struct QRCodeReport; | |
typedef struct AIMGradeReport_struct AIMGradeReport; | |
typedef struct DataMatrixSizeOptions_struct DataMatrixSizeOptions; | |
typedef struct DataMatrixDescriptionOptions_struct DataMatrixDescriptionOptions; | |
typedef struct DataMatrixSearchOptions_struct DataMatrixSearchOptions; | |
typedef struct DataMatrixReport_struct DataMatrixReport; | |
typedef struct JPEG2000FileAdvancedOptions_struct JPEG2000FileAdvancedOptions; | |
typedef struct MatchGeometricPatternAdvancedOptions2_struct MatchGeometricPatternAdvancedOptions2; | |
typedef struct InspectionAlignment_struct InspectionAlignment; | |
typedef struct InspectionOptions_struct InspectionOptions; | |
typedef struct CharReport2_struct CharReport2; | |
typedef struct CharInfo2_struct CharInfo2; | |
typedef struct ReadTextReport2_struct ReadTextReport2; | |
typedef struct EllipseFeature_struct EllipseFeature; | |
typedef struct CircleFeature_struct CircleFeature; | |
typedef struct ConstCurveFeature_struct ConstCurveFeature; | |
typedef struct RectangleFeature_struct RectangleFeature; | |
typedef struct LegFeature_struct LegFeature; | |
typedef struct CornerFeature_struct CornerFeature; | |
typedef struct LineFeature_struct LineFeature; | |
typedef struct ParallelLinePairFeature_struct ParallelLinePairFeature; | |
typedef struct PairOfParallelLinePairsFeature_struct PairOfParallelLinePairsFeature; | |
typedef union GeometricFeature_union GeometricFeature; | |
typedef struct FeatureData_struct FeatureData; | |
typedef struct GeometricPatternMatch2_struct GeometricPatternMatch2; | |
typedef struct ClosedCurveFeature_struct ClosedCurveFeature; | |
typedef struct LineMatch_struct LineMatch; | |
typedef struct LineDescriptor_struct LineDescriptor; | |
typedef struct RectangleDescriptor_struct RectangleDescriptor; | |
typedef struct RectangleMatch_struct RectangleMatch; | |
typedef struct EllipseDescriptor_struct EllipseDescriptor; | |
typedef struct EllipseMatch_struct EllipseMatch; | |
typedef struct CircleMatch_struct CircleMatch; | |
typedef struct CircleDescriptor_struct CircleDescriptor; | |
typedef struct ShapeDetectionOptions_struct ShapeDetectionOptions; | |
typedef struct Curve_struct Curve; | |
typedef struct CurveOptions_struct CurveOptions; | |
typedef struct Barcode2DInfo_struct Barcode2DInfo; | |
typedef struct DataMatrixOptions_struct DataMatrixOptions; | |
typedef struct ClassifierAccuracyReport_struct ClassifierAccuracyReport; | |
typedef struct NearestNeighborClassResult_struct NearestNeighborClassResult; | |
typedef struct NearestNeighborTrainingReport_struct NearestNeighborTrainingReport; | |
typedef struct ParticleClassifierPreprocessingOptions_struct ParticleClassifierPreprocessingOptions; | |
typedef struct ClassifierSampleInfo_struct ClassifierSampleInfo; | |
typedef struct ClassScore_struct ClassScore; | |
typedef struct ClassifierReport_struct ClassifierReport; | |
typedef struct NearestNeighborOptions_struct NearestNeighborOptions; | |
typedef struct ParticleClassifierOptions_struct ParticleClassifierOptions; | |
typedef struct RGBU64Value_struct RGBU64Value; | |
typedef struct GeometricPatternMatch_struct GeometricPatternMatch; | |
typedef struct MatchGeometricPatternAdvancedOptions_struct MatchGeometricPatternAdvancedOptions; | |
typedef struct MatchGeometricPatternOptions_struct MatchGeometricPatternOptions; | |
typedef struct LearnGeometricPatternAdvancedOptions_struct LearnGeometricPatternAdvancedOptions; | |
typedef struct FitEllipseOptions_struct FitEllipseOptions; | |
typedef struct FitCircleOptions_struct FitCircleOptions; | |
typedef struct ConstructROIOptions2_struct ConstructROIOptions2; | |
typedef struct HSLValue_struct HSLValue; | |
typedef struct HSVValue_struct HSVValue; | |
typedef struct HSIValue_struct HSIValue; | |
typedef struct CIELabValue_struct CIELabValue; | |
typedef struct CIEXYZValue_struct CIEXYZValue; | |
typedef union Color2_union Color2; | |
typedef struct BestEllipse2_struct BestEllipse2; | |
typedef struct LearnPatternAdvancedOptions_struct LearnPatternAdvancedOptions; | |
typedef struct AVIInfo_struct AVIInfo; | |
typedef struct LearnPatternAdvancedShiftOptions_struct LearnPatternAdvancedShiftOptions; | |
typedef struct LearnPatternAdvancedRotationOptions_struct LearnPatternAdvancedRotationOptions; | |
typedef struct MatchPatternAdvancedOptions_struct MatchPatternAdvancedOptions; | |
typedef struct ParticleFilterCriteria2_struct ParticleFilterCriteria2; | |
typedef struct BestCircle2_struct BestCircle2; | |
typedef struct OCRSpacingOptions_struct OCRSpacingOptions; | |
typedef struct OCRProcessingOptions_struct OCRProcessingOptions; | |
typedef struct ReadTextOptions_struct ReadTextOptions; | |
typedef struct CharInfo_struct CharInfo; | |
#if !defined(USERINT_HEADER) && !defined(_CVI_RECT_DEFINED) | |
typedef struct Rect_struct Rect; | |
#endif | |
typedef struct CharReport_struct CharReport; | |
typedef struct ReadTextReport_struct ReadTextReport; | |
#if !defined(USERINT_HEADER) && !defined(_CVI_POINT_DEFINED) | |
typedef struct Point_struct Point; | |
#endif | |
typedef struct Annulus_struct Annulus; | |
typedef struct EdgeLocationReport_struct EdgeLocationReport; | |
typedef struct EdgeOptions_struct EdgeOptions; | |
typedef struct EdgeReport_struct EdgeReport; | |
typedef struct ExtremeReport_struct ExtremeReport; | |
typedef struct FitLineOptions_struct FitLineOptions; | |
typedef struct DisplayMapping_struct DisplayMapping; | |
typedef struct DetectExtremesOptions_struct DetectExtremesOptions; | |
typedef struct ImageInfo_struct ImageInfo; | |
typedef struct LCDOptions_struct LCDOptions; | |
typedef struct LCDReport_struct LCDReport; | |
typedef struct LCDSegments_struct LCDSegments; | |
typedef struct LearnCalibrationOptions_struct LearnCalibrationOptions; | |
typedef struct LearnColorPatternOptions_struct LearnColorPatternOptions; | |
typedef struct Line_struct Line; | |
typedef struct LinearAverages_struct LinearAverages; | |
typedef struct LineProfile_struct LineProfile; | |
typedef struct MatchColorPatternOptions_struct MatchColorPatternOptions; | |
typedef struct HistogramReport_struct HistogramReport; | |
typedef struct ArcInfo_struct ArcInfo; | |
typedef struct AxisReport_struct AxisReport; | |
typedef struct BarcodeInfo_struct BarcodeInfo; | |
typedef struct BCGOptions_struct BCGOptions; | |
typedef struct BestCircle_struct BestCircle; | |
typedef struct BestEllipse_struct BestEllipse; | |
typedef struct BestLine_struct BestLine; | |
typedef struct BrowserOptions_struct BrowserOptions; | |
typedef struct CoordinateSystem_struct CoordinateSystem; | |
typedef struct CalibrationInfo_struct CalibrationInfo; | |
typedef struct CalibrationPoints_struct CalibrationPoints; | |
typedef struct CaliperOptions_struct CaliperOptions; | |
typedef struct CaliperReport_struct CaliperReport; | |
typedef struct DrawTextOptions_struct DrawTextOptions; | |
typedef struct CircleReport_struct CircleReport; | |
typedef struct ClosedContour_struct ClosedContour; | |
typedef struct ColorHistogramReport_struct ColorHistogramReport; | |
typedef struct ColorInformation_struct ColorInformation; | |
typedef struct Complex_struct Complex; | |
typedef struct ConcentricRakeReport_struct ConcentricRakeReport; | |
typedef struct ConstructROIOptions_struct ConstructROIOptions; | |
typedef struct ContourInfo_struct ContourInfo; | |
typedef union ContourUnion_union ContourUnion; | |
typedef struct ContourInfo2_struct ContourInfo2; | |
typedef struct ContourPoint_struct ContourPoint; | |
typedef struct CoordinateTransform_struct CoordinateTransform; | |
typedef struct CoordinateTransform2_struct CoordinateTransform2; | |
typedef struct CannyOptions_struct CannyOptions; | |
typedef struct Range_struct Range; | |
typedef struct UserPointSymbol_struct UserPointSymbol; | |
typedef struct View3DOptions_struct View3DOptions; | |
typedef struct MatchPatternOptions_struct MatchPatternOptions; | |
typedef struct TIFFFileOptions_struct TIFFFileOptions; | |
typedef union Color_union Color; | |
typedef union PixelValue_union PixelValue; | |
typedef struct OpenContour_struct OpenContour; | |
typedef struct OverlayTextOptions_struct OverlayTextOptions; | |
typedef struct ParticleFilterCriteria_struct ParticleFilterCriteria; | |
typedef struct ParticleReport_struct ParticleReport; | |
typedef struct PatternMatch_struct PatternMatch; | |
typedef struct QuantifyData_struct QuantifyData; | |
typedef struct QuantifyReport_struct QuantifyReport; | |
typedef struct RakeOptions_struct RakeOptions; | |
typedef struct RakeReport_struct RakeReport; | |
typedef struct TransformReport_struct TransformReport; | |
typedef struct ShapeReport_struct ShapeReport; | |
typedef struct MeterArc_struct MeterArc; | |
typedef struct ThresholdData_struct ThresholdData; | |
typedef struct StructuringElement_struct StructuringElement; | |
typedef struct SpokeReport_struct SpokeReport; | |
typedef struct SimpleEdgeOptions_struct SimpleEdgeOptions; | |
typedef struct SelectParticleCriteria_struct SelectParticleCriteria; | |
typedef struct SegmentInfo_struct SegmentInfo; | |
typedef struct RotationAngleRange_struct RotationAngleRange; | |
typedef struct RotatedRect_struct RotatedRect; | |
typedef struct ROIProfile_struct ROIProfile; | |
typedef struct ToolWindowOptions_struct ToolWindowOptions; | |
typedef struct SpokeOptions_struct SpokeOptions; | |
//============================================================================ | |
// Data Structures | |
//============================================================================ | |
#if !defined __GNUC__ && !defined _M_X64 | |
#pragma pack(push,1) | |
#endif | |
typedef struct DivisionModel_struct { | |
float kappa; //The learned kappa coefficient of division model. | |
} DivisionModel; | |
typedef struct FocalLength_struct { | |
float fx; //Focal length in X direction. | |
float fy; //Focal length in Y direction. | |
} FocalLength; | |
typedef struct PolyModel_struct { | |
float* kCoeffs; //The learned radial coefficients of polynomial model. | |
unsigned int numKCoeffs; //Number of K coefficients. | |
float p1; //The P1(learned tangential coefficients of polynomial model). | |
float p2; //The P2(learned tangential coefficients of polynomial model). | |
} PolyModel; | |
typedef struct DistortionModelParams_struct { | |
DistortionModel distortionModel; //Type of learned distortion model. | |
PolyModel polyModel; //The learned coefficients of polynomial model. | |
DivisionModel divisionModel; //The learned coefficient of division model. | |
} DistortionModelParams; | |
typedef struct PointFloat_struct { | |
float x; //The x-coordinate of the point. | |
float y; //The y-coordinate of the point. | |
} PointFloat; | |
typedef struct InternalParameters_struct { | |
char isInsufficientData; | |
FocalLength focalLength; | |
PointFloat opticalCenter; | |
} InternalParameters; | |
typedef struct MaxGridSize_struct { | |
unsigned int xMax; //Maximum x limit for the grid size. | |
unsigned int yMax; //Maximum y limit for the grid size. | |
} MaxGridSize; | |
typedef struct ImageSize_struct { | |
unsigned int xRes; //X resolution of the image. | |
unsigned int yRes; //Y resolution of the image. | |
} ImageSize; | |
typedef struct CalibrationReferencePoints_struct { | |
PointDouble* pixelCoords; //Specifies the coordinates of the pixel reference points. | |
unsigned int numPixelCoords; //Number of pixel coordinates. | |
PointDouble* realCoords; //Specifies the measuring unit associated with the image. | |
unsigned int numRealCoords; //Number of real coordinates. | |
CalibrationUnit units; //Specifies the units of X Step and Y Step. | |
ImageSize imageSize; //Specifies the size of calibration template image. | |
} CalibrationReferencePoints; | |
typedef struct GetCameraParametersReport_struct { | |
double* projectionMatrix; //The projection(homography) matrix of working plane. | |
unsigned int projectionMatrixRows; //Number of rows in projection matrix. | |
unsigned int projectionMatrixCols; //Number of columns in projection matrix. | |
DistortionModelParams distortion; //Distortion model Coefficients. | |
InternalParameters internalParams; //The learned internal paramters of camera model such as focal length and optical center. | |
} GetCameraParametersReport; | |
typedef struct CalibrationAxisInfo_struct { | |
PointFloat center; //The origin of the reference coordinate system, expressed in pixel units. | |
float rotationAngle; //The angle of the x-axis of the real-world coordinate system, in relation to the horizontal. | |
AxisOrientation axisDirection; //Specifies the direction of the calibraiton axis which is either Direct or Indirect. | |
} CalibrationAxisInfo; | |
typedef struct CalibrationLearnSetupInfo_struct { | |
CalibrationMode2 calibrationMethod; //Type of calibration method used. | |
DistortionModel distortionModel; //Type of learned distortion model. | |
ScalingMethod scaleMode; //The aspect scaling to use when correcting an image. | |
CalibrationROI roiMode; //The ROI to use when correcting an image. | |
char learnCorrectionTable; //Set this input to true value if you want the correction table to be determined and stored. | |
} CalibrationLearnSetupInfo; | |
typedef struct GridDescriptor_struct { | |
float xStep; //The distance in the x direction between two adjacent pixels in units specified by unit. | |
float yStep; //The distance in the y direction between two adjacent pixels in units specified by unit. | |
CalibrationUnit unit; //The unit of measure for the image. | |
} GridDescriptor; | |
typedef struct ErrorStatistics_struct { | |
double mean; //Mean error statistics value. | |
double maximum; //Maximum value of error. | |
double standardDeviation; //The standard deviation error statistiscs value. | |
double distortion; //The distortion error statistics value. | |
} ErrorStatistics; | |
typedef struct GetCalibrationInfoReport_struct { | |
ROI* userRoi; //Specifies the ROI the user provided when learning the calibration. | |
ROI* calibrationRoi; //Specifies the ROI that corresponds to the region of the image where the calibration information is accurate. | |
CalibrationAxisInfo axisInfo; //Reference Coordinate System for the real-world coordinates. | |
CalibrationLearnSetupInfo learnSetupInfo; //Calibration learn setup information. | |
GridDescriptor gridDescriptor; //Specifies scaling constants used to calibrate the image. | |
float* errorMap; //The the error map of calibration template image. | |
unsigned int errorMapRows; //Number of rows in error map. | |
unsigned int errorMapCols; //Number of Columns in error map. | |
ErrorStatistics errorStatistics; //Error statistics of the calibration. | |
} GetCalibrationInfoReport; | |
typedef struct EdgePolarity_struct { | |
EdgePolaritySearchMode start; | |
EdgePolaritySearchMode end; | |
} EdgePolarity; | |
typedef struct ClampSettings_struct { | |
double angleRange; //Specifies the angle range. | |
EdgePolarity edgePolarity; //Specifies the edge polarity. | |
} ClampSettings; | |
typedef struct PointDouble_struct { | |
double x; //The x-coordinate of the point. | |
double y; //The y-coordinate of the point. | |
} PointDouble; | |
typedef struct PointDoublePair_struct { | |
PointDouble start; //The Start co-ordinate of the pair. | |
PointDouble end; //The End co-ordinate of the pair. | |
} PointDoublePair; | |
typedef struct ClampResults_struct { | |
double distancePix; //Defines the Pixel world distance. | |
double distanceRealWorld; //Defines the real world distance. | |
double angleAbs; //Defines the absolute angle. | |
double angleRelative; //Defines the relative angle. | |
} ClampResults; | |
typedef struct ClampPoints_struct { | |
PointDoublePair pixel; //Specifies the pixel world point pair for clamp. | |
PointDoublePair realWorld; //Specifies the real world point pair for clamp. | |
} ClampPoints; | |
typedef struct RGBValue_struct { | |
unsigned char B; //The blue value of the color. | |
unsigned char G; //The green value of the color. | |
unsigned char R; //The red value of the color. | |
unsigned char alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} RGBValue; | |
typedef struct ClampOverlaySettings_struct { | |
int showSearchArea; //If TRUE, the function overlays the search area on the image. | |
int showCurves; //If TRUE, the function overlays the curves on the image. | |
int showClampLocation; //If TRUE, the function overlays the clamp location on the image. | |
int showResult; //If TRUE, the function overlays the hit lines to the object and the edge used to generate the hit line on the result image. | |
RGBValue searchAreaColor; //Specifies the RGB color value to use to overlay the search area. | |
RGBValue curvesColor; //Specifies the RGB color value to use to overlay the curves. | |
RGBValue clampLocationsColor; //Specifies the RGB color value to use to overlay the clamp locations. | |
RGBValue resultColor; //Specifies the RGB color value to use to overlay the results. | |
char* overlayGroupName; //Specifies the group overlay name for the step overlays. | |
} ClampOverlaySettings; | |
typedef struct ClampMax2Report_struct { | |
ClampResults clampResults; //Specifies the Clamp results information returned by the function. | |
ClampPoints clampPoints; //Specifies the clamp points information returned by the function. | |
unsigned int calibrationValid; //Specifies if the calibration information is valid or not. | |
} ClampMax2Report; | |
typedef struct ContourFitSplineReport_struct { | |
PointDouble* points; //It returns the points of the best-fit B-spline curve. | |
int numberOfPoints; //Number of Best fit points returned. | |
} ContourFitSplineReport; | |
typedef struct LineFloat_struct { | |
PointFloat start; //The coordinate location of the start of the line. | |
PointFloat end; //The coordinate location of the end of the line. | |
} LineFloat; | |
typedef struct LineEquation_struct { | |
double a; //The a coefficient of the line equation. | |
double b; //The b coefficient of the line equation. | |
double c; //The c coefficient of the line equation. | |
} LineEquation; | |
typedef struct ContourFitLineReport_struct { | |
LineFloat lineSegment; //Line Segment represents the intersection of the line equation and the contour. | |
LineEquation lineEquation; //Line Equation is a structure of three coefficients A, B, and C of the equation in the normal form (Ax + By + C=0) of the best fit line. | |
} ContourFitLineReport; | |
typedef struct ContourFitPolynomialReport_struct { | |
PointDouble* bestFit; //It returns the points of the best-fit polynomial. | |
int numberOfPoints; //Number of Best fit points returned. | |
double* polynomialCoefficients; //Polynomial Coefficients returns the coefficients of the polynomial equation. | |
int numberOfCoefficients; //Number of Coefficients returned in the polynomial coefficients array. | |
} ContourFitPolynomialReport; | |
typedef struct PartialCircle_struct { | |
PointFloat center; //Center of the circle. | |
double radius; //Radius of the circle. | |
double startAngle; //Start angle of the fitted structure. | |
double endAngle; //End angle of the fitted structure. | |
} PartialCircle; | |
typedef struct PartialEllipse_struct { | |
PointFloat center; //Center of the Ellipse. | |
double angle; //Angle of the ellipse. | |
double majorRadius; //The length of the semi-major axis of the ellipse. | |
double minorRadius; //The length of the semi-minor axis of the ellipse. | |
double startAngle; //Start angle of the fitted structure. | |
double endAngle; //End angle of the fitted structure. | |
} PartialEllipse; | |
typedef struct SetupMatchPatternData_struct { | |
unsigned char* matchSetupData; //String containing the match setup data. | |
int numMatchSetupData; //Number of match setup data. | |
} SetupMatchPatternData; | |
typedef struct RangeSettingDouble_struct { | |
SettingType settingType; //Match Constraints specifies the match option whose values you want to constrain by the given range. | |
double min; //Min is the minimum value of the range for a given Match Constraint. | |
double max; //Max is the maximum value of the range for a given Match Constraint. | |
} RangeSettingDouble; | |
typedef struct GeometricAdvancedSetupDataOption_struct { | |
GeometricSetupDataItem type; //It determines the option you want to use during the matching phase. | |
double value; //Value is the value for the option you want to use during the matching phase. | |
} GeometricAdvancedSetupDataOption; | |
typedef struct ContourInfoReport_struct { | |
PointDouble* pointsPixel; //Points (pixel) specifies the location of every point detected on the curve, in pixels. | |
unsigned int numPointsPixel; //Number of points pixel elements. | |
PointDouble* pointsReal; //Points (real) specifies the location of every point detected on the curve, in calibrated units. | |
unsigned int numPointsReal; //Number of points real elements. | |
double* curvaturePixel; //Curvature Pixel displays the curvature profile for the selected contour, in pixels. | |
unsigned int numCurvaturePixel; //Number of curvature pixels. | |
double* curvatureReal; //Curvature Real displays the curvature profile for the selected contour, in calibrated units. | |
unsigned int numCurvatureReal; //Number of curvature Real elements. | |
double length; //Length (pixel) specifies the length, in pixels, of the curves in the image. | |
double lengthReal; //Length (real) specifies the length, in calibrated units, of the curves within the curvature range. | |
unsigned int hasEquation; //Has Equation specifies whether the contour has a fitted equation. | |
} ContourInfoReport; | |
typedef struct ROILabel_struct { | |
char* className; //Specifies the classname you want to segment. | |
unsigned int label; //Label is the label number associated with the Class Name. | |
} ROILabel; | |
typedef struct SupervisedColorSegmentationReport_struct { | |
ROILabel* labelOut; //The Roi labels array. | |
unsigned int numLabelOut; //The number of elements in labelOut array. | |
} SupervisedColorSegmentationReport; | |
typedef struct LabelToROIReport_struct { | |
ROI** roiArray; //Array of ROIs. | |
unsigned int numOfROIs; //Number of ROIs in the roiArray. | |
unsigned int* labelsOutArray; //Array of labels. | |
unsigned int numOfLabels; //Number of labels. | |
int* isTooManyVectorsArray; //isTooManyVectorsArray array. | |
unsigned int isTooManyVectorsArraySize; //Number of elements in isTooManyVectorsArray. | |
} LabelToROIReport; | |
typedef struct ColorSegmenationOptions_struct { | |
unsigned int windowX; //X is the window size in x direction. | |
unsigned int windowY; //Y is the window size in y direction. | |
unsigned int stepSize; //Step Size is the distance between two windows. | |
unsigned int minParticleArea; //Min Particle Area is the minimum number of allowed pixels. | |
unsigned int maxParticleArea; //Max Particle Area is the maximum number of allowed pixels. | |
short isFineSegment; //When enabled, the step processes the boundary pixels of each segmentation cluster using a step size of 1. | |
} ColorSegmenationOptions; | |
typedef struct ClassifiedCurve_struct { | |
double length; //Specifies the length, in pixels, of the curves within the curvature range. | |
double lengthReal; //specifies the length, in calibrated units, of the curves within the curvature range. | |
double maxCurvature; //specifies the maximum curvature, in pixels, for the selected curvature range. | |
double maxCurvatureReal; //specifies the maximum curvature, in calibrated units, for the selected curvature range. | |
unsigned int label; //specifies the class to which the the sample belongs. | |
PointDouble* curvePoints; //Curve Points is a point-coordinate cluster that defines the points of the curve. | |
unsigned int numCurvePoints; //Number of curve points. | |
} ClassifiedCurve; | |
typedef struct RangeDouble_struct { | |
double minValue; //The minimum value of the range. | |
double maxValue; //The maximum value of the range. | |
} RangeDouble; | |
typedef struct RangeLabel_struct { | |
RangeDouble range; //Specifies the range of curvature values. | |
unsigned int label; //Class Label specifies the class to which the the sample belongs. | |
} RangeLabel; | |
typedef struct CurvatureAnalysisReport_struct { | |
ClassifiedCurve* curves; | |
unsigned int numCurves; | |
} CurvatureAnalysisReport; | |
typedef struct Disparity_struct { | |
PointDouble current; //Current is a array of points that defines the target contour. | |
PointDouble reference; //reference is a array of points that defines the template contour. | |
double distance; //Specifies the distance, in pixels, between the template contour point and the target contour point. | |
} Disparity; | |
typedef struct ComputeDistancesReport_struct { | |
Disparity* distances; //Distances is an array containing the computed distances. | |
unsigned int numDistances; //Number elements in the distances array. | |
Disparity* distancesReal; //Distances Real is an array containing the computed distances in calibrated units. | |
unsigned int numDistancesReal; //Number of elements in real distances array. | |
} ComputeDistancesReport; | |
typedef struct MatchMode_struct { | |
unsigned int rotation; //Rotation When enabled, the Function searches for occurrences of the template in the inspection image, allowing for template matches to be rotated. | |
unsigned int scale; //Rotation When enabled, the Function searches for occurrences of the template in the inspection image, allowing for template matches to be rotated. | |
unsigned int occlusion; //Occlusion specifies whether or not to search for occluded versions of the shape. | |
} MatchMode; | |
typedef struct ClassifiedDisparity_struct { | |
double length; //Length (pixel) specifies the length, in pixels, of the curves within the curvature range. | |
double lengthReal; //Length (real) specifies the length, in calibrated units, of the curves within the curvature range. | |
double maxDistance; //Maximum Distance (pixel) specifies the maximum distance, in pixels, between points along the selected contour and the template contour. | |
double maxDistanceReal; //Maximum Distance (real) specifies the maximum distance, in calibrated units, between points along the selected contour and the template contour. | |
unsigned int label; //Class Label specifies the class to which the the sample belongs. | |
PointDouble* templateSubsection; //Template subsection points is an array of points that defines the boundary of the template. | |
unsigned int numTemplateSubsection; //Number of reference points. | |
PointDouble* targetSubsection; //Current Points(Target subsection points) is an array of points that defines the boundary of the target. | |
unsigned int numTargetSubsection; //Number of current points. | |
} ClassifiedDisparity; | |
typedef struct ClassifyDistancesReport_struct { | |
ClassifiedDisparity* classifiedDistances; //Disparity array containing the classified distances. | |
unsigned int numClassifiedDistances; //Number of elements in the disparity array. | |
} ClassifyDistancesReport; | |
typedef struct ContourComputeCurvatureReport_struct { | |
double* curvaturePixel; //Curvature Pixel displays the curvature profile for the selected contour, in pixels. | |
unsigned int numCurvaturePixel; //Number of curvature pixels. | |
double* curvatureReal; //Curvature Real displays the curvature profile for the selected contour, in calibrated units. | |
unsigned int numCurvatureReal; //Number of curvature Real elements. | |
} ContourComputeCurvatureReport; | |
typedef struct ContourOverlaySettings_struct { | |
unsigned int overlay; //Overlay specifies whether to display the overlay on the image. | |
RGBValue color; //Color is the color of the overlay. | |
unsigned int width; //Width specifies the width of the overlay in pixels. | |
unsigned int maintainWidth; //Maintain Width? specifies whether you want the overlay measured in screen pixels or image pixels. | |
} ContourOverlaySettings; | |
typedef struct CurveParameters_struct { | |
ExtractionMode extractionMode; //Specifies the method the function uses to identify curves in the image. | |
int threshold; //Specifies the minimum contrast a seed point must have in order to begin a curve. | |
EdgeFilterSize filterSize; //Specifies the width of the edge filter the function uses to identify curves in the image. | |
int minLength; //Specifies the length, in pixels, of the smallest curve the function will extract. | |
int searchStep; //Search Step Size specifies the distance, in the y direction, between the image rows that the algorithm inspects for curve seed points. | |
int maxEndPointGap; //Specifies the maximum gap, in pixels, between the endpoints of a curve that the function identifies as a closed curve. | |
int subpixel; //Subpixel specifies whether to detect curve points with subpixel accuracy. | |
} CurveParameters; | |
typedef struct ExtractContourReport_struct { | |
PointDouble* contourPoints; //Contour Points specifies every point found on the contour. | |
int numContourPoints; //Number of contour points. | |
PointDouble* sourcePoints; //Source Image Points specifies every point found on the contour in the source image. | |
int numSourcePoints; //Number of source points. | |
} ExtractContourReport; | |
typedef struct ConnectionConstraint_struct { | |
ConnectionConstraintType constraintType; //Constraint Type specifies what criteria to use to consider two curves part of a contour. | |
RangeDouble range; //Specifies range for a given Match Constraint. | |
} ConnectionConstraint; | |
typedef struct ExtractTextureFeaturesReport_struct { | |
int* waveletBands; //The array having all the Wavelet Banks used for extraction. | |
int numWaveletBands; //Number of wavelet banks in the Array. | |
double** textureFeatures; //2-D array to store all the Texture features extracted. | |
int textureFeaturesRows; //Number of Rows in the Texture Features array. | |
int textureFeaturesCols; //Number of Cols in Texture Features array. | |
} ExtractTextureFeaturesReport; | |
typedef struct WaveletBandsReport_struct { | |
float** LLBand; //2-D array for LL Band. | |
float** LHBand; //2-D array for LH Band. | |
float** HLBand; //2-D array for HL Band. | |
float** HHBand; //2-D array for HH Band. | |
float** LLLBand; //2-D array for LLL Band. | |
float** LLHBand; //2-D array for LLH Band. | |
float LHLBand; //2-D array for LHL Band. | |
float** LHHBand; //2-D array for LHH Band. | |
int rows; //Number of Rows for each of the 2-D arrays. | |
int cols; //Number of Columns for each of the 2-D arrays. | |
} WaveletBandsReport; | |
typedef struct CircleFitOptions_struct { | |
int maxRadius; //Specifies the acceptable distance, in pixels, that a point determined to belong to the circle can be from the perimeter of the circle. | |
double stepSize; //Step Size is the angle, in degrees, between each radial line in the annular region. | |
RakeProcessType processType; //Method used to process the data extracted for edge detection. | |
} CircleFitOptions; | |
typedef struct EdgeOptions2_struct { | |
EdgePolaritySearchMode polarity; //Specifies the polarity of the edges to be found. | |
unsigned int kernelSize; //Specifies the size of the edge detection kernel. | |
unsigned int width; //Specifies the number of pixels averaged perpendicular to the search direction to compute the edge profile strength at each point along the search ROI. | |
float minThreshold; //Specifies the minimum edge strength (gradient magnitude) required for a detected edge. | |
InterpolationMethod interpolationType; //Specifies the interpolation method used to locate the edge position. | |
ColumnProcessingMode columnProcessingMode; //Specifies the method used to find the straight edge. | |
} EdgeOptions2; | |
typedef struct FindCircularEdgeOptions_struct { | |
SpokeDirection direction; //Specifies the Spoke direction to search in the ROI. | |
int showSearchArea; //If TRUE, the function overlays the search area on the image. | |
int showSearchLines; //If TRUE, the function overlays the search lines used to locate the edges on the image. | |
int showEdgesFound; //If TRUE, the function overlays the locations of the edges found on the image. | |
int showResult; //If TRUE, the function overlays the hit lines to the object and the edge used to generate the hit line on the result image. | |
RGBValue searchAreaColor; //Specifies the RGB color value to use to overlay the search area. | |
RGBValue searchLinesColor; //Specifies the RGB color value to use to overlay the search lines. | |
RGBValue searchEdgesColor; //Specifies the RGB color value to use to overlay the search edges. | |
RGBValue resultColor; //Specifies the RGB color value to use to overlay the results. | |
char* overlayGroupName; //Specifies the overlay group name to assign to the overlays. | |
EdgeOptions2 edgeOptions; //Specifies the edge detection options along a single search line. | |
} FindCircularEdgeOptions; | |
typedef struct FindConcentricEdgeOptions_struct { | |
ConcentricRakeDirection direction; //Specifies the Concentric Rake direction. | |
int showSearchArea; //If TRUE, the function overlays the search area on the image. | |
int showSearchLines; //If TRUE, the function overlays the search lines used to locate the edges on the image. | |
int showEdgesFound; //If TRUE, the function overlays the locations of the edges found on the image. | |
int showResult; //If TRUE, the function overlays the hit lines to the object and the edge used to generate the hit line on the result image. | |
RGBValue searchAreaColor; //Specifies the RGB color value to use to overlay the search area. | |
RGBValue searchLinesColor; //Specifies the RGB color value to use to overlay the search lines. | |
RGBValue searchEdgesColor; //Specifies the RGB color value to use to overlay the search edges. | |
RGBValue resultColor; //Specifies the RGB color value to use to overlay the results. | |
char* overlayGroupName; //Specifies the overlay group name to assign to the overlays. | |
EdgeOptions2 edgeOptions; //Specifies the edge detection options along a single search line. | |
} FindConcentricEdgeOptions; | |
typedef struct ConcentricEdgeFitOptions_struct { | |
int maxRadius; //Specifies the acceptable distance, in pixels, that a point determined to belong to the circle can be from the perimeter of the circle. | |
double stepSize; //The sampling factor that determines the gap between the rake lines. | |
RakeProcessType processType; //Method used to process the data extracted for edge detection. | |
} ConcentricEdgeFitOptions; | |
typedef struct FindConcentricEdgeReport_struct { | |
PointFloat startPt; //Pixel Coordinates for starting point of the edge. | |
PointFloat endPt; //Pixel Coordinates for end point of the edge. | |
PointFloat startPtCalibrated; //Real world Coordinates for starting point of the edge. | |
PointFloat endPtCalibrated; //Real world Coordinates for end point of the edge. | |
double angle; //Angle of the edge found. | |
double angleCalibrated; //Calibrated angle of the edge found. | |
double straightness; //The straightness value of the detected straight edge. | |
double avgStrength; //Average strength of the egde found. | |
double avgSNR; //Average SNR(Signal to Noise Ratio) for the edge found. | |
int lineFound; //If the edge is found or not. | |
} FindConcentricEdgeReport; | |
typedef struct FindCircularEdgeReport_struct { | |
PointFloat centerCalibrated; //Real world Coordinates of the Center. | |
double radiusCalibrated; //Real world radius of the Circular Edge found. | |
PointFloat center; //Pixel Coordinates of the Center. | |
double radius; //Radius in pixels of the Circular Edge found. | |
double roundness; //The roundness of the calculated circular edge. | |
double avgStrength; //Average strength of the egde found. | |
double avgSNR; //Average SNR(Signal to Noise Ratio) for the edge found. | |
int circleFound; //If the circlular edge is found or not. | |
} FindCircularEdgeReport; | |
typedef struct WindowSize_struct { | |
int x; //Window lenght on X direction. | |
int y; //Window lenght on Y direction. | |
int stepSize; //Distance between windows. | |
} WindowSize; | |
typedef struct DisplacementVector_struct { | |
int x; //length on X direction. | |
int y; //length on Y direction. | |
} DisplacementVector; | |
typedef struct WaveletOptions_struct { | |
WaveletType typeOfWavelet; //Type of wavelet(db, bior. | |
float minEnergy; //Minimum Energy in the bands to consider for texture defect detection. | |
} WaveletOptions; | |
typedef struct CooccurrenceOptions_struct { | |
int level; //Level/size of matrix. | |
DisplacementVector displacement; //Displacemnet between pixels to accumulate the matrix. | |
} CooccurrenceOptions; | |
typedef struct ParticleClassifierLocalThresholdOptions_struct { | |
LocalThresholdMethod method; //Specifies the local thresholding method the function uses. | |
ParticleType particleType; //Specifies what kind of particles to look for. | |
unsigned int windowWidth; //The width of the rectangular window around the pixel on which the function performs the local threshold. | |
unsigned int windowHeight; //The height of the rectangular window around the pixel on which the function performs the local threshold. | |
double deviationWeight; //Specifies the k constant used in the Niblack local thresholding algorithm, which determines the weight applied to the variance calculation. | |
} ParticleClassifierLocalThresholdOptions; | |
typedef struct RangeFloat_struct { | |
float minValue; //The minimum value of the range. | |
float maxValue; //The maximum value of the range. | |
} RangeFloat; | |
typedef struct ParticleClassifierAutoThresholdOptions_struct { | |
ThresholdMethod method; //The method for binary thresholding, which specifies how to calculate the classes. | |
ParticleType particleType; //Specifies what kind of particles to look for. | |
RangeFloat limits; //The limits on the automatic threshold range. | |
} ParticleClassifierAutoThresholdOptions; | |
typedef struct ParticleClassifierPreprocessingOptions2_struct { | |
ParticleClassifierThresholdType thresholdType; //The type of threshold to perform on the image. | |
RangeFloat manualThresholdRange; //The range of pixels to keep if manually thresholding the image. | |
ParticleClassifierAutoThresholdOptions autoThresholdOptions; //The options used to auto threshold the image. | |
ParticleClassifierLocalThresholdOptions localThresholdOptions; //The options used to local threshold the image. | |
int rejectBorder; //Set this element to TRUE to reject border particles. | |
int numErosions; //The number of erosions to perform. | |
} ParticleClassifierPreprocessingOptions2; | |
typedef struct MeasureParticlesReport_struct { | |
double** pixelMeasurements; //The measurements on the particles in the image, in pixel coordinates. | |
double** calibratedMeasurements; //The measurements on the particles in the image, in real-world coordinates. | |
size_t numParticles; //The number of particles on which measurements were taken. | |
size_t numMeasurements; //The number of measurements taken. | |
} MeasureParticlesReport; | |
typedef struct GeometricPatternMatch3_struct { | |
PointFloat position; //The location of the origin of the template in the match. | |
float rotation; //The rotation of the match relative to the template image, in degrees. | |
float scale; //The size of the match relative to the size of the template image, expressed as a percentage. | |
float score; //The accuracy of the match. | |
PointFloat corner[4]; //An array of four points describing the rectangle surrounding the template image. | |
int inverse; //This element is TRUE if the match is an inverse of the template image. | |
float occlusion; //The percentage of the match that is occluded. | |
float templateMatchCurveScore; //The accuracy of the match obtained by comparing the template curves to the curves in the match region. | |
float matchTemplateCurveScore; //The accuracy of the match obtained by comparing the curves in the match region to the template curves. | |
float correlationScore; //The accuracy of the match obtained by comparing the template image to the match region using a correlation metric that compares the two regions as a function of their pixel values. | |
PointFloat calibratedPosition; //The location of the origin of the template in the match. | |
float calibratedRotation; //The rotation of the match relative to the template image, in degrees. | |
PointFloat calibratedCorner[4]; //An array of four points describing the rectangle surrounding the template image. | |
} GeometricPatternMatch3; | |
typedef struct MatchGeometricPatternAdvancedOptions3_struct { | |
unsigned int subpixelIterations; //Specifies the maximum number of incremental improvements used to refine matches with subpixel information. | |
double subpixelTolerance; //Specifies the maximum amount of change, in pixels, between consecutive incremental improvements in the match position before the function stops refining the match position. | |
unsigned int initialMatchListLength; //Specifies the maximum size of the match list. | |
int targetTemplateCurveScore; //Set this element to TRUE to specify that the function should calculate the match curve to template curve score and return it for each match result. | |
int correlationScore; //Set this element to TRUE to specify that the function should calculate the correlation score and return it for each match result. | |
double minMatchSeparationDistance; //Specifies the minimum separation distance, in pixels, between the origins of two matches that have unique positions. | |
double minMatchSeparationAngle; //Specifies the minimum angular difference, in degrees, between two matches that have unique angles. | |
double minMatchSeparationScale; //Specifies the minimum difference in scale, expressed as a percentage, between two matches that have unique scales. | |
double maxMatchOverlap; //Specifies the maximum amount of overlap, expressed as a percentage, allowed between the bounding rectangles of two unique matches. | |
int coarseResult; //Specifies whether you want the function to spend less time accurately estimating the location of a match. | |
int enableCalibrationSupport; //Set this element to TRUE to specify the algorithm treat the inspection image as a calibrated image. | |
ContrastMode enableContrastReversal; //Use this element to specify the contrast of the matches to search for in the image. | |
GeometricMatchingSearchStrategy matchStrategy; //Specifies the aggressiveness of the search strategy. | |
unsigned int refineMatchFactor; //Specifies the factor that is applied to the number of matches requested by the user to determine the number of matches that are refined at the initial matching stage. | |
unsigned int subpixelMatchFactor; //Specifies the factor that is applied to the number of matches requested by the user to determine the number of matches that are evaluated at the final subpixel matching stage. | |
} MatchGeometricPatternAdvancedOptions3; | |
typedef struct ColorOptions_struct { | |
ColorClassificationResolution colorClassificationResolution; //Specifies the color resolution of the classifier. | |
unsigned int useLuminance; //Specifies if the luminance band is going to be used in the feature vector. | |
ColorMode colorMode; //Specifies the color mode of the classifier. | |
} ColorOptions; | |
typedef struct SampleScore_struct { | |
char* className; //The name of the class. | |
float distance; //The distance from the item to this class. | |
unsigned int index; //index of this sample. | |
} SampleScore; | |
typedef struct ClassifierReportAdvanced_struct { | |
char* bestClassName; //The name of the best class for the sample. | |
float classificationScore; //The similarity of the sample and the two closest classes in the classifier. | |
float identificationScore; //The similarity of the sample and the assigned class. | |
ClassScore* allScores; //All classes and their scores. | |
int allScoresSize; //The number of entries in allScores. | |
SampleScore* sampleScores; //All samples and their scores. | |
int sampleScoresSize; //The number of entries in sampleScores. | |
} ClassifierReportAdvanced; | |
typedef struct LearnGeometricPatternAdvancedOptions2_struct { | |
double minScaleFactor; //Specifies the minimum scale factor that the template is learned for. | |
double maxScaleFactor; //Specifies the maximum scale factor the template is learned for. | |
double minRotationAngleValue; //Specifies the minimum rotation angle the template is learned for. | |
double maxRotationAngleValue; //Specifies the maximum rotation angle the template is learned for. | |
unsigned int imageSamplingFactor; //Specifies the factor that is used to subsample the template and the image for the initial matching phase. | |
} LearnGeometricPatternAdvancedOptions2; | |
typedef struct ParticleFilterOptions2_struct { | |
int rejectMatches; //Set this parameter to TRUE to transfer only those particles that do not meet all the criteria. | |
int rejectBorder; //Set this element to TRUE to reject border particles. | |
int fillHoles; //Set this element to TRUE to fill holes in particles. | |
int connectivity8; //Set this parameter to TRUE to use connectivity-8 to determine whether particles are touching. | |
} ParticleFilterOptions2; | |
typedef struct FindEdgeOptions2_struct { | |
RakeDirection direction; //The direction to search in the ROI. | |
int showSearchArea; //If TRUE, the function overlays the search area on the image. | |
int showSearchLines; //If TRUE, the function overlays the search lines used to locate the edges on the image. | |
int showEdgesFound; //If TRUE, the function overlays the locations of the edges found on the image. | |
int showResult; //If TRUE, the function overlays the hit lines to the object and the edge used to generate the hit line on the result image. | |
RGBValue searchAreaColor; //Specifies the RGB color value to use to overlay the search area. | |
RGBValue searchLinesColor; //Specifies the RGB color value to use to overlay the search lines. | |
RGBValue searchEdgesColor; //Specifies the RGB color value to use to overlay the search edges. | |
RGBValue resultColor; //Specifies the RGB color value to use to overlay the results. | |
char* overlayGroupName; //Specifies the overlay group name to assign to the overlays. | |
EdgeOptions2 edgeOptions; //Specifies the edge detection options along a single search line. | |
} FindEdgeOptions2; | |
typedef struct FindEdgeReport_struct { | |
StraightEdge* straightEdges; //An array of straight edges detected. | |
unsigned int numStraightEdges; //Indicates the number of straight edges found. | |
} FindEdgeReport; | |
typedef struct FindTransformRectOptions2_struct { | |
FindReferenceDirection direction; //Specifies the direction and orientation in which the function searches for the primary axis. | |
int showSearchArea; //If TRUE, the function overlays the search area on the image. | |
int showSearchLines; //If TRUE, the function overlays the search lines used to locate the edges on the image. | |
int showEdgesFound; //If TRUE, the function overlays the locations of the edges found on the image. | |
int showResult; //If TRUE, the function overlays the hit lines to the object and the edge used to generate the hit line on the result image. | |
RGBValue searchAreaColor; //Specifies the RGB color value to use to overlay the search area. | |
RGBValue searchLinesColor; //Specifies the RGB color value to use to overlay the search lines. | |
RGBValue searchEdgesColor; //Specifies the RGB color value to use to overlay the search edges. | |
RGBValue resultColor; //Specifies the RGB color value to use to overlay the results. | |
char* overlayGroupName; //Specifies the overlay group name to assign to the overlays. | |
EdgeOptions2 edgeOptions; //Specifies the edge detection options along a single search line. | |
} FindTransformRectOptions2; | |
typedef struct FindTransformRectsOptions2_struct { | |
FindReferenceDirection direction; //Specifies the direction and orientation in which the function searches for the primary axis. | |
int showSearchArea; //If TRUE, the function overlays the search area on the image. | |
int showSearchLines; //If TRUE, the function overlays the search lines used to locate the edges on the image. | |
int showEdgesFound; //If TRUE, the function overlays the locations of the edges found on the image. | |
int showResult; //If TRUE, the function overlays the hit lines to the object and the edge used to generate the hit line on the result image. | |
RGBValue searchAreaColor; //Specifies the RGB color value to use to overlay the search area. | |
RGBValue searchLinesColor; //Specifies the RGB color value to use to overlay the search lines. | |
RGBValue searchEdgesColor; //Specifies the RGB color value to use to overlay the search edges. | |
RGBValue resultColor; //Specifies the RGB color value to use to overlay the results. | |
char* overlayGroupName; //Specifies the overlay group name to assign to the overlays. | |
EdgeOptions2 primaryEdgeOptions; //Specifies the parameters used to compute the edge gradient information and detect the edges for the primary ROI. | |
EdgeOptions2 secondaryEdgeOptions; //Specifies the parameters used to compute the edge gradient information and detect the edges for the secondary ROI. | |
} FindTransformRectsOptions2; | |
typedef struct ReadTextReport3_struct { | |
const char* readString; //The read string. | |
CharReport3* characterReport; //An array of reports describing the properties of each identified character. | |
int numCharacterReports; //The number of identified characters. | |
ROI* roiBoundingCharacters; //An array specifying the coordinates of the character bounding ROI. | |
} ReadTextReport3; | |
typedef struct CharacterStatistics_struct { | |
int left; //The left offset of the character bounding rectangles in the current ROI. | |
int top; //The top offset of the character bounding rectangles in the current ROI. | |
int width; //The width of each of the characters you trained in the current ROI. | |
int height; //The height of each trained character in the current ROI. | |
int characterSize; //The size of the character in pixels. | |
} CharacterStatistics; | |
typedef struct CharReport3_struct { | |
const char* character; //The character value. | |
int classificationScore; //The degree to which the assigned character class represents the object better than the other character classes in the character set. | |
int verificationScore; //The similarity of the character and the reference character for the character class. | |
int verified; //This element is TRUE if a reference character was found for the character class and FALSE if a reference character was not found. | |
int lowThreshold; //The minimum value of the threshold range used for this character. | |
int highThreshold; //The maximum value of the threshold range used for this character. | |
CharacterStatistics characterStats; //Describes the characters segmented in the ROI. | |
} CharReport3; | |
typedef struct ArcInfo2_struct { | |
PointFloat center; //The center point of the arc. | |
double radius; //The radius of the arc. | |
double startAngle; //The starting angle of the arc, specified counter-clockwise from the x-axis. | |
double endAngle; //The ending angle of the arc, specified counter-clockwise from the x-axis. | |
} ArcInfo2; | |
typedef struct EdgeReport2_struct { | |
EdgeInfo* edges; //An array of edges detected. | |
unsigned int numEdges; //Indicates the number of edges detected. | |
double* gradientInfo; //An array that contains the calculated edge strengths along the user-defined search area. | |
unsigned int numGradientInfo; //Indicates the number of elements contained in gradientInfo. | |
int calibrationValid; //Indicates if the calibration data corresponding to the location of the edges is correct. | |
} EdgeReport2; | |
typedef struct SearchArcInfo_struct { | |
ArcInfo2 arcCoordinates; //Describes the arc used for edge detection. | |
EdgeReport2 edgeReport; //Describes the edges found in this search line. | |
} SearchArcInfo; | |
typedef struct ConcentricRakeReport2_struct { | |
EdgeInfo* firstEdges; //The first edge point detected along each search line in the ROI. | |
unsigned int numFirstEdges; //The number of points in the firstEdges array. | |
EdgeInfo* lastEdges; //The last edge point detected along each search line in the ROI. | |
unsigned int numLastEdges; //The number of points in the lastEdges array. | |
SearchArcInfo* searchArcs; //Contains the arcs used for edge detection and the edge information for each arc. | |
unsigned int numSearchArcs; //The number of arcs in the searchArcs array. | |
} ConcentricRakeReport2; | |
typedef struct SpokeReport2_struct { | |
EdgeInfo* firstEdges; //The first edge point detected along each search line in the ROI. | |
unsigned int numFirstEdges; //The number of points in the firstEdges array. | |
EdgeInfo* lastEdges; //The last edge point detected along each search line in the ROI. | |
unsigned int numLastEdges; //The number of points in the lastEdges array. | |
SearchLineInfo* searchLines; //The search lines used for edge detection. | |
unsigned int numSearchLines; //The number of search lines used in the edge detection. | |
} SpokeReport2; | |
typedef struct EdgeInfo_struct { | |
PointFloat position; //The location of the edge in the image. | |
PointFloat calibratedPosition; //The position of the edge in the image in real-world coordinates. | |
double distance; //The location of the edge from the first point along the boundary of the input ROI. | |
double calibratedDistance; //The location of the edge from the first point along the boundary of the input ROI in real-world coordinates. | |
double magnitude; //The intensity contrast at the edge. | |
double noisePeak; //The strength of the noise associated with the current edge. | |
int rising; //Indicates the polarity of the edge. | |
} EdgeInfo; | |
typedef struct SearchLineInfo_struct { | |
LineFloat lineCoordinates; //The endpoints of the search line. | |
EdgeReport2 edgeReport; //Describes the edges found in this search line. | |
} SearchLineInfo; | |
typedef struct RakeReport2_struct { | |
EdgeInfo* firstEdges; //The first edge point detected along each search line in the ROI. | |
unsigned int numFirstEdges; //The number of points in the firstEdges array. | |
EdgeInfo* lastEdges; //The last edge point detected along each search line in the ROI. | |
unsigned int numLastEdges; //The number of points in the lastEdges array. | |
SearchLineInfo* searchLines; //The search lines used for edge detection. | |
unsigned int numSearchLines; //The number of search lines used in the edge detection. | |
} RakeReport2; | |
typedef struct TransformBehaviors_struct { | |
GroupBehavior ShiftBehavior; //Specifies the behavior of an overlay group when a shift operation is applied to an image. | |
GroupBehavior ScaleBehavior; //Specifies the behavior of an overlay group when a scale operation is applied to an image. | |
GroupBehavior RotateBehavior; //Specifies the behavior of an overlay group when a rotate operation is applied to an image. | |
GroupBehavior SymmetryBehavior; //Specifies the behavior of an overlay group when a symmetry operation is applied to an image. | |
} TransformBehaviors; | |
typedef struct QRCodeDataToken_struct { | |
QRStreamMode mode; //Specifies the stream mode or the format of the data that is encoded in the QR code. | |
unsigned int modeData; //Indicates specifiers used by the user to postprocess the data if it requires it. | |
unsigned char* data; //Shows the encoded data in the QR code. | |
unsigned int dataLength; //Specifies the length of the data found in the QR code. | |
} QRCodeDataToken; | |
typedef struct ParticleFilterOptions_struct { | |
int rejectMatches; //Set this parameter to TRUE to transfer only those particles that do not meet all the criteria. | |
int rejectBorder; //Set this element to TRUE to reject border particles. | |
int connectivity8; //Set this parameter to TRUE to use connectivity-8 to determine whether particles are touching. | |
} ParticleFilterOptions; | |
typedef struct StraightEdgeReport2_struct { | |
StraightEdge* straightEdges; //Contains an array of found straight edges. | |
unsigned int numStraightEdges; //Indicates the number of straight edges found. | |
SearchLineInfo* searchLines; //Contains an array of all search lines used in the detection. | |
unsigned int numSearchLines; //The number of search lines used in the edge detection. | |
} StraightEdgeReport2; | |
typedef struct StraightEdgeOptions_struct { | |
unsigned int numLines; //Specifies the number of straight edges to find. | |
StraightEdgeSearchMode searchMode; //Specifies the method used to find the straight edge. | |
double minScore; //Specifies the minimum score of a detected straight edge. | |
double maxScore; //Specifies the maximum score of a detected edge. | |
double orientation; //Specifies the angle at which the straight edge is expected to be found. | |
double angleRange; //Specifies the +/- range around the orientation within which the straight edge is expected to be found. | |
double angleTolerance; //Specifies the expected angular accuracy of the straight edge. | |
unsigned int stepSize; //Specifies the gap in pixels between the search lines used with the rake-based methods. | |
double minSignalToNoiseRatio; //Specifies the minimum signal to noise ratio (SNR) of the edge points used to fit the straight edge. | |
double minCoverage; //Specifies the minimum number of points as a percentage of the number of search lines that need to be included in the detected straight edge. | |
unsigned int houghIterations; //Specifies the number of iterations used in the Hough-based method. | |
} StraightEdgeOptions; | |
typedef struct StraightEdge_struct { | |
LineFloat straightEdgeCoordinates; //End points of the detected straight edge in pixel coordinates. | |
LineFloat calibratedStraightEdgeCoordinates; //End points of the detected straight edge in real-world coordinates. | |
double angle; //Angle of the found edge using the pixel coordinates. | |
double calibratedAngle; //Angle of the found edge using the real-world coordinates. | |
double score; //Describes the score of the detected edge. | |
double straightness; //The straightness value of the detected straight edge. | |
double averageSignalToNoiseRatio; //Describes the average signal to noise ratio (SNR) of the detected edge. | |
int calibrationValid; //Indicates if the calibration data for the straight edge is valid. | |
EdgeInfo* usedEdges; //An array of edges that were used to determine this straight line. | |
unsigned int numUsedEdges; //Indicates the number of edges in the usedEdges array. | |
} StraightEdge; | |
typedef struct QRCodeSearchOptions_struct { | |
QRRotationMode rotationMode; //Specifies the amount of QR code rotation the function should allow for. | |
unsigned int skipLocation; //If set to TRUE, specifies that the function should assume that the QR code occupies the entire image (or the entire search region). | |
unsigned int edgeThreshold; //The strength of the weakest edge the function uses to find the coarse location of the QR code in the image. | |
QRDemodulationMode demodulationMode; //The demodulation mode the function uses to locate the QR code. | |
QRCellSampleSize cellSampleSize; //The cell sample size the function uses to locate the QR code. | |
QRCellFilterMode cellFilterMode; //The cell filter mode the function uses to locate the QR code. | |
unsigned int skewDegreesAllowed; //Specifies the amount of skew in the QR code the function should allow for. | |
} QRCodeSearchOptions; | |
typedef struct QRCodeSizeOptions_struct { | |
unsigned int minSize; //Specifies the minimum size (in pixels) of the QR code in the image. | |
unsigned int maxSize; //Specifies the maximum size (in pixels) of the QR code in the image. | |
} QRCodeSizeOptions; | |
typedef struct QRCodeDescriptionOptions_struct { | |
QRDimensions dimensions; //The number of rows and columns that are populated for the QR code, measured in cells. | |
QRPolarities polarity; //The polarity of the QR code. | |
QRMirrorMode mirror; //This element is TRUE if the QR code appears mirrored in the image and FALSE if the QR code appears normally in the image. | |
QRModelType modelType; //This option allows you to specify the type of QR code. | |
} QRCodeDescriptionOptions; | |
typedef struct QRCodeReport_struct { | |
unsigned int found; //This element is TRUE if the function located and decoded a QR code and FALSE if the function failed to locate and decode a QR code. | |
unsigned char* data; //The data encoded in the QR code. | |
unsigned int dataLength; //The length of the data array. | |
PointFloat boundingBox[4]; //An array of four points describing the rectangle surrounding the QR code. | |
QRCodeDataToken* tokenizedData; //Contains the data tokenized in exactly the way it was encoded in the code. | |
unsigned int sizeOfTokenizedData; //Size of the tokenized data. | |
unsigned int numErrorsCorrected; //The number of errors the function corrected when decoding the QR code. | |
unsigned int dimensions; //The number of rows and columns that are populated for the QR code, measured in cells. | |
unsigned int version; //The version of the QR code. | |
QRModelType modelType; //This option allows you to specify what type of QR code this is. | |
QRStreamMode streamMode; //The format of the data encoded in the stream. | |
QRPolarities matrixPolarity; //The polarity of the QR code. | |
unsigned int mirrored; //This element is TRUE if the QR code appears mirrored in the image and FALSE if the QR code appears normally in the image. | |
unsigned int positionInAppendStream; //Indicates what position the QR code is in with respect to the stream of data in all codes. | |
unsigned int sizeOfAppendStream; //Specifies how many QR codes are part of a larger array of codes. | |
int firstEAN128ApplicationID; //The first EAN-128 Application ID encountered in the stream. | |
int firstECIDesignator; //The first Regional Language Designator encountered in the stream. | |
unsigned int appendStreamIdentifier; //Specifies what stream the QR code is in relation to when the code is part of a larger array of codes. | |
unsigned int minimumEdgeStrength; //The strength of the weakest edge the function used to find the coarse location of the QR code in the image. | |
QRDemodulationMode demodulationMode; //The demodulation mode the function used to locate the QR code. | |
QRCellSampleSize cellSampleSize; //The cell sample size the function used to locate the QR code. | |
QRCellFilterMode cellFilterMode; //The cell filter mode the function used to locate the QR code. | |
} QRCodeReport; | |
typedef struct AIMGradeReport_struct { | |
AIMGrade overallGrade; //The overall letter grade, which is equal to the lowest of the other five letter grades. | |
AIMGrade decodingGrade; //The letter grade assigned to a Data Matrix barcode based on the success of the function in decoding the Data Matrix barcode. | |
AIMGrade symbolContrastGrade; //The letter grade assigned to a Data Matrix barcode based on the symbol contrast raw score. | |
float symbolContrast; //The symbol contrast raw score representing the percentage difference between the mean of the reflectance of the darkest 10 percent and lightest 10 percent of the Data Matrix barcode. | |
AIMGrade printGrowthGrade; //The print growth letter grade for the Data Matrix barcode. | |
float printGrowth; //The print growth raw score for the barcode, which is based on the extent to which dark or light markings appropriately fill their module boundaries. | |
AIMGrade axialNonuniformityGrade; //The axial nonuniformity grade for the Data Matrix barcode. | |
float axialNonuniformity; //The axial nonuniformity raw score for the barcode, which is based on how much the sampling point spacing differs from one axis to another. | |
AIMGrade unusedErrorCorrectionGrade; //The unused error correction letter grade for the Data Matrix barcode. | |
float unusedErrorCorrection; //The unused error correction raw score for the Data Matrix barcode, which is based on the extent to which regional or spot damage in the Data Matrix barcode has eroded the reading safety margin provided by the error correction. | |
} AIMGradeReport; | |
typedef struct DataMatrixSizeOptions_struct { | |
unsigned int minSize; //Specifies the minimum size (in pixels) of the Data Matrix barcode in the image. | |
unsigned int maxSize; //Specifies the maximum size (in pixels) of the Data Matrix barcode in the image. | |
unsigned int quietZoneWidth; //Specifies the expected minimum size of the quiet zone, in pixels. | |
} DataMatrixSizeOptions; | |
typedef struct DataMatrixDescriptionOptions_struct { | |
float aspectRatio; //Specifies the ratio of the width of each Data Matrix barcode cell (in pixels) to the height of the Data Matrix barcode (in pixels). | |
unsigned int rows; //Specifies the number of rows in the Data Matrix barcode. | |
unsigned int columns; //Specifies the number of columns in the Data Matrix barcode. | |
int rectangle; //Set this element to TRUE to specify that the Data Matrix barcode is rectangular. | |
DataMatrixECC ecc; //Specifies the ECC used for this Data Matrix barcode. | |
DataMatrixPolarity polarity; //Specifies the data-to-background contrast for the Data Matrix barcode. | |
DataMatrixCellFillMode cellFill; //Specifies the fill percentage for a cell of the Data Matrix barcode that is in the "ON" state. | |
float minBorderIntegrity; //Specifies the minimum percentage of the border (locator pattern and timing pattern) the function should expect in the Data Matrix barcode. | |
DataMatrixMirrorMode mirrorMode; //Specifies if the Data Matrix barcode appears normally in the image or if the barcode appears mirrored in the image. | |
} DataMatrixDescriptionOptions; | |
typedef struct DataMatrixSearchOptions_struct { | |
DataMatrixRotationMode rotationMode; //Specifies the amount of Data Matrix barcode rotation the function should allow for. | |
int skipLocation; //If set to TRUE, specifies that the function should assume that the Data Matrix barcode occupies the entire image (or the entire search region). | |
unsigned int edgeThreshold; //Specifies the minimum contrast a pixel must have in order to be considered part of a matrix cell edge. | |
DataMatrixDemodulationMode demodulationMode; //Specifies the mode the function should use to demodulate (determine which cells are on and which cells are off) the Data Matrix barcode. | |
DataMatrixCellSampleSize cellSampleSize; //Specifies the sample size, in pixels, the function should take to determine if each cell is on or off. | |
DataMatrixCellFilterMode cellFilterMode; //Specifies the mode the function uses to determine the pixel value for each cell. | |
unsigned int skewDegreesAllowed; //Specifies the amount of skew in the Data Matrix barcode the function should allow for. | |
unsigned int maxIterations; //Specifies the maximum number of iterations before the function stops looking for the Data Matrix barcode. | |
unsigned int initialSearchVectorWidth; //Specifies the number of pixels the function should average together to determine the location of an edge. | |
} DataMatrixSearchOptions; | |
typedef struct DataMatrixReport_struct { | |
int found; //This element is TRUE if the function located and decoded a Data Matrix barcode and FALSE if the function failed to locate and decode a Data Matrix barcode. | |
int binary; //This element is TRUE if the Data Matrix barcode contains binary data and FALSE if the Data Matrix barcode contains text data. | |
unsigned char* data; //The data encoded in the Data Matrix barcode. | |
unsigned int dataLength; //The length of the data array. | |
PointFloat boundingBox[4]; //An array of four points describing the rectangle surrounding the Data Matrix barcode. | |
unsigned int numErrorsCorrected; //The number of errors the function corrected when decoding the Data Matrix barcode. | |
unsigned int numErasuresCorrected; //The number of erasures the function corrected when decoding the Data Matrix barcode. | |
float aspectRatio; //Specifies the aspect ratio of the Data Matrix barcode in the image, which equals the ratio of the width of a Data Matrix barcode cell (in pixels) to the height of a Data Matrix barcode cell (in pixels). | |
unsigned int rows; //The number of rows in the Data Matrix barcode. | |
unsigned int columns; //The number of columns in the Data Matrix barcode. | |
DataMatrixECC ecc; //The Error Correction Code (ECC) used by the Data Matrix barcode. | |
DataMatrixPolarity polarity; //The polarity of the Data Matrix barcode. | |
DataMatrixCellFillMode cellFill; //The cell fill percentage of the Data Matrix barcode. | |
float borderIntegrity; //The percentage of the Data Matrix barcode border that appears correctly in the image. | |
int mirrored; //This element is TRUE if the Data Matrix barcode appears mirrored in the image and FALSE if the Data Matrix barcode appears normally in the image. | |
unsigned int minimumEdgeStrength; //The strength of the weakest edge the function used to find the coarse location of the Data Matrix barcode in the image. | |
DataMatrixDemodulationMode demodulationMode; //The demodulation mode the function used to locate the Data Matrix barcode. | |
DataMatrixCellSampleSize cellSampleSize; //The cell sample size the function used to locate the Data Matrix barcode. | |
DataMatrixCellFilterMode cellFilterMode; //The cell filter mode the function used to locate the Data Matrix barcode. | |
unsigned int iterations; //The number of iterations the function took in attempting to locate the Data Matrix barcode. | |
} DataMatrixReport; | |
typedef struct JPEG2000FileAdvancedOptions_struct { | |
WaveletTransformMode waveletMode; //Determines which wavelet transform to use when writing the file. | |
int useMultiComponentTransform; //Set this parameter to TRUE to use an additional transform on RGB images. | |
unsigned int maxWaveletTransformLevel; //Specifies the maximum allowed level of wavelet transform. | |
float quantizationStepSize; //Specifies the absolute base quantization step size for derived quantization mode. | |
} JPEG2000FileAdvancedOptions; | |
typedef struct MatchGeometricPatternAdvancedOptions2_struct { | |
int minFeaturesUsed; //Specifies the minimum number of features the function uses when matching. | |
int maxFeaturesUsed; //Specifies the maximum number of features the function uses when matching. | |
int subpixelIterations; //Specifies the maximum number of incremental improvements used to refine matches with subpixel information. | |
double subpixelTolerance; //Specifies the maximum amount of change, in pixels, between consecutive incremental improvements in the match position before the function stops refining the match position. | |
int initialMatchListLength; //Specifies the maximum size of the match list. | |
float matchTemplateCurveScore; //Set this element to TRUE to specify that the function should calculate the match curve to template curve score and return it for each match result. | |
int correlationScore; //Set this element to TRUE to specify that the function should calculate the correlation score and return it for each match result. | |
double minMatchSeparationDistance; //Specifies the minimum separation distance, in pixels, between the origins of two matches that have unique positions. | |
double minMatchSeparationAngle; //Specifies the minimum angular difference, in degrees, between two matches that have unique angles. | |
double minMatchSeparationScale; //Specifies the minimum difference in scale, expressed as a percentage, between two matches that have unique scales. | |
double maxMatchOverlap; //Specifies the maximum amount of overlap, expressed as a percentage, allowed between the bounding rectangles of two unique matches. | |
int coarseResult; //Specifies whether you want the function to spend less time accurately estimating the location of a match. | |
int smoothContours; //Set this element to TRUE to specify smoothing be done on the contours of the inspection image before feature extraction. | |
int enableCalibrationSupport; //Set this element to TRUE to specify the algorithm treat the inspection image as a calibrated image. | |
} MatchGeometricPatternAdvancedOptions2; | |
typedef struct InspectionAlignment_struct { | |
PointFloat position; //The location of the center of the golden template in the image under inspection. | |
float rotation; //The rotation of the golden template in the image under inspection, in degrees. | |
float scale; //The percentage of the size of the area under inspection compared to the size of the golden template. | |
} InspectionAlignment; | |
typedef struct InspectionOptions_struct { | |
RegistrationMethod registrationMethod; //Specifies how the function registers the golden template and the target image. | |
NormalizationMethod normalizationMethod; //Specifies how the function normalizes the golden template to the target image. | |
int edgeThicknessToIgnore; //Specifies desired thickness of edges to be ignored. | |
float brightThreshold; //Specifies the threshold for areas where the target image is brighter than the golden template. | |
float darkThreshold; //Specifies the threshold for areas where the target image is darker than the golden template. | |
int binary; //Specifies whether the function should return a binary image giving the location of defects, or a grayscale image giving the intensity of defects. | |
} InspectionOptions; | |
typedef struct CharReport2_struct { | |
const char* character; //The character value. | |
PointFloat corner[4]; //An array of four points that describes the rectangle that surrounds the character. | |
int lowThreshold; //The minimum value of the threshold range used for this character. | |
int highThreshold; //The maximum value of the threshold range used for this character. | |
int classificationScore; //The degree to which the assigned character class represents the object better than the other character classes in the character set. | |
int verificationScore; //The similarity of the character and the reference character for the character class. | |
int verified; //This element is TRUE if a reference character was found for the character class and FALSE if a reference character was not found. | |
} CharReport2; | |
typedef struct CharInfo2_struct { | |
const char* charValue; //Retrieves the character value of the corresponding character in the character set. | |
const Image* charImage; //The image you used to train this character. | |
const Image* internalImage; //The internal representation that NI Vision uses to match objects to this character. | |
int isReferenceChar; //This element is TRUE if the character is the reference character for the character class. | |
} CharInfo2; | |
typedef struct ReadTextReport2_struct { | |
const char* readString; //The read string. | |
CharReport2* characterReport; //An array of reports describing the properties of each identified character. | |
int numCharacterReports; //The number of identified characters. | |
} ReadTextReport2; | |
typedef struct EllipseFeature_struct { | |
PointFloat position; //The location of the center of the ellipse. | |
double rotation; //The orientation of the semi-major axis of the ellipse with respect to the horizontal. | |
double minorRadius; //The length of the semi-minor axis of the ellipse. | |
double majorRadius; //The length of the semi-major axis of the ellipse. | |
} EllipseFeature; | |
typedef struct CircleFeature_struct { | |
PointFloat position; //The location of the center of the circle. | |
double radius; //The radius of the circle. | |
} CircleFeature; | |
typedef struct ConstCurveFeature_struct { | |
PointFloat position; //The center of the circle that this constant curve lies upon. | |
double radius; //The radius of the circle that this constant curve lies upon. | |
double startAngle; //When traveling along the constant curve from one endpoint to the next in a counterclockwise manner, this is the angular component of the vector originating at the center of the constant curve and pointing towards the first endpoint of the constant curve. | |
double endAngle; //When traveling along the constant curve from one endpoint to the next in a counterclockwise manner, this is the angular component of the vector originating at the center of the constant curve and pointing towards the second endpoint of the constant curve. | |
} ConstCurveFeature; | |
typedef struct RectangleFeature_struct { | |
PointFloat position; //The center of the rectangle. | |
PointFloat corner[4]; //The four corners of the rectangle. | |
double rotation; //The orientation of the rectangle with respect to the horizontal. | |
double width; //The width of the rectangle. | |
double height; //The height of the rectangle. | |
} RectangleFeature; | |
typedef struct LegFeature_struct { | |
PointFloat position; //The location of the leg feature. | |
PointFloat corner[4]; //The four corners of the leg feature. | |
double rotation; //The orientation of the leg with respect to the horizontal. | |
double width; //The width of the leg. | |
double height; //The height of the leg. | |
} LegFeature; | |
typedef struct CornerFeature_struct { | |
PointFloat position; //The location of the corner feature. | |
double rotation; //The angular component of the vector bisecting the corner from position. | |
double enclosedAngle; //The measure of the enclosed angle of the corner. | |
int isVirtual; | |
} CornerFeature; | |
typedef struct LineFeature_struct { | |
PointFloat startPoint; //The starting point of the line. | |
PointFloat endPoint; //The ending point of the line. | |
double length; //The length of the line measured in pixels from the start point to the end point. | |
double rotation; //The orientation of the line with respect to the horizontal. | |
} LineFeature; | |
typedef struct ParallelLinePairFeature_struct { | |
PointFloat firstStartPoint; //The starting point of the first line of the pair. | |
PointFloat firstEndPoint; //The ending point of the first line of the pair. | |
PointFloat secondStartPoint; //The starting point of the second line of the pair. | |
PointFloat secondEndPoint; //The ending point of the second line of the pair. | |
double rotation; //The orientation of the feature with respect to the horizontal. | |
double distance; //The distance from the first line to the second line. | |
} ParallelLinePairFeature; | |
typedef struct PairOfParallelLinePairsFeature_struct { | |
ParallelLinePairFeature firstParallelLinePair; //The first parallel line pair. | |
ParallelLinePairFeature secondParallelLinePair; //The second parallel line pair. | |
double rotation; //The orientation of the feature with respect to the horizontal. | |
double distance; //The distance from the midline of the first parallel line pair to the midline of the second parallel line pair. | |
} PairOfParallelLinePairsFeature; | |
typedef union GeometricFeature_union { | |
CircleFeature* circle; //A pointer to a CircleFeature. | |
EllipseFeature* ellipse; //A pointer to an EllipseFeature. | |
ConstCurveFeature* constCurve; //A pointer to a ConstCurveFeature. | |
RectangleFeature* rectangle; //A pointer to a RectangleFeature. | |
LegFeature* leg; //A pointer to a LegFeature. | |
CornerFeature* corner; //A pointer to a CornerFeature. | |
ParallelLinePairFeature* parallelLinePair; //A pointer to a ParallelLinePairFeature. | |
PairOfParallelLinePairsFeature* pairOfParallelLinePairs; //A pointer to a PairOfParallelLinePairsFeature. | |
LineFeature* line; //A pointer to a LineFeature. | |
ClosedCurveFeature* closedCurve; //A pointer to a ClosedCurveFeature. | |
} GeometricFeature; | |
typedef struct FeatureData_struct { | |
FeatureType type; //An enumeration representing the type of the feature. | |
PointFloat* contourPoints; //A set of points describing the contour of the feature. | |
int numContourPoints; //The number of points in the contourPoints array. | |
GeometricFeature feature; //The feature data specific to this type of feature. | |
} FeatureData; | |
typedef struct GeometricPatternMatch2_struct { | |
PointFloat position; //The location of the origin of the template in the match. | |
float rotation; //The rotation of the match relative to the template image, in degrees. | |
float scale; //The size of the match relative to the size of the template image, expressed as a percentage. | |
float score; //The accuracy of the match. | |
PointFloat corner[4]; //An array of four points describing the rectangle surrounding the template image. | |
int inverse; //This element is TRUE if the match is an inverse of the template image. | |
float occlusion; //The percentage of the match that is occluded. | |
float templateMatchCurveScore; //The accuracy of the match obtained by comparing the template curves to the curves in the match region. | |
float matchTemplateCurveScore; //The accuracy of the match obtained by comparing the curves in the match region to the template curves. | |
float correlationScore; //The accuracy of the match obtained by comparing the template image to the match region using a correlation metric that compares the two regions as a function of their pixel values. | |
String255 label; //The label corresponding to this match when the match is returned by imaqMatchMultipleGeometricPatterns(). | |
FeatureData* featureData; //The features used in this match. | |
int numFeatureData; //The size of the featureData array. | |
PointFloat calibratedPosition; //The location of the origin of the template in the match. | |
float calibratedRotation; //The rotation of the match relative to the template image, in degrees. | |
PointFloat calibratedCorner[4]; //An array of four points describing the rectangle surrounding the template image. | |
} GeometricPatternMatch2; | |
typedef struct ClosedCurveFeature_struct { | |
PointFloat position; //The center of the closed curve feature. | |
double arcLength; //The arc length of the closed curve feature. | |
} ClosedCurveFeature; | |
typedef struct LineMatch_struct { | |
PointFloat startPoint; //The starting point of the matched line. | |
PointFloat endPoint; //The ending point of the matched line. | |
double length; //The length of the line measured in pixels from the start point to the end point. | |
double rotation; //The orientation of the matched line. | |
double score; //The score of the matched line. | |
} LineMatch; | |
typedef struct LineDescriptor_struct { | |
double minLength; //Specifies the minimum length of a line the function will return. | |
double maxLength; //Specifies the maximum length of a line the function will return. | |
} LineDescriptor; | |
typedef struct RectangleDescriptor_struct { | |
double minWidth; //Specifies the minimum width of a rectangle the algorithm will return. | |
double maxWidth; //Specifies the maximum width of a rectangle the algorithm will return. | |
double minHeight; //Specifies the minimum height of a rectangle the algorithm will return. | |
double maxHeight; //Specifies the maximum height of a rectangle the algorithm will return. | |
} RectangleDescriptor; | |
typedef struct RectangleMatch_struct { | |
PointFloat corner[4]; //The corners of the matched rectangle. | |
double rotation; //The orientation of the matched rectangle. | |
double width; //The width of the matched rectangle. | |
double height; //The height of the matched rectangle. | |
double score; //The score of the matched rectangle. | |
} RectangleMatch; | |
typedef struct EllipseDescriptor_struct { | |
double minMajorRadius; //Specifies the minimum length of the semi-major axis of an ellipse the function will return. | |
double maxMajorRadius; //Specifies the maximum length of the semi-major axis of an ellipse the function will return. | |
double minMinorRadius; //Specifies the minimum length of the semi-minor axis of an ellipse the function will return. | |
double maxMinorRadius; //Specifies the maximum length of the semi-minor axis of an ellipse the function will return. | |
} EllipseDescriptor; | |
typedef struct EllipseMatch_struct { | |
PointFloat position; //The location of the center of the matched ellipse. | |
double rotation; //The orientation of the matched ellipse. | |
double majorRadius; //The length of the semi-major axis of the matched ellipse. | |
double minorRadius; //The length of the semi-minor axis of the matched ellipse. | |
double score; //The score of the matched ellipse. | |
} EllipseMatch; | |
typedef struct CircleMatch_struct { | |
PointFloat position; //The location of the center of the matched circle. | |
double radius; //The radius of the matched circle. | |
double score; //The score of the matched circle. | |
} CircleMatch; | |
typedef struct CircleDescriptor_struct { | |
double minRadius; //Specifies the minimum radius of a circle the function will return. | |
double maxRadius; //Specifies the maximum radius of a circle the function will return. | |
} CircleDescriptor; | |
typedef struct ShapeDetectionOptions_struct { | |
unsigned int mode; //Specifies the method used when looking for the shape in the image. | |
RangeFloat* angleRanges; //An array of angle ranges, in degrees, where each range specifies how much you expect the shape to be rotated in the image. | |
int numAngleRanges; //The size of the orientationRanges array. | |
RangeFloat scaleRange; //A range that specifies the sizes of the shapes you expect to be in the image, expressed as a ratio percentage representing the size of the pattern in the image divided by size of the original pattern multiplied by 100. | |
double minMatchScore; | |
} ShapeDetectionOptions; | |
typedef struct Curve_struct { | |
PointFloat* points; //The points on the curve. | |
unsigned int numPoints; //The number of points in the curve. | |
int closed; //This element is TRUE if the curve is closed and FALSE if the curve is open. | |
double curveLength; //The length of the curve. | |
double minEdgeStrength; //The lowest edge strength detected on the curve. | |
double maxEdgeStrength; //The highest edge strength detected on the curve. | |
double averageEdgeStrength; //The average of all edge strengths detected on the curve. | |
} Curve; | |
typedef struct CurveOptions_struct { | |
ExtractionMode extractionMode; //Specifies the method the function uses to identify curves in the image. | |
int threshold; //Specifies the minimum contrast a seed point must have in order to begin a curve. | |
EdgeFilterSize filterSize; //Specifies the width of the edge filter the function uses to identify curves in the image. | |
int minLength; //Specifies the length, in pixels, of the smallest curve the function will extract. | |
int rowStepSize; //Specifies the distance, in the y direction, between lines the function inspects for curve seed points. | |
int columnStepSize; //Specifies the distance, in the x direction, between columns the function inspects for curve seed points. | |
int maxEndPointGap; //Specifies the maximum gap, in pixels, between the endpoints of a curve that the function identifies as a closed curve. | |
int onlyClosed; //Set this element to TRUE to specify that the function should only identify closed curves in the image. | |
int subpixelAccuracy; //Set this element to TRUE to specify that the function identifies the location of curves with subpixel accuracy by interpolating between points to find the crossing of threshold. | |
} CurveOptions; | |
typedef struct Barcode2DInfo_struct { | |
Barcode2DType type; //The type of the 2D barcode. | |
int binary; //This element is TRUE if the 2D barcode contains binary data and FALSE if the 2D barcode contains text data. | |
unsigned char* data; //The data encoded in the 2D barcode. | |
unsigned int dataLength; //The length of the data array. | |
PointFloat boundingBox[4]; //An array of four points describing the rectangle surrounding the 2D barcode. | |
unsigned int numErrorsCorrected; //The number of errors the function corrected when decoding the 2D barcode. | |
unsigned int numErasuresCorrected; //The number of erasures the function corrected when decoding the 2D barcode. | |
unsigned int rows; //The number of rows in the 2D barcode. | |
unsigned int columns; //The number of columns in the 2D barcode. | |
} Barcode2DInfo; | |
typedef struct DataMatrixOptions_struct { | |
Barcode2DSearchMode searchMode; //Specifies the mode the function uses to search for barcodes. | |
Barcode2DContrast contrast; //Specifies the contrast of the barcodes that the function searches for. | |
Barcode2DCellShape cellShape; //Specifies the shape of the barcode data cells, which affects how the function decodes the barcode. | |
Barcode2DShape barcodeShape; //Specifies the shape of the barcodes that the function searches for. | |
DataMatrixSubtype subtype; //Specifies the Data Matrix subtypes of the barcodes that the function searches for. | |
} DataMatrixOptions; | |
typedef struct ClassifierAccuracyReport_struct { | |
int size; //The size of the arrays in this structure. | |
float accuracy; //The overall accuracy of the classifier, from 0 to 1000. | |
char** classNames; //The names of the classes of this classifier. | |
double* classAccuracy; //An array of size elements that contains accuracy information for each class. | |
double* classPredictiveValue; //An array containing size elements that contains the predictive values of each class. | |
int** classificationDistribution; //A two-dimensional array containing information about how the classifier classifies its samples. | |
} ClassifierAccuracyReport; | |
typedef struct NearestNeighborClassResult_struct { | |
char* className; //The name of the class. | |
float standardDeviation; //The standard deviation of the members of this class. | |
int count; //The number of samples in this class. | |
} NearestNeighborClassResult; | |
typedef struct NearestNeighborTrainingReport_struct { | |
float** classDistancesTable; //The confidence in the training. | |
NearestNeighborClassResult* allScores; //All classes and their scores. | |
int allScoresSize; //The number of entries in allScores. | |
} NearestNeighborTrainingReport; | |
typedef struct ParticleClassifierPreprocessingOptions_struct { | |
int manualThreshold; //Set this element to TRUE to specify the threshold range manually. | |
RangeFloat manualThresholdRange; //If a manual threshold is being done, the range of pixels to keep. | |
ThresholdMethod autoThresholdMethod; //If an automatic threshold is being done, the method used to calculate the threshold range. | |
RangeFloat limits; //The limits on the automatic threshold range. | |
ParticleType particleType; //Specifies what kind of particles to look for. | |
int rejectBorder; //Set this element to TRUE to reject border particles. | |
int numErosions; //The number of erosions to perform. | |
} ParticleClassifierPreprocessingOptions; | |
typedef struct ClassifierSampleInfo_struct { | |
char* className; //The name of the class this sample is in. | |
double* featureVector; //The feature vector of this sample, or NULL if this is not a custom classifier session. | |
int featureVectorSize; //The number of elements in the feature vector. | |
Image* thumbnail; //A thumbnail image of this sample, or NULL if no image was specified. | |
} ClassifierSampleInfo; | |
typedef struct ClassScore_struct { | |
char* className; //The name of the class. | |
float distance; //The distance from the item to this class. | |
} ClassScore; | |
typedef struct ClassifierReport_struct { | |
char* bestClassName; //The name of the best class for the sample. | |
float classificationScore; //The similarity of the sample and the two closest classes in the classifier. | |
float identificationScore; //The similarity of the sample and the assigned class. | |
ClassScore* allScores; //All classes and their scores. | |
int allScoresSize; //The number of entries in allScores. | |
} ClassifierReport; | |
typedef struct NearestNeighborOptions_struct { | |
NearestNeighborMethod method; //The method to use. | |
NearestNeighborMetric metric; //The metric to use. | |
int k; //The value of k, if the IMAQ_K_NEAREST_NEIGHBOR method is used. | |
} NearestNeighborOptions; | |
typedef struct ParticleClassifierOptions_struct { | |
float scaleDependence; //The relative importance of scale when classifying particles. | |
float mirrorDependence; //The relative importance of mirror symmetry when classifying particles. | |
} ParticleClassifierOptions; | |
typedef struct RGBU64Value_struct { | |
unsigned short B; //The blue value of the color. | |
unsigned short G; //The green value of the color. | |
unsigned short R; //The red value of the color. | |
unsigned short alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} RGBU64Value; | |
typedef struct GeometricPatternMatch_struct { | |
PointFloat position; //The location of the origin of the template in the match. | |
float rotation; //The rotation of the match relative to the template image, in degrees. | |
float scale; //The size of the match relative to the size of the template image, expressed as a percentage. | |
float score; //The accuracy of the match. | |
PointFloat corner[4]; //An array of four points describing the rectangle surrounding the template image. | |
int inverse; //This element is TRUE if the match is an inverse of the template image. | |
float occlusion; //The percentage of the match that is occluded. | |
float templateMatchCurveScore; //The accuracy of the match obtained by comparing the template curves to the curves in the match region. | |
float matchTemplateCurveScore; //The accuracy of the match obtained by comparing the curves in the match region to the template curves. | |
float correlationScore; //The accuracy of the match obtained by comparing the template image to the match region using a correlation metric that compares the two regions as a function of their pixel values. | |
} GeometricPatternMatch; | |
typedef struct MatchGeometricPatternAdvancedOptions_struct { | |
int minFeaturesUsed; //Specifies the minimum number of features the function uses when matching. | |
int maxFeaturesUsed; //Specifies the maximum number of features the function uses when matching. | |
int subpixelIterations; //Specifies the maximum number of incremental improvements used to refine matches with subpixel information. | |
double subpixelTolerance; //Specifies the maximum amount of change, in pixels, between consecutive incremental improvements in the match position before the function stops refining the match position. | |
int initialMatchListLength; //Specifies the maximum size of the match list. | |
int matchTemplateCurveScore; //Set this element to TRUE to specify that the function should calculate the match curve to template curve score and return it for each match result. | |
int correlationScore; //Set this element to TRUE to specify that the function should calculate the correlation score and return it for each match result. | |
double minMatchSeparationDistance; //Specifies the minimum separation distance, in pixels, between the origins of two matches that have unique positions. | |
double minMatchSeparationAngle; //Specifies the minimum angular difference, in degrees, between two matches that have unique angles. | |
double minMatchSeparationScale; //Specifies the minimum difference in scale, expressed as a percentage, between two matches that have unique scales. | |
double maxMatchOverlap; //Specifies the maximum amount of overlap, expressed as a percentage, allowed between the bounding rectangles of two unique matches. | |
int coarseResult; //Specifies whether you want the function to spend less time accurately estimating the location of a match. | |
} MatchGeometricPatternAdvancedOptions; | |
typedef struct MatchGeometricPatternOptions_struct { | |
unsigned int mode; //Specifies the method imaqMatchGeometricPattern() uses when looking for the pattern in the image. | |
int subpixelAccuracy; //Set this element to TRUE to specify that the function should calculate match locations with subpixel accuracy. | |
RangeFloat* angleRanges; //An array of angle ranges, in degrees, where each range specifies how much you expect the template to be rotated in the image. | |
int numAngleRanges; //Number of angle ranges in the angleRanges array. | |
RangeFloat scaleRange; //A range that specifies the sizes of the pattern you expect to be in the image, expressed as a ratio percentage representing the size of the pattern in the image divided by size of the original pattern multiplied by 100. | |
RangeFloat occlusionRange; //A range that specifies the percentage of the pattern you expect to be occluded in the image. | |
int numMatchesRequested; //Number of valid matches expected. | |
float minMatchScore; //The minimum score a match can have for the function to consider the match valid. | |
} MatchGeometricPatternOptions; | |
typedef struct LearnGeometricPatternAdvancedOptions_struct { | |
int minRectLength; //Specifies the minimum length for each side of a rectangular feature. | |
double minRectAspectRatio; //Specifies the minimum aspect ratio of a rectangular feature. | |
int minRadius; //Specifies the minimum radius for a circular feature. | |
int minLineLength; //Specifies the minimum length for a linear feature. | |
double minFeatureStrength; //Specifies the minimum strength for a feature. | |
int maxFeaturesUsed; //Specifies the maximum number of features the function uses when learning. | |
int maxPixelDistanceFromLine; //Specifies the maximum number of pixels between an edge pixel and a linear feature for the function to consider that edge pixel as part of the linear feature. | |
} LearnGeometricPatternAdvancedOptions; | |
typedef struct FitEllipseOptions_struct { | |
int rejectOutliers; //Whether to use every given point or only a subset of the points to fit the ellipse. | |
double minScore; //Specifies the required quality of the fitted ellipse. | |
double pixelRadius; //The acceptable distance, in pixels, that a point determined to belong to the ellipse can be from the circumference of the ellipse. | |
int maxIterations; //Specifies the number of refinement iterations you allow the function to perform on the initial subset of points. | |
} FitEllipseOptions; | |
typedef struct FitCircleOptions_struct { | |
int rejectOutliers; //Whether to use every given point or only a subset of the points to fit the circle. | |
double minScore; //Specifies the required quality of the fitted circle. | |
double pixelRadius; //The acceptable distance, in pixels, that a point determined to belong to the circle can be from the circumference of the circle. | |
int maxIterations; //Specifies the number of refinement iterations you allow the function to perform on the initial subset of points. | |
} FitCircleOptions; | |
typedef struct ConstructROIOptions2_struct { | |
int windowNumber; //The window number of the image window. | |
const char* windowTitle; //Specifies the message string that the function displays in the title bar of the window. | |
PaletteType type; //The palette type to use. | |
RGBValue* palette; //If type is IMAQ_PALETTE_USER, this array is the palette of colors to use with the window. | |
int numColors; //If type is IMAQ_PALETTE_USER, this element is the number of colors in the palette array. | |
unsigned int maxContours; //The maximum number of contours the user will be able to select. | |
} ConstructROIOptions2; | |
typedef struct HSLValue_struct { | |
unsigned char L; //The color luminance. | |
unsigned char S; //The color saturation. | |
unsigned char H; //The color hue. | |
unsigned char alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} HSLValue; | |
typedef struct HSVValue_struct { | |
unsigned char V; //The color value. | |
unsigned char S; //The color saturation. | |
unsigned char H; //The color hue. | |
unsigned char alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} HSVValue; | |
typedef struct HSIValue_struct { | |
unsigned char I; //The color intensity. | |
unsigned char S; //The color saturation. | |
unsigned char H; //The color hue. | |
unsigned char alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} HSIValue; | |
typedef struct CIELabValue_struct { | |
double b; //The yellow/blue information of the color. | |
double a; //The red/green information of the color. | |
double L; //The color lightness. | |
unsigned char alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} CIELabValue; | |
typedef struct CIEXYZValue_struct { | |
double Z; //The Z color information. | |
double Y; //The color luminance. | |
double X; //The X color information. | |
unsigned char alpha; //The alpha value of the color, which represents extra information about a color image, such as gamma correction. | |
} CIEXYZValue; | |
typedef union Color2_union { | |
RGBValue rgb; //The information needed to describe a color in the RGB (Red, Green, and Blue) color space. | |
HSLValue hsl; //The information needed to describe a color in the HSL (Hue, Saturation, and Luminance) color space. | |
HSVValue hsv; //The information needed to describe a color in the HSI (Hue, Saturation, and Value) color space. | |
HSIValue hsi; //The information needed to describe a color in the HSI (Hue, Saturation, and Intensity) color space. | |
CIELabValue cieLab; //The information needed to describe a color in the CIE L*a*b* (L, a, b) color space. | |
CIEXYZValue cieXYZ; //The information needed to describe a color in the CIE XYZ (X, Y, Z) color space. | |
int rawValue; //The integer value for the data in the color union. | |
} Color2; | |
typedef struct BestEllipse2_struct { | |
PointFloat center; //The coordinate location of the center of the ellipse. | |
PointFloat majorAxisStart; //The coordinate location of the start of the major axis of the ellipse. | |
PointFloat majorAxisEnd; //The coordinate location of the end of the major axis of the ellipse. | |
PointFloat minorAxisStart; //The coordinate location of the start of the minor axis of the ellipse. | |
PointFloat minorAxisEnd; //The coordinate location of the end of the minor axis of the ellipse. | |
double area; //The area of the ellipse. | |
double perimeter; //The length of the perimeter of the ellipse. | |
double error; //Represents the least square error of the fitted ellipse to the entire set of points. | |
int valid; //This element is TRUE if the function achieved the minimum score within the number of allowed refinement iterations and FALSE if the function did not achieve the minimum score. | |
int* pointsUsed; //An array of the indexes for the points array indicating which points the function used to fit the ellipse. | |
int numPointsUsed; //The number of points the function used to fit the ellipse. | |
} BestEllipse2; | |
typedef struct LearnPatternAdvancedOptions_struct { | |
LearnPatternAdvancedShiftOptions* shiftOptions; //Use this element to control the behavior of imaqLearnPattern2() during the shift-invariant learning phase. | |
LearnPatternAdvancedRotationOptions* rotationOptions; //Use this element to control the behavior of imaqLearnPattern2()during the rotation-invariant learning phase. | |
} LearnPatternAdvancedOptions; | |
typedef struct AVIInfo_struct { | |
unsigned int width; //The width of each frame. | |
unsigned int height; //The height of each frame. | |
ImageType imageType; //The type of images this AVI contains. | |
unsigned int numFrames; //The number of frames in the AVI. | |
unsigned int framesPerSecond; //The number of frames per second this AVI should be shown at. | |
char* filterName; //The name of the compression filter used to create this AVI. | |
int hasData; //Specifies whether this AVI has data attached to each frame or not. | |
unsigned int maxDataSize; //If this AVI has data, the maximum size of the data in each frame. | |
} AVIInfo; | |
typedef struct LearnPatternAdvancedShiftOptions_struct { | |
int initialStepSize; //The largest number of image pixels to shift the sample across the inspection image during the initial phase of shift-invariant matching. | |
int initialSampleSize; //Specifies the number of template pixels that you want to include in a sample for the initial phase of shift-invariant matching. | |
double initialSampleSizeFactor; //Specifies the size of the sample for the initial phase of shift-invariant matching as a percent of the template size, in pixels. | |
int finalSampleSize; //Specifies the number of template pixels you want to add to initialSampleSize for the final phase of shift-invariant matching. | |
double finalSampleSizeFactor; //Specifies the size of the sample for the final phase of shift-invariant matching as a percent of the edge points in the template, in pixels. | |
int subpixelSampleSize; //Specifies the number of template pixels that you want to include in a sample for the subpixel phase of shift-invariant matching. | |
double subpixelSampleSizeFactor; //Specifies the size of the sample for the subpixel phase of shift-invariant matching as a percent of the template size, in pixels. | |
} LearnPatternAdvancedShiftOptions; | |
typedef struct LearnPatternAdvancedRotationOptions_struct { | |
SearchStrategy searchStrategySupport; //Specifies the aggressiveness of the rotation search strategy available during the matching phase. | |
int initialStepSize; //The largest number of image pixels to shift the sample across the inspection image during the initial phase of matching. | |
int initialSampleSize; //Specifies the number of template pixels that you want to include in a sample for the initial phase of rotation-invariant matching. | |
double initialSampleSizeFactor; //Specifies the size of the sample for the initial phase of rotation-invariant matching as a percent of the template size, in pixels. | |
int initialAngularAccuracy; //Sets the angle accuracy, in degrees, to use during the initial phase of rotation-invariant matching. | |
int finalSampleSize; //Specifies the number of template pixels you want to add to initialSampleSize for the final phase of rotation-invariant matching. | |
double finalSampleSizeFactor; //Specifies the size of the sample for the final phase of rotation-invariant matching as a percent of the edge points in the template, in pixels. | |
int finalAngularAccuracy; //Sets the angle accuracy, in degrees, to use during the final phase of the rotation-invariant matching. | |
int subpixelSampleSize; //Specifies the number of template pixels that you want to include in a sample for the subpixel phase of rotation-invariant matching. | |
double subpixelSampleSizeFactor; //Specifies the size of the sample for the subpixel phase of rotation-invariant matching as a percent of the template size, in pixels. | |
} LearnPatternAdvancedRotationOptions; | |
typedef struct MatchPatternAdvancedOptions_struct { | |
int subpixelIterations; //Defines the maximum number of incremental improvements used to refine matching using subpixel information. | |
double subpixelTolerance; //Defines the maximum amount of change, in pixels, between consecutive incremental improvements in the match position that you want to trigger the end of the refinement process. | |
int initialMatchListLength; //Specifies the maximum size of the match list. | |
int matchListReductionFactor; //Specifies the reduction of the match list as matches are refined. | |
int initialStepSize; //Specifies the number of pixels to shift the sample across the inspection image during the initial phase of shift-invariant matching. | |
SearchStrategy searchStrategy; //Specifies the aggressiveness of the rotation search strategy. | |
int intermediateAngularAccuracy; //Specifies the accuracy to use during the intermediate phase of rotation-invariant matching. | |
} MatchPatternAdvancedOptions; | |
typedef struct ParticleFilterCriteria2_struct { | |
MeasurementType parameter; //The morphological measurement that the function uses for filtering. | |
float lower; //The lower bound of the criteria range. | |
float upper; //The upper bound of the criteria range. | |
int calibrated; //Set this element to TRUE to take calibrated measurements. | |
int exclude; //Set this element to TRUE to indicate that a match occurs when the measurement is outside the criteria range. | |
} ParticleFilterCriteria2; | |
typedef struct BestCircle2_struct { | |
PointFloat center; //The coordinate location of the center of the circle. | |
double radius; //The radius of the circle. | |
double area; //The area of the circle. | |
double perimeter; //The length of the perimeter of the circle. | |
double error; //Represents the least square error of the fitted circle to the entire set of points. | |
int valid; //This element is TRUE if the function achieved the minimum score within the number of allowed refinement iterations and FALSE if the function did not achieve the minimum score. | |
int* pointsUsed; //An array of the indexes for the points array indicating which points the function used to fit the circle. | |
int numPointsUsed; //The number of points the function used to fit the circle. | |
} BestCircle2; | |
typedef struct OCRSpacingOptions_struct { | |
int minCharSpacing; //The minimum number of pixels that must be between two characters for NI Vision to train or read the characters separately. | |
int minCharSize; //The minimum number of pixels required for an object to be a potentially identifiable character. | |
int maxCharSize; //The maximum number of pixels required for an object to be a potentially identifiable character. | |
int maxHorizontalElementSpacing; //The maximum horizontal spacing, in pixels, allowed between character elements to train or read the character elements as a single character. | |
int maxVerticalElementSpacing; //The maximum vertical element spacing in pixels. | |
int minBoundingRectWidth; //The minimum possible width, in pixels, for a character bounding rectangle. | |
int maxBoundingRectWidth; //The maximum possible width, in pixels, for a character bounding rectangle. | |
int minBoundingRectHeight; //The minimum possible height, in pixels, for a character bounding rectangle. | |
int maxBoundingRectHeight; //The maximum possible height, in pixels, for a character bounding rectangle. | |
int autoSplit; //Set this element to TRUE to automatically adjust the location of the character bounding rectangle when characters overlap vertically. | |
} OCRSpacingOptions; | |
typedef struct OCRProcessingOptions_struct { | |
ThresholdMode mode; //The thresholding mode. | |
int lowThreshold; //The low threshold value when you set mode to IMAQ_FIXED_RANGE. | |
int highThreshold; //The high threshold value when you set mode to IMAQ_FIXED_RANGE. | |
int blockCount; //The number of blocks for threshold calculation algorithms that require blocks. | |
int fastThreshold; //Set this element to TRUE to use a faster, less accurate threshold calculation algorithm. | |
int biModalCalculation; //Set this element to TRUE to calculate both the low and high threshold values when using the fast thresholding method. | |
int darkCharacters; //Set this element to TRUE to read or train dark characters on a light background. | |
int removeParticlesTouchingROI; //Set this element to TRUE to remove the particles touching the ROI. | |
int erosionCount; //The number of erosions to perform. | |
} OCRProcessingOptions; | |
typedef struct ReadTextOptions_struct { | |
String255 validChars[255]; //An array of strings that specifies the valid characters. | |
int numValidChars; //The number of strings in the validChars array that you have initialized. | |
char substitutionChar; //The character to substitute for objects that the function cannot match with any of the trained characters. | |
ReadStrategy readStrategy; //The read strategy, which determines how closely the function analyzes images in the reading process to match objects with trained characters. | |
int acceptanceLevel; //The minimum acceptance level at which an object is considered a trained character. | |
int aspectRatio; //The maximum aspect ratio variance percentage for valid characters. | |
ReadResolution readResolution; //The read resolution, which determines how much of the trained character data the function uses to match objects to trained characters. | |
} ReadTextOptions; | |
typedef struct CharInfo_struct { | |
const char* charValue; //Retrieves the character value of the corresponding character in the character set. | |
const Image* charImage; //The image you used to train this character. | |
const Image* internalImage; //The internal representation that NI Vision uses to match objects to this character. | |
} CharInfo; | |
#if !defined(USERINT_HEADER) && !defined(_CVI_RECT_DEFINED) | |
typedef struct Rect_struct { | |
int top; //Location of the top edge of the rectangle. | |
int left; //Location of the left edge of the rectangle. | |
int height; //Height of the rectangle. | |
int width; //Width of the rectangle. | |
} Rect; | |
#define _CVI_RECT_DEFINED | |
#endif | |
typedef struct CharReport_struct { | |
const char* character; //The character value. | |
PointFloat corner[4]; //An array of four points that describes the rectangle that surrounds the character. | |
int reserved; //This element is reserved. | |
int lowThreshold; //The minimum value of the threshold range used for this character. | |
int highThreshold; //The maximum value of the threshold range used for this character. | |
} CharReport; | |
typedef struct ReadTextReport_struct { | |
const char* readString; //The read string. | |
const CharReport* characterReport; //An array of reports describing the properties of each identified character. | |
int numCharacterReports; //The number of identified characters. | |
} ReadTextReport; | |
#if !defined(USERINT_HEADER) && !defined(_CVI_POINT_DEFINED) | |
typedef struct Point_struct { | |
int x; //The x-coordinate of the point. | |
int y; //The y-coordinate of the point. | |
} Point; | |
#define _CVI_POINT_DEFINED | |
#endif | |
typedef struct Annulus_struct { | |
Point center; //The coordinate location of the center of the annulus. | |
int innerRadius; //The internal radius of the annulus. | |
int outerRadius; //The external radius of the annulus. | |
double startAngle; //The start angle, in degrees, of the annulus. | |
double endAngle; //The end angle, in degrees, of the annulus. | |
} Annulus; | |
typedef struct EdgeLocationReport_struct { | |
PointFloat* edges; //The coordinate location of all edges detected by the search line. | |
int numEdges; //The number of points in the edges array. | |
} EdgeLocationReport; | |
typedef struct EdgeOptions_struct { | |
unsigned threshold; //Specifies the threshold value for the contrast of the edge. | |
unsigned width; //The number of pixels that the function averages to find the contrast at either side of the edge. | |
unsigned steepness; //The span, in pixels, of the slope of the edge projected along the path specified by the input points. | |
InterpolationMethod subpixelType; //The method for interpolating. | |
unsigned subpixelDivisions; //The number of samples the function obtains from a pixel. | |
} EdgeOptions; | |
typedef struct EdgeReport_struct { | |
float location; //The location of the edge from the first point in the points array. | |
float contrast; //The contrast at the edge. | |
PolarityType polarity; //The polarity of the edge. | |
float reserved; //This element is reserved. | |
PointFloat coordinate; //The coordinates of the edge. | |
} EdgeReport; | |
typedef struct ExtremeReport_struct { | |
double location; //The locations of the extreme. | |
double amplitude; //The amplitude of the extreme. | |
double secondDerivative; //The second derivative of the extreme. | |
} ExtremeReport; | |
typedef struct FitLineOptions_struct { | |
float minScore; //Specifies the required quality of the fitted line. | |
float pixelRadius; //Specifies the neighborhood pixel relationship for the initial subset of points being used. | |
int numRefinements; //Specifies the number of refinement iterations you allow the function to perform on the initial subset of points. | |
} FitLineOptions; | |
typedef struct DisplayMapping_struct { | |
MappingMethod method; //Describes the method for converting 16-bit pixels to 8-bit pixels. | |
int minimumValue; //When method is IMAQ_RANGE, minimumValue represents the value that is mapped to 0. | |
int maximumValue; //When method is IMAQ_RANGE, maximumValue represents the value that is mapped to 255. | |
int shiftCount; //When method is IMAQ_DOWNSHIFT, shiftCount represents the number of bits the function right-shifts the 16-bit pixel values. | |
} DisplayMapping; | |
typedef struct DetectExtremesOptions_struct { | |
double threshold; //Defines which extremes are too small. | |
int width; //Specifies the number of consecutive data points the function uses in the quadratic least-squares fit. | |
} DetectExtremesOptions; | |
typedef struct ImageInfo_struct { | |
CalibrationUnit imageUnit; //If you set calibration information with imaqSetSimpleCalibrationInfo(), imageUnit is the calibration unit. | |
float stepX; //If you set calibration information with imaqSetCalibrationInfo(), stepX is the distance in the calibration unit between two pixels in the x direction. | |
float stepY; //If you set calibration information with imaqSetCalibrationInfo(), stepY is the distance in the calibration unit between two pixels in the y direction. | |
ImageType imageType; //The type of the image. | |
int xRes; //The number of columns in the image. | |
int yRes; //The number of rows in the image. | |
int xOffset; //If you set mask offset information with imaqSetMaskOffset(), xOffset is the offset of the mask origin in the x direction. | |
int yOffset; //If you set mask offset information with imaqSetMaskOffset(), yOffset is the offset of the mask origin in the y direction. | |
int border; //The number of border pixels around the image. | |
int pixelsPerLine; //The number of pixels stored for each line of the image. | |
void* reserved0; //This element is reserved. | |
void* reserved1; //This element is reserved. | |
void* imageStart; //A pointer to pixel (0,0). | |
} ImageInfo; | |
typedef struct LCDOptions_struct { | |
int litSegments; //Set this parameter to TRUE if the segments are brighter than the background. | |
float threshold; //Determines whether a segment is ON or OFF. | |
int sign; //Indicates whether the function must read the sign of the indicator. | |
int decimalPoint; //Determines whether to look for a decimal separator after each digit. | |
} LCDOptions; | |
typedef struct LCDReport_struct { | |
const char* text; //A string of the characters of the LCD. | |
LCDSegments* segmentInfo; //An array of LCDSegment structures describing which segments of each digit are on. | |
int numCharacters; //The number of characters that the function reads. | |
int reserved; //This element is reserved. | |
} LCDReport; | |
typedef struct LCDSegments_struct { | |
unsigned a:1; //True if the a segment is on. | |
unsigned b:1; //True if the b segment is on. | |
unsigned c:1; //True if the c segment is on. | |
unsigned d:1; //True if the d segment is on. | |
unsigned e:1; //True if the e segment is on. | |
unsigned f:1; //True if the f segment is on. | |
unsigned g:1; //True if the g segment is on. | |
unsigned reserved:25; //This element is reserved. | |
} LCDSegments; | |
typedef struct LearnCalibrationOptions_struct { | |
CalibrationMode mode; //Specifies the type of algorithm you want to use to reduce distortion in your image. | |
ScalingMethod method; //Defines the scaling method correction functions use to correct the image. | |
CalibrationROI roi; //Specifies the ROI correction functions use when correcting an image. | |
int learnMap; //Set this element to TRUE if you want the function to calculate and store an error map during the learning process. | |
int learnTable; //Set this element to TRUE if you want the function to calculate and store the correction table. | |
} LearnCalibrationOptions; | |
typedef struct LearnColorPatternOptions_struct { | |
LearningMode learnMode; //Specifies the invariance mode the function uses when learning the pattern. | |
ImageFeatureMode featureMode; //Specifies the features the function uses when learning the color pattern. | |
int threshold; //Specifies the saturation threshold the function uses to distinguish between two colors that have the same hue values. | |
ColorIgnoreMode ignoreMode; //Specifies whether the function excludes certain colors from the color features of the template image. | |
ColorInformation* colorsToIgnore; //An array of ColorInformation structures providing a set of colors to exclude from the color features of the template image. | |
int numColorsToIgnore; //The number of ColorInformation structures in the colorsToIgnore array. | |
} LearnColorPatternOptions; | |
typedef struct Line_struct { | |
Point start; //The coordinate location of the start of the line. | |
Point end; //The coordinate location of the end of the line. | |
} Line; | |
typedef struct LinearAverages_struct { | |
float* columnAverages; //An array containing the mean pixel value of each column. | |
int columnCount; //The number of elements in the columnAverages array. | |
float* rowAverages; //An array containing the mean pixel value of each row. | |
int rowCount; //The number of elements in the rowAverages array. | |
float* risingDiagAverages; //An array containing the mean pixel value of each diagonal running from the lower left to the upper right of the inspected area of the image. | |
int risingDiagCount; //The number of elements in the risingDiagAverages array. | |
float* fallingDiagAverages; //An array containing the mean pixel value of each diagonal running from the upper left to the lower right of the inspected area of the image. | |
int fallingDiagCount; //The number of elements in the fallingDiagAverages array. | |
} LinearAverages; | |
typedef struct LineProfile_struct { | |
float* profileData; //An array containing the value of each pixel in the line. | |
Rect boundingBox; //The bounding rectangle of the line. | |
float min; //The smallest pixel value in the line profile. | |
float max; //The largest pixel value in the line profile. | |
float mean; //The mean value of the pixels in the line profile. | |
float stdDev; //The standard deviation of the line profile. | |
int dataCount; //The size of the profileData array. | |
} LineProfile; | |
typedef struct MatchColorPatternOptions_struct { | |
MatchingMode matchMode; //Specifies the method to use when looking for the color pattern in the image. | |
ImageFeatureMode featureMode; //Specifies the features to use when looking for the color pattern in the image. | |
int minContrast; //Specifies the minimum contrast expected in the image. | |
int subpixelAccuracy; //Set this parameter to TRUE to return areas in the image that match the pattern area with subpixel accuracy. | |
RotationAngleRange* angleRanges; //An array of angle ranges, in degrees, where each range specifies how much you expect the pattern to be rotated in the image. | |
int numRanges; //Number of angle ranges in the angleRanges array. | |
double colorWeight; //Determines the percent contribution of the color score to the final color pattern matching score. | |
ColorSensitivity sensitivity; //Specifies the sensitivity of the color information in the image. | |
SearchStrategy strategy; //Specifies how the color features of the image are used during the search phase. | |
int numMatchesRequested; //Number of valid matches expected. | |
float minMatchScore; //The minimum score a match can have for the function to consider the match valid. | |
} MatchColorPatternOptions; | |
typedef struct HistogramReport_struct { | |
int* histogram; //An array describing the number of pixels that fell into each class. | |
int histogramCount; //The number of elements in the histogram array. | |
float min; //The smallest pixel value that the function classified. | |
float max; //The largest pixel value that the function classified. | |
float start; //The smallest pixel value that fell into the first class. | |
float width; //The size of each class. | |
float mean; //The mean value of the pixels that the function classified. | |
float stdDev; //The standard deviation of the pixels that the function classified. | |
int numPixels; //The number of pixels that the function classified. | |
} HistogramReport; | |
typedef struct ArcInfo_struct { | |
Rect boundingBox; //The coordinate location of the bounding box of the arc. | |
double startAngle; //The counterclockwise angle from the x-axis in degrees to the start of the arc. | |
double endAngle; //The counterclockwise angle from the x-axis in degrees to the end of the arc. | |
} ArcInfo; | |
typedef struct AxisReport_struct { | |
PointFloat origin; //The origin of the coordinate system, which is the intersection of the two axes of the coordinate system. | |
PointFloat mainAxisEnd; //The end of the main axis, which is the result of the computation of the intersection of the main axis with the rectangular search area. | |
PointFloat secondaryAxisEnd; //The end of the secondary axis, which is the result of the computation of the intersection of the secondary axis with the rectangular search area. | |
} AxisReport; | |
typedef struct BarcodeInfo_struct { | |
const char* outputString; //A string containing the decoded barcode data. | |
int size; //The size of the output string. | |
char outputChar1; //The contents of this character depend on the barcode type. | |
char outputChar2; //The contents of this character depend on the barcode type. | |
double confidenceLevel; //A quality measure of the decoded barcode ranging from 0 to 100, with 100 being the best. | |
BarcodeType type; //The type of barcode. | |
} BarcodeInfo; | |
typedef struct BCGOptions_struct { | |
float brightness; //Adjusts the brightness of the image. | |
float contrast; //Adjusts the contrast of the image. | |
float gamma; //Performs gamma correction. | |
} BCGOptions; | |
typedef struct BestCircle_struct { | |
PointFloat center; //The coordinate location of the center of the circle. | |
double radius; //The radius of the circle. | |
double area; //The area of the circle. | |
double perimeter; //The length of the perimeter of the circle. | |
double error; //Represents the least square error of the fitted circle to the entire set of points. | |
} BestCircle; | |
typedef struct BestEllipse_struct { | |
PointFloat center; //The coordinate location of the center of the ellipse. | |
PointFloat majorAxisStart; //The coordinate location of the start of the major axis of the ellipse. | |
PointFloat majorAxisEnd; //The coordinate location of the end of the major axis of the ellipse. | |
PointFloat minorAxisStart; //The coordinate location of the start of the minor axis of the ellipse. | |
PointFloat minorAxisEnd; //The coordinate location of the end of the minor axis of the ellipse. | |
double area; //The area of the ellipse. | |
double perimeter; //The length of the perimeter of the ellipse. | |
} BestEllipse; | |
typedef struct BestLine_struct { | |
PointFloat start; //The coordinate location of the start of the line. | |
PointFloat end; //The coordinate location of the end of the line. | |
LineEquation equation; //Defines the three coefficients of the equation of the best fit line. | |
int valid; //This element is TRUE if the function achieved the minimum score within the number of allowed refinement iterations and FALSE if the function did not achieve the minimum score. | |
double error; //Represents the least square error of the fitted line to the entire set of points. | |
int* pointsUsed; //An array of the indexes for the points array indicating which points the function used to fit the line. | |
int numPointsUsed; //The number of points the function used to fit the line. | |
} BestLine; | |
typedef struct BrowserOptions_struct { | |
int width; //The width to make the browser. | |
int height; //The height to make the browser image. | |
int imagesPerLine; //The number of images to place on a single line. | |
RGBValue backgroundColor; //The background color of the browser. | |
int frameSize; //Specifies the number of pixels with which to border each thumbnail. | |
BrowserFrameStyle style; //The style for the frame around each thumbnail. | |
float ratio; //Specifies the width to height ratio of each thumbnail. | |
RGBValue focusColor; //The color to use to display focused cells. | |
} BrowserOptions; | |
typedef struct CoordinateSystem_struct { | |
PointFloat origin; //The origin of the coordinate system. | |
float angle; //The angle, in degrees, of the x-axis of the coordinate system relative to the image x-axis. | |
AxisOrientation axisOrientation; //The direction of the y-axis of the coordinate reference system. | |
} CoordinateSystem; | |
typedef struct CalibrationInfo_struct { | |
float* errorMap; //The error map for the calibration. | |
int mapColumns; //The number of columns in the error map. | |
int mapRows; //The number of rows in the error map. | |
ROI* userRoi; //Specifies the ROI the user provided when learning the calibration. | |
ROI* calibrationRoi; //Specifies the ROI that corresponds to the region of the image where the calibration information is accurate. | |
LearnCalibrationOptions options; //Specifies the calibration options the user provided when learning the calibration. | |
GridDescriptor grid; //Specifies the scaling constants for the image. | |
CoordinateSystem system; //Specifies the coordinate system for the real world coordinates. | |
RangeFloat range; //The range of the grayscale the function used to represent the circles in the grid image. | |
float quality; //The quality score of the learning process, which is a value between 0-1000. | |
} CalibrationInfo; | |
typedef struct CalibrationPoints_struct { | |
PointFloat* pixelCoordinates; //The array of pixel coordinates. | |
PointFloat* realWorldCoordinates; //The array of corresponding real-world coordinates. | |
int numCoordinates; //The number of coordinates in both of the arrays. | |
} CalibrationPoints; | |
typedef struct CaliperOptions_struct { | |
TwoEdgePolarityType polarity; //Specifies the edge polarity of the edge pairs. | |
float separation; //The distance between edge pairs. | |
float separationDeviation; //Sets the range around the separation value. | |
} CaliperOptions; | |
typedef struct CaliperReport_struct { | |
float edge1Contrast; //The contrast of the first edge. | |
PointFloat edge1Coord; //The coordinates of the first edge. | |
float edge2Contrast; //The contrast of the second edge. | |
PointFloat edge2Coord; //The coordinates of the second edge. | |
float separation; //The distance between the two edges. | |
float reserved; //This element is reserved. | |
} CaliperReport; | |
typedef struct DrawTextOptions_struct { | |
char fontName[32]; //The font name to use. | |
int fontSize; //The size of the font. | |
int bold; //Set this parameter to TRUE to bold text. | |
int italic; //Set this parameter to TRUE to italicize text. | |
int underline; //Set this parameter to TRUE to underline text. | |
int strikeout; //Set this parameter to TRUE to strikeout text. | |
TextAlignment textAlignment; //Sets the alignment of text. | |
FontColor fontColor; //Sets the font color. | |
} DrawTextOptions; | |
typedef struct CircleReport_struct { | |
Point center; //The coordinate point of the center of the circle. | |
int radius; //The radius of the circle, in pixels. | |
int area; //The area of the circle, in pixels. | |
} CircleReport; | |
typedef struct ClosedContour_struct { | |
Point* points; //The points that make up the closed contour. | |
int numPoints; //The number of points in the array. | |
} ClosedContour; | |
typedef struct ColorHistogramReport_struct { | |
HistogramReport plane1; //The histogram report of the first color plane. | |
HistogramReport plane2; //The histogram report of the second plane. | |
HistogramReport plane3; //The histogram report of the third plane. | |
} ColorHistogramReport; | |
typedef struct ColorInformation_struct { | |
int infoCount; //The size of the info array. | |
int saturation; //The saturation level the function uses to learn the color information. | |
double* info; //An array of color information that represents the color spectrum analysis of a region of an image in a compact form. | |
} ColorInformation; | |
typedef struct Complex_struct { | |
float r; //The real part of the value. | |
float i; //The imaginary part of the value. | |
} Complex; | |
typedef struct ConcentricRakeReport_struct { | |
ArcInfo* rakeArcs; //An array containing the location of each concentric arc line used for edge detection. | |
int numArcs; //The number of arc lines in the rakeArcs array. | |
PointFloat* firstEdges; //The coordinate location of all edges detected as first edges. | |
int numFirstEdges; //The number of points in the first edges array. | |
PointFloat* lastEdges; //The coordinate location of all edges detected as last edges. | |
int numLastEdges; //The number of points in the last edges array. | |
EdgeLocationReport* allEdges; //An array of reports describing the location of the edges located by each concentric rake arc line. | |
int* linesWithEdges; //An array of indices into the rakeArcs array indicating the concentric rake arc lines on which the function detected at least one edge. | |
int numLinesWithEdges; //The number of concentric rake arc lines along which the function detected edges. | |
} ConcentricRakeReport; | |
typedef struct ConstructROIOptions_struct { | |
int windowNumber; //The window number of the image window. | |
const char* windowTitle; //Specifies the message string that the function displays in the title bar of the window. | |
PaletteType type; //The palette type to use. | |
RGBValue* palette; //If type is IMAQ_PALETTE_USER, this array is the palette of colors to use with the window. | |
int numColors; //If type is IMAQ_PALETTE_USER, this element is the number of colors in the palette array. | |
} ConstructROIOptions; | |
typedef struct ContourInfo_struct { | |
ContourType type; //The contour type. | |
unsigned numPoints; //The number of points that make up the contour. | |
Point* points; //The points describing the contour. | |
RGBValue contourColor; //The contour color. | |
} ContourInfo; | |
typedef union ContourUnion_union { | |
Point* point; //Use this member when the contour is of type IMAQ_POINT. | |
Line* line; //Use this member when the contour is of type IMAQ_LINE. | |
Rect* rect; //Use this member when the contour is of type IMAQ_RECT. | |
Rect* ovalBoundingBox; //Use this member when the contour is of type IMAQ_OVAL. | |
ClosedContour* closedContour; //Use this member when the contour is of type IMAQ_CLOSED_CONTOUR. | |
OpenContour* openContour; //Use this member when the contour is of type IMAQ_OPEN_CONTOUR. | |
Annulus* annulus; //Use this member when the contour is of type IMAQ_ANNULUS. | |
RotatedRect* rotatedRect; //Use this member when the contour is of type IMAQ_ROTATED_RECT. | |
} ContourUnion; | |
typedef struct ContourInfo2_struct { | |
ContourType type; //The contour type. | |
RGBValue color; //The contour color. | |
ContourUnion structure; //The information necessary to describe the contour in coordinate space. | |
} ContourInfo2; | |
typedef struct ContourPoint_struct { | |
double x; //The x-coordinate value in the image. | |
double y; //The y-coordinate value in the image. | |
double curvature; //The change in slope at this edge point of the segment. | |
double xDisplacement; //The x displacement of the current edge pixel from a cubic spline fit of the current edge segment. | |
double yDisplacement; //The y displacement of the current edge pixel from a cubic spline fit of the current edge segment. | |
} ContourPoint; | |
typedef struct CoordinateTransform_struct { | |
Point initialOrigin; //The origin of the initial coordinate system. | |
float initialAngle; //The angle, in degrees, of the x-axis of the initial coordinate system relative to the image x-axis. | |
Point finalOrigin; //The origin of the final coordinate system. | |
float finalAngle; //The angle, in degrees, of the x-axis of the final coordinate system relative to the image x-axis. | |
} CoordinateTransform; | |
typedef struct CoordinateTransform2_struct { | |
CoordinateSystem referenceSystem; //Defines the coordinate system for input coordinates. | |
CoordinateSystem measurementSystem; //Defines the coordinate system in which the function should perform measurements. | |
} CoordinateTransform2; | |
typedef struct CannyOptions_struct { | |
float sigma; //The sigma of the Gaussian smoothing filter that the function applies to the image before edge detection. | |
float upperThreshold; //The upper fraction of pixel values in the image from which the function chooses a seed or starting point of an edge segment. | |
float lowerThreshold; //The function multiplies this value by upperThreshold to determine the lower threshold for all the pixels in an edge segment. | |
int windowSize; //The window size of the Gaussian filter that the function applies to the image. | |
} CannyOptions; | |
typedef struct Range_struct { | |
int minValue; //The minimum value of the range. | |
int maxValue; //The maximum value of the range. | |
} Range; | |
typedef struct UserPointSymbol_struct { | |
int cols; //Number of columns in the symbol. | |
int rows; //Number of rows in the symbol. | |
int* pixels; //The pixels of the symbol. | |
} UserPointSymbol; | |
typedef struct View3DOptions_struct { | |
int sizeReduction; //A divisor the function uses when determining the final height and width of the 3D image. | |
int maxHeight; //Defines the maximum height of a pixel from the image source drawn in 3D. | |
Direction3D direction; //Defines the 3D orientation. | |
float alpha; //Determines the angle between the horizontal and the baseline. | |
float beta; //Determines the angle between the horizontal and the second baseline. | |
int border; //Defines the border size. | |
int background; //Defines the background color. | |
Plane3D plane; //Indicates the view a function uses to show complex images. | |
} View3DOptions; | |
typedef struct MatchPatternOptions_struct { | |
MatchingMode mode; //Specifies the method to use when looking for the pattern in the image. | |
int minContrast; //Specifies the minimum contrast expected in the image. | |
int subpixelAccuracy; //Set this element to TRUE to return areas in the image that match the pattern area with subpixel accuracy. | |
RotationAngleRange* angleRanges; //An array of angle ranges, in degrees, where each range specifies how much you expect the pattern to be rotated in the image. | |
int numRanges; //Number of angle ranges in the angleRanges array. | |
int numMatchesRequested; //Number of valid matches expected. | |
int matchFactor; //Controls the number of potential matches that the function examines. | |
float minMatchScore; //The minimum score a match can have for the function to consider the match valid. | |
} MatchPatternOptions; | |
typedef struct TIFFFileOptions_struct { | |
int rowsPerStrip; //Indicates the number of rows that the function writes per strip. | |
PhotometricMode photoInterp; //Designates which photometric interpretation to use. | |
TIFFCompressionType compressionType; //Indicates the type of compression to use on the TIFF file. | |
} TIFFFileOptions; | |
typedef union Color_union { | |
RGBValue rgb; //The information needed to describe a color in the RGB (Red, Green, and Blue) color space. | |
HSLValue hsl; //The information needed to describe a color in the HSL (Hue, Saturation, and Luminance) color space. | |
HSVValue hsv; //The information needed to describe a color in the HSI (Hue, Saturation, and Value) color space. | |
HSIValue hsi; //The information needed to describe a color in the HSI (Hue, Saturation, and Intensity) color space. | |
int rawValue; //The integer value for the data in the color union. | |
} Color; | |
typedef union PixelValue_union { | |
float grayscale; //A grayscale pixel value. | |
RGBValue rgb; //A RGB pixel value. | |
HSLValue hsl; //A HSL pixel value. | |
Complex complex; //A complex pixel value. | |
RGBU64Value rgbu64; //An unsigned 64-bit RGB pixel value. | |
} PixelValue; | |
typedef struct OpenContour_struct { | |
Point* points; //The points that make up the open contour. | |
int numPoints; //The number of points in the array. | |
} OpenContour; | |
typedef struct OverlayTextOptions_struct { | |
const char* fontName; //The name of the font to use. | |
int fontSize; //The size of the font. | |
int bold; //Set this element to TRUE to bold the text. | |
int italic; //Set this element to TRUE to italicize the text. | |
int underline; //Set this element to TRUE to underline the text. | |
int strikeout; //Set this element to TRUE to strikeout the text. | |
TextAlignment horizontalTextAlignment; //Sets the alignment of the text. | |
VerticalTextAlignment verticalTextAlignment; //Sets the vertical alignment for the text. | |
RGBValue backgroundColor; //Sets the color for the text background pixels. | |
double angle; //The counterclockwise angle, in degrees, of the text relative to the x-axis. | |
} OverlayTextOptions; | |
typedef struct ParticleFilterCriteria_struct { | |
MeasurementValue parameter; //The morphological measurement that the function uses for filtering. | |
float lower; //The lower bound of the criteria range. | |
float upper; //The upper bound of the criteria range. | |
int exclude; //Set this element to TRUE to indicate that a match occurs when the value is outside the criteria range. | |
} ParticleFilterCriteria; | |
typedef struct ParticleReport_struct { | |
int area; //The number of pixels in the particle. | |
float calibratedArea; //The size of the particle, calibrated to the calibration information of the image. | |
float perimeter; //The length of the perimeter, calibrated to the calibration information of the image. | |
int numHoles; //The number of holes in the particle. | |
int areaOfHoles; //The total surface area, in pixels, of all the holes in a particle. | |
float perimeterOfHoles; //The length of the perimeter of all the holes in the particle calibrated to the calibration information of the image. | |
Rect boundingBox; //The smallest rectangle that encloses the particle. | |
float sigmaX; //The sum of the particle pixels on the x-axis. | |
float sigmaY; //The sum of the particle pixels on the y-axis. | |
float sigmaXX; //The sum of the particle pixels on the x-axis, squared. | |
float sigmaYY; //The sum of the particle pixels on the y-axis, squared. | |
float sigmaXY; //The sum of the particle pixels on the x-axis and y-axis. | |
int longestLength; //The length of the longest horizontal line segment. | |
Point longestPoint; //The location of the leftmost pixel of the longest segment in the particle. | |
int projectionX; //The length of the particle when projected onto the x-axis. | |
int projectionY; //The length of the particle when projected onto the y-axis. | |
int connect8; //This element is TRUE if the function used connectivity-8 to determine if particles are touching. | |
} ParticleReport; | |
typedef struct PatternMatch_struct { | |
PointFloat position; //The location of the center of the match. | |
float rotation; //The rotation of the match relative to the template image, in degrees. | |
float scale; //The size of the match relative to the size of the template image, expressed as a percentage. | |
float score; //The accuracy of the match. | |
PointFloat corner[4]; //An array of four points describing the rectangle surrounding the template image. | |
} PatternMatch; | |
typedef struct QuantifyData_struct { | |
float mean; //The mean value of the pixel values. | |
float stdDev; //The standard deviation of the pixel values. | |
float min; //The smallest pixel value. | |
float max; //The largest pixel value. | |
float calibratedArea; //The area, calibrated to the calibration information of the image. | |
int pixelArea; //The area, in number of pixels. | |
float relativeSize; //The proportion, expressed as a percentage, of the associated region relative to the whole image. | |
} QuantifyData; | |
typedef struct QuantifyReport_struct { | |
QuantifyData global; //Statistical data of the whole image. | |
QuantifyData* regions; //An array of QuantifyData structures containing statistical data of each region of the image. | |
int regionCount; //The number of regions. | |
} QuantifyReport; | |
typedef struct RakeOptions_struct { | |
int threshold; //Specifies the threshold value for the contrast of the edge. | |
int width; //The number of pixels that the function averages to find the contrast at either side of the edge. | |
int steepness; //The span, in pixels, of the slope of the edge projected along the path specified by the input points. | |
int subsamplingRatio; //Specifies the number of pixels that separate two consecutive search lines. | |
InterpolationMethod subpixelType; //The method for interpolating. | |
int subpixelDivisions; //The number of samples the function obtains from a pixel. | |
} RakeOptions; | |
typedef struct RakeReport_struct { | |
LineFloat* rakeLines; //The coordinate location of each of the rake lines used by the function. | |
int numRakeLines; //The number of lines in the rakeLines array. | |
PointFloat* firstEdges; //The coordinate location of all edges detected as first edges. | |
unsigned int numFirstEdges; //The number of points in the firstEdges array. | |
PointFloat* lastEdges; //The coordinate location of all edges detected as last edges. | |
unsigned int numLastEdges; //The number of points in the lastEdges array. | |
EdgeLocationReport* allEdges; //An array of reports describing the location of the edges located by each rake line. | |
int* linesWithEdges; //An array of indices into the rakeLines array indicating the rake lines on which the function detected at least one edge. | |
int numLinesWithEdges; //The number of rake lines along which the function detected edges. | |
} RakeReport; | |
typedef struct TransformReport_struct { | |
PointFloat* points; //An array of transformed coordinates. | |
int* validPoints; //An array of values that describe the validity of each of the coordinates according to the region of interest you calibrated using either imaqLearnCalibrationGrid() or imaqLearnCalibrationPoints(). | |
int numPoints; //The length of both the points array and the validPoints array. | |
} TransformReport; | |
typedef struct ShapeReport_struct { | |
Rect coordinates; //The bounding rectangle of the object. | |
Point centroid; //The coordinate location of the centroid of the object. | |
int size; //The size, in pixels, of the object. | |
double score; //A value ranging between 1 and 1,000 that specifies how similar the object in the image is to the template. | |
} ShapeReport; | |
typedef struct MeterArc_struct { | |
PointFloat needleBase; //The coordinate location of the base of the meter needle. | |
PointFloat* arcCoordPoints; //An array of points describing the coordinate location of the meter arc. | |
int numOfArcCoordPoints; //The number of points in the arcCoordPoints array. | |
int needleColor; //This element is TRUE when the meter has a light-colored needle on a dark background. | |
} MeterArc; | |
typedef struct ThresholdData_struct { | |
float rangeMin; //The lower boundary of the range to keep. | |
float rangeMax; //The upper boundary of the range to keep. | |
float newValue; //If useNewValue is TRUE, newValue is the replacement value for pixels within the range. | |
int useNewValue; //If TRUE, the function sets pixel values within [rangeMin, rangeMax] to the value specified in newValue. | |
} ThresholdData; | |
typedef struct StructuringElement_struct { | |
int matrixCols; //Number of columns in the matrix. | |
int matrixRows; //Number of rows in the matrix. | |
int hexa; //Set this element to TRUE if you specify a hexagonal structuring element in kernel. | |
int* kernel; //The values of the structuring element. | |
} StructuringElement; | |
typedef struct SpokeReport_struct { | |
LineFloat* spokeLines; //The coordinate location of each of the spoke lines used by the function. | |
int numSpokeLines; //The number of lines in the spokeLines array. | |
PointFloat* firstEdges; //The coordinate location of all edges detected as first edges. | |
int numFirstEdges; //The number of points in the firstEdges array. | |
PointFloat* lastEdges; //The coordinate location of all edges detected as last edges. | |
int numLastEdges; //The number of points in the lastEdges array. | |
EdgeLocationReport* allEdges; //An array of reports describing the location of the edges located by each spoke line. | |
int* linesWithEdges; //An array of indices into the spokeLines array indicating the rake lines on which the function detected at least one edge. | |
int numLinesWithEdges; //The number of spoke lines along which the function detects edges. | |
} SpokeReport; | |
typedef struct SimpleEdgeOptions_struct { | |
LevelType type; //Determines how the function evaluates the threshold and hysteresis values. | |
int threshold; //The pixel value at which an edge occurs. | |
int hysteresis; //A value that helps determine edges in noisy images. | |
EdgeProcess process; //Determines which edges the function looks for. | |
int subpixel; //Set this element to TRUE to find edges with subpixel accuracy by interpolating between points to find the crossing of the given threshold. | |
} SimpleEdgeOptions; | |
typedef struct SelectParticleCriteria_struct { | |
MeasurementValue parameter; //The morphological measurement that the function uses for filtering. | |
float lower; //The lower boundary of the criteria range. | |
float upper; //The upper boundary of the criteria range. | |
} SelectParticleCriteria; | |
typedef struct SegmentInfo_struct { | |
int numberOfPoints; //The number of points in the segment. | |
int isOpen; //If TRUE, the contour is open. | |
double weight; //The significance of the edge in terms of the gray values that constitute the edge. | |
ContourPoint* points; //The points of the segment. | |
} SegmentInfo; | |
typedef struct RotationAngleRange_struct { | |
float lower; //The lowest amount of rotation, in degrees, a valid pattern can have. | |
float upper; //The highest amount of rotation, in degrees, a valid pattern can have. | |
} RotationAngleRange; | |
typedef struct RotatedRect_struct { | |
int top; //Location of the top edge of the rectangle before rotation. | |
int left; //Location of the left edge of the rectangle before rotation. | |
int height; //Height of the rectangle. | |
int width; //Width of the rectangle. | |
double angle; //The rotation, in degrees, of the rectangle. | |
} RotatedRect; | |
typedef struct ROIProfile_struct { | |
LineProfile report; //Quantifying information about the points along the edge of each contour in the ROI. | |
Point* pixels; //An array of the points along the edge of each contour in the ROI. | |
} ROIProfile; | |
typedef struct ToolWindowOptions_struct { | |
int showSelectionTool; //If TRUE, the selection tool becomes visible. | |
int showZoomTool; //If TRUE, the zoom tool becomes visible. | |
int showPointTool; //If TRUE, the point tool becomes visible. | |
int showLineTool; //If TRUE, the line tool becomes visible. | |
int showRectangleTool; //If TRUE, the rectangle tool becomes visible. | |
int showOvalTool; //If TRUE, the oval tool becomes visible. | |
int showPolygonTool; //If TRUE, the polygon tool becomes visible. | |
int showClosedFreehandTool; //If TRUE, the closed freehand tool becomes visible. | |
int showPolyLineTool; //If TRUE, the polyline tool becomes visible. | |
int showFreehandTool; //If TRUE, the freehand tool becomes visible. | |
int showAnnulusTool; //If TRUE, the annulus becomes visible. | |
int showRotatedRectangleTool; //If TRUE, the rotated rectangle tool becomes visible. | |
int showPanTool; //If TRUE, the pan tool becomes visible. | |
int showZoomOutTool; //If TRUE, the zoom out tool becomes visible. | |
int reserved2; //This element is reserved and should be set to FALSE. | |
int reserved3; //This element is reserved and should be set to FALSE. | |
int reserved4; //This element is reserved and should be set to FALSE. | |
} ToolWindowOptions; | |
typedef struct SpokeOptions_struct { | |
int threshold; //Specifies the threshold value for the contrast of the edge. | |
int width; //The number of pixels that the function averages to find the contrast at either side of the edge. | |
int steepness; //The span, in pixels, of the slope of the edge projected along the path specified by the input points. | |
double subsamplingRatio; //The angle, in degrees, between each radial search line in the spoke. | |
InterpolationMethod subpixelType; //The method for interpolating. | |
int subpixelDivisions; //The number of samples the function obtains from a pixel. | |
} SpokeOptions; | |
#if !defined __GNUC__ && !defined _M_X64 | |
#pragma pack(pop) | |
#endif | |
//============================================================================ | |
// Callback Function Type | |
//============================================================================ | |
#ifndef __GNUC__ | |
typedef void (IMAQ_CALLBACK* EventCallback)(WindowEventType event, int windowNumber, Tool tool, Rect rect); | |
#endif | |
//============================================================================ | |
// Globals | |
//============================================================================ | |
#ifndef __GNUC__ | |
#pragma const_seg("IMAQVisionColorConstants") | |
#endif | |
static const RGBValue IMAQ_RGB_TRANSPARENT = { 0, 0, 0, 1 }; | |
static const RGBValue IMAQ_RGB_RED = { 0, 0, 255, 0 }; | |
static const RGBValue IMAQ_RGB_BLUE = { 255, 0, 0, 0 }; | |
static const RGBValue IMAQ_RGB_GREEN = { 0, 255, 0, 0 }; | |
static const RGBValue IMAQ_RGB_YELLOW = { 0, 255, 255, 0 }; | |
static const RGBValue IMAQ_RGB_WHITE = { 255, 255, 255, 0 }; | |
static const RGBValue IMAQ_RGB_BLACK = { 0, 0, 0, 0 }; | |
#ifndef __GNUC__ | |
#pragma const_seg() | |
#endif | |
//============================================================================ | |
// Backwards Compatibility | |
//============================================================================ | |
typedef ColorSensitivity ColorComplexity; | |
#define IMAQ_COMPLEXITY_LOW IMAQ_SENSITIVITY_LOW | |
#define IMAQ_COMPLEXITY_MED IMAQ_SENSITIVITY_MED | |
#define IMAQ_COMPLEXITY_HIGH IMAQ_SENSITIVITY_HIGH | |
#define ERR_INVALID_COLORCOMPLEXITY ERR_INVALID_COLORSENSITIVITY | |
//============================================================================ | |
// Logical functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqAnd(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqAndConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCompare(Image* dest, const Image* source, const Image* compareImage, ComparisonFunction compare); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCompareConstant(Image* dest, const Image* source, PixelValue value, ComparisonFunction compare); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLogicalDifference(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLogicalDifferenceConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqNand(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqNandConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqNor(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqNorConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOr(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOrConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqXnor(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqXnorConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqXor(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqXorConstant(Image* dest, const Image* source, PixelValue value); | |
//============================================================================ | |
// Particle Analysis functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCountParticles(Image* image, int connectivity8, int* numParticles); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMeasureParticle(Image* image, int particleNumber, int calibrated, MeasurementType measurement, double* value); | |
IMAQ_FUNC MeasureParticlesReport* IMAQ_STDCALL imaqMeasureParticles(Image* image, MeasureParticlesCalibrationMode calibrationMode, const MeasurementType* measurements, size_t numMeasurements); | |
IMAQ_FUNC int IMAQ_STDCALL imaqParticleFilter4(Image* dest, Image* source, const ParticleFilterCriteria2* criteria, int criteriaCount, const ParticleFilterOptions2* options, const ROI* roi, int* numParticles); | |
//============================================================================ | |
// Morphology functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqConvexHull(Image* dest, Image* source, int connectivity8); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDanielssonDistance(Image* dest, Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFillHoles(Image* dest, const Image* source, int connectivity8); | |
IMAQ_FUNC CircleReport* IMAQ_STDCALL imaqFindCircles(Image* dest, Image* source, float minRadius, float maxRadius, int* numCircles); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLabel2(Image* dest, Image* source, int connectivity8, int* particleCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMorphology(Image* dest, Image* source, MorphologyMethod method, const StructuringElement* structuringElement); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRejectBorder(Image* dest, Image* source, int connectivity8); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSegmentation(Image* dest, Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSeparation(Image* dest, Image* source, int erosions, const StructuringElement* structuringElement); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSimpleDistance(Image* dest, Image* source, const StructuringElement* structuringElement); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSizeFilter(Image* dest, Image* source, int connectivity8, int erosions, SizeType keepSize, const StructuringElement* structuringElement); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSkeleton(Image* dest, Image* source, SkeletonMethod method); | |
//============================================================================ | |
// Acquisition functions | |
//============================================================================ | |
IMAQ_FUNC Image* IMAQ_STDCALL imaqCopyFromRing(SESSION_ID sessionID, Image* image, int imageToCopy, int* imageNumber, Rect rect); | |
IMAQ_FUNC Image* IMAQ_STDCALL imaqEasyAcquire(const char* interfaceName); | |
IMAQ_FUNC Image* IMAQ_STDCALL imaqExtractFromRing(SESSION_ID sessionID, int imageToExtract, int* imageNumber); | |
IMAQ_FUNC Image* IMAQ_STDCALL imaqGrab(SESSION_ID sessionID, Image* image, int immediate); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReleaseImage(SESSION_ID sessionID); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetupGrab(SESSION_ID sessionID, Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetupRing(SESSION_ID sessionID, Image** images, int numImages, int skipCount, Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetupSequence(SESSION_ID sessionID, Image** images, int numImages, int skipCount, Rect rect); | |
IMAQ_FUNC Image* IMAQ_STDCALL imaqSnap(SESSION_ID sessionID, Image* image, Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqStartAcquisition(SESSION_ID sessionID); | |
IMAQ_FUNC int IMAQ_STDCALL imaqStopAcquisition(SESSION_ID sessionID); | |
//============================================================================ | |
// Arithmetic functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqAbsoluteDifference(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqAbsoluteDifferenceConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqAdd(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqAddConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqAverage(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqAverageConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDivide2(Image* dest, const Image* sourceA, const Image* sourceB, RoundingMode roundingMode); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDivideConstant2(Image* dest, const Image* source, PixelValue value, RoundingMode roundingMode); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMax(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMaxConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMin(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMinConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqModulo(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqModuloConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMulDiv(Image* dest, const Image* sourceA, const Image* sourceB, float value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMultiply(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMultiplyConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSubtract(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSubtractConstant(Image* dest, const Image* source, PixelValue value); | |
//============================================================================ | |
// Caliper functions | |
//============================================================================ | |
IMAQ_FUNC CaliperReport* IMAQ_STDCALL imaqCaliperTool(const Image* image, const Point* points, int numPoints, const EdgeOptions* edgeOptions, const CaliperOptions* caliperOptions, int* numEdgePairs); | |
IMAQ_FUNC ConcentricRakeReport2* IMAQ_STDCALL imaqConcentricRake2(Image* image, ROI* roi, ConcentricRakeDirection direction, EdgeProcess process, int stepSize, EdgeOptions2* edgeOptions); | |
IMAQ_FUNC ExtremeReport* IMAQ_STDCALL imaqDetectExtremes(const double* pixels, int numPixels, DetectionMode mode, const DetectExtremesOptions* options, int* numExtremes); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDetectRotation(const Image* referenceImage, const Image* testImage, PointFloat referenceCenter, PointFloat testCenter, int radius, float precision, double* angle); | |
IMAQ_FUNC EdgeReport2* IMAQ_STDCALL imaqEdgeTool4(Image* image, ROI* roi, EdgeProcess processType, EdgeOptions2* edgeOptions, const unsigned int reverseDirection); | |
IMAQ_FUNC FindEdgeReport* IMAQ_STDCALL imaqFindEdge2(Image* image, const ROI* roi, const CoordinateSystem* baseSystem, const CoordinateSystem* newSystem, const FindEdgeOptions2* findEdgeOptions, const StraightEdgeOptions* straightEdgeOptions); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFindTransformRect2(Image* image, const ROI* roi, FindTransformMode mode, CoordinateSystem* baseSystem, CoordinateSystem* newSystem, const FindTransformRectOptions2* findTransformOptions, const StraightEdgeOptions* straightEdgeOptions, AxisReport* axisReport); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFindTransformRects2(Image* image, const ROI* primaryROI, const ROI* secondaryROI, FindTransformMode mode, CoordinateSystem* baseSystem, CoordinateSystem* newSystem, const FindTransformRectsOptions2* findTransformOptions, const StraightEdgeOptions* primaryStraightEdgeOptions, const StraightEdgeOptions* secondaryStraightEdgeOptions, AxisReport* axisReport); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLineGaugeTool2(const Image* image, Point start, Point end, LineGaugeMethod method, const EdgeOptions* edgeOptions, const CoordinateTransform2* transform, float* distance); | |
IMAQ_FUNC RakeReport2* IMAQ_STDCALL imaqRake2(Image* image, ROI* roi, RakeDirection direction, EdgeProcess process, int stepSize, EdgeOptions2* edgeOptions); | |
IMAQ_FUNC PointFloat* IMAQ_STDCALL imaqSimpleEdge(const Image* image, const Point* points, int numPoints, const SimpleEdgeOptions* options, int* numEdges); | |
IMAQ_FUNC SpokeReport2* IMAQ_STDCALL imaqSpoke2(Image* image, ROI* roi, SpokeDirection direction, EdgeProcess process, int stepSize, EdgeOptions2* edgeOptions); | |
IMAQ_FUNC StraightEdgeReport2* IMAQ_STDCALL imaqStraightEdge(const Image* image, const ROI* roi, SearchDirection searchDirection, const EdgeOptions2* edgeOptions, const StraightEdgeOptions* straightEdgeOptions); | |
IMAQ_FUNC StraightEdgeReport2* IMAQ_STDCALL imaqStraightEdge2(const Image* image, const ROI* roi, SearchDirection searchDirection, const EdgeOptions2* edgeOptions, const StraightEdgeOptions* straightEdgeOptions, unsigned int optimizedMode); | |
//============================================================================ | |
// Spatial Filters functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCannyEdgeFilter(Image* dest, const Image* source, const CannyOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqConvolve2(Image* dest, Image* source, float* kernel, int matrixRows, int matrixCols, float normalize, Image* mask, RoundingMode roundingMode); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCorrelate(Image* dest, Image* source, const Image* templateImage, Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqEdgeFilter(Image* dest, Image* source, OutlineMethod method, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLowPass(Image* dest, Image* source, int width, int height, float tolerance, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMedianFilter(Image* dest, Image* source, int width, int height, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqNthOrderFilter(Image* dest, Image* source, int width, int height, int n, const Image* mask); | |
//============================================================================ | |
// Drawing functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqDrawLineOnImage(Image* dest, const Image* source, DrawMode mode, Point start, Point end, float newPixelValue); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDrawShapeOnImage(Image* dest, const Image* source, Rect rect, DrawMode mode, ShapeMode shape, float newPixelValue); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDrawTextOnImage(Image* dest, const Image* source, Point coord, const char* text, const DrawTextOptions* options, int* fontNameUsed); | |
//============================================================================ | |
// Interlacing functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqInterlaceCombine(Image* frame, const Image* odd, const Image* even); | |
IMAQ_FUNC int IMAQ_STDCALL imaqInterlaceSeparate(const Image* frame, Image* odd, Image* even); | |
//============================================================================ | |
// Image Information functions | |
//============================================================================ | |
IMAQ_FUNC char** IMAQ_STDCALL imaqEnumerateCustomKeys(const Image* image, unsigned int* size); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetBitDepth(const Image* image, unsigned int* bitDepth); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetBytesPerPixel(const Image* image, int* byteCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetImageInfo(const Image* image, ImageInfo* info); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetImageSize(const Image* image, int* width, int* height); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetImageType(const Image* image, ImageType* type); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetMaskOffset(const Image* image, Point* offset); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqGetPixelAddress(const Image* image, Point pixel); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetVisionInfoTypes(const Image* image, unsigned int* present); | |
IMAQ_FUNC int IMAQ_STDCALL imaqIsImageEmpty(const Image* image, int* empty); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqReadCustomData(const Image* image, const char* key, unsigned int* size); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRemoveCustomData(Image* image, const char* key); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRemoveVisionInfo2(const Image* image, unsigned int info); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetBitDepth(Image* image, unsigned int bitDepth); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetImageSize(Image* image, int width, int height); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetMaskOffset(Image* image, Point offset); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteCustomData(Image* image, const char* key, const void* data, unsigned int size); | |
//============================================================================ | |
// Display functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqAreToolsContextSensitive(int* sensitive); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCloseWindow(int windowNumber); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDisplayImage(const Image* image, int windowNumber, int resize); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetLastKey(char* keyPressed, int* windowNumber, int* modifiers); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqGetSystemWindowHandle(int windowNumber); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowCenterPos(int windowNumber, Point* centerPosition); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetToolContextSensitivity(int sensitive); | |
IMAQ_FUNC int IMAQ_STDCALL imaqShowWindow(int windowNumber, int visible); | |
//============================================================================ | |
// Image Manipulation functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCast(Image* dest, const Image* source, ImageType type, const float* lookup, int shift); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCopyRect(Image* dest, const Image* source, Rect rect, Point destLoc); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDuplicate(Image* dest, const Image* source); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqFlatten(const Image* image, FlattenType type, CompressionType compression, int quality, unsigned int* size); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFlip(Image* dest, const Image* source, FlipAxis axis); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMask(Image* dest, const Image* source, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqResample(Image* dest, const Image* source, int newWidth, int newHeight, InterpolationMethod method, Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRotate2(Image* dest, const Image* source, float angle, PixelValue fill, InterpolationMethod method, int maintainSize); | |
IMAQ_FUNC int IMAQ_STDCALL imaqScale(Image* dest, const Image* source, int xScale, int yScale, ScalingMode scaleMode, Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqShift(Image* dest, const Image* source, int shiftX, int shiftY, PixelValue fill); | |
IMAQ_FUNC int IMAQ_STDCALL imaqTranspose(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqUnflatten(Image* image, const void* data, unsigned int size); | |
IMAQ_FUNC int IMAQ_STDCALL imaqUnwrapImage(Image* dest, const Image* source, Annulus annulus, RectOrientation orientation, InterpolationMethod method); | |
IMAQ_FUNC int IMAQ_STDCALL imaqView3D(Image* dest, Image* source, const View3DOptions* options); | |
//============================================================================ | |
// File I/O functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCloseAVI(AVISession session); | |
IMAQ_FUNC AVISession IMAQ_STDCALL imaqCreateAVI(const char* fileName, const char* compressionFilter, int quality, unsigned int framesPerSecond, unsigned int maxDataSize); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetAVIInfo(AVISession session, AVIInfo* info); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetFileInfo(const char* fileName, CalibrationUnit* calibrationUnit, float* calibrationX, float* calibrationY, int* width, int* height, ImageType* imageType); | |
IMAQ_FUNC FilterName* IMAQ_STDCALL imaqGetFilterNames(int* numFilters); | |
IMAQ_FUNC char** IMAQ_STDCALL imaqLoadImagePopup(const char* defaultDirectory, const char* defaultFileSpec, const char* fileTypeList, const char* title, int allowMultiplePaths, ButtonLabel buttonLabel, int restrictDirectory, int restrictExtension, int allowCancel, int allowMakeDirectory, int* cancelled, int* numPaths); | |
IMAQ_FUNC AVISession IMAQ_STDCALL imaqOpenAVI(const char* fileName); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReadAVIFrame(Image* image, AVISession session, unsigned int frameNum, void* data, unsigned int* dataSize); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReadFile(Image* image, const char* fileName, RGBValue* colorTable, int* numColors); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReadVisionFile(Image* image, const char* fileName, RGBValue* colorTable, int* numColors); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteAVIFrame(Image* image, AVISession session, const void* data, unsigned int dataLength); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteBMPFile(const Image* image, const char* fileName, int compress, const RGBValue* colorTable); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteFile(const Image* image, const char* fileName, const RGBValue* colorTable); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteJPEGFile(const Image* image, const char* fileName, unsigned int quality, void* colorTable); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteJPEG2000File(const Image* image, const char* fileName, int lossless, float compressionRatio, const JPEG2000FileAdvancedOptions* advancedOptions, const RGBValue* colorTable); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWritePNGFile2(const Image* image, const char* fileName, unsigned int compressionSpeed, const RGBValue* colorTable, int useBitDepth); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteTIFFFile(const Image* image, const char* fileName, const TIFFFileOptions* options, const RGBValue* colorTable); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteVisionFile(const Image* image, const char* fileName, const RGBValue* colorTable); | |
//============================================================================ | |
// Analytic Geometry functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqBuildCoordinateSystem(const Point* points, ReferenceMode mode, AxisOrientation orientation, CoordinateSystem* system); | |
IMAQ_FUNC BestCircle2* IMAQ_STDCALL imaqFitCircle2(const PointFloat* points, int numPoints, const FitCircleOptions* options); | |
IMAQ_FUNC BestEllipse2* IMAQ_STDCALL imaqFitEllipse2(const PointFloat* points, int numPoints, const FitEllipseOptions* options); | |
IMAQ_FUNC BestLine* IMAQ_STDCALL imaqFitLine(const PointFloat* points, int numPoints, const FitLineOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetAngle(PointFloat start1, PointFloat end1, PointFloat start2, PointFloat end2, float* angle); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetBisectingLine(PointFloat start1, PointFloat end1, PointFloat start2, PointFloat end2, PointFloat* bisectStart, PointFloat* bisectEnd); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetDistance(PointFloat point1, PointFloat point2, float* distance); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetIntersection(PointFloat start1, PointFloat end1, PointFloat start2, PointFloat end2, PointFloat* intersection); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetMidLine(PointFloat refLineStart, PointFloat refLineEnd, PointFloat point, PointFloat* midLineStart, PointFloat* midLineEnd); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetPerpendicularLine(PointFloat refLineStart, PointFloat refLineEnd, PointFloat point, PointFloat* perpLineStart, PointFloat* perpLineEnd, double* distance); | |
IMAQ_FUNC SegmentInfo* IMAQ_STDCALL imaqGetPointsOnContour(const Image* image, int* numSegments); | |
IMAQ_FUNC Point* IMAQ_STDCALL imaqGetPointsOnLine(Point start, Point end, int* numPoints); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetPolygonArea(const PointFloat* points, int numPoints, float* area); | |
IMAQ_FUNC float* IMAQ_STDCALL imaqInterpolatePoints(const Image* image, const Point* points, int numPoints, InterpolationMethod method, int subpixel, int* interpCount); | |
//============================================================================ | |
// Clipboard functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqClipboardToImage(Image* dest, RGBValue* palette); | |
IMAQ_FUNC int IMAQ_STDCALL imaqImageToClipboard(const Image* image, const RGBValue* palette); | |
//============================================================================ | |
// Border functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqFillBorder(Image* image, BorderMethod method); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetBorderSize(const Image* image, int* borderSize); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetBorderSize(Image* image, int size); | |
//============================================================================ | |
// Image Management functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqArrayToImage(Image* image, const void* array, int numCols, int numRows); | |
IMAQ_FUNC Image* IMAQ_STDCALL imaqCreateImage(ImageType type, int borderSize); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqImageToArray(const Image* image, Rect rect, int* columns, int* rows); | |
//============================================================================ | |
// Color Processing functions | |
//============================================================================ | |
IMAQ_FUNC Color2 IMAQ_STDCALL imaqChangeColorSpace2(const Color2* sourceColor, ColorMode sourceSpace, ColorMode destSpace, double offset, const CIEXYZValue* whiteReference); | |
IMAQ_FUNC int IMAQ_STDCALL imaqColorBCGTransform(Image* dest, const Image* source, const BCGOptions* redOptions, const BCGOptions* greenOptions, const BCGOptions* blueOptions, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqColorEqualize(Image* dest, const Image* source, int colorEqualization); | |
IMAQ_FUNC ColorHistogramReport* IMAQ_STDCALL imaqColorHistogram2(Image* image, int numClasses, ColorMode mode, const CIEXYZValue* whiteReference, Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqColorLookup(Image* dest, const Image* source, ColorMode mode, const Image* mask, const short* plane1, const short* plane2, const short* plane3); | |
IMAQ_FUNC int IMAQ_STDCALL imaqColorThreshold(Image* dest, const Image* source, int replaceValue, ColorMode mode, const Range* plane1Range, const Range* plane2Range, const Range* plane3Range); | |
IMAQ_FUNC SupervisedColorSegmentationReport* IMAQ_STDCALL imaqSupervisedColorSegmentation(ClassifierSession* session, Image* labelImage, const Image* srcImage, const ROI* roi, const ROILabel* labelIn, unsigned int numLabelIn, int maxDistance, int minIdentificationScore, const ColorSegmenationOptions* segmentOptions); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetColorSegmentationMaxDistance(ClassifierSession* session, const ColorSegmenationOptions* segmentOptions, SegmentationDistanceLevel distLevel, int* maxDistance); | |
//============================================================================ | |
// Transform functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqBCGTransform(Image* dest, const Image* source, const BCGOptions* options, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqEqualize(Image* dest, const Image* source, float min, float max, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqInverse(Image* dest, const Image* source, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMathTransform(Image* dest, const Image* source, MathTransformMethod method, float rangeMin, float rangeMax, float power, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWatershedTransform(Image* dest, const Image* source, int connectivity8, int* zoneCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLookup2(Image* dest, const Image* source, const int* table, const Image* mask); | |
//============================================================================ | |
// Window Management functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqAreScrollbarsVisible(int windowNumber, int* visible); | |
IMAQ_FUNC int IMAQ_STDCALL imaqBringWindowToTop(int windowNumber); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetMousePos(Point* position, int* windowNumber); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowBackground(int windowNumber, WindowBackgroundFillStyle* fillStyle, WindowBackgroundHatchStyle* hatchStyle, RGBValue* fillColor, RGBValue* backgroundColor); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowDisplayMapping(int windowNum, DisplayMapping* mapping); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowGrid(int windowNumber, int* xResolution, int* yResolution); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowHandle(int* handle); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowPos(int windowNumber, Point* position); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowSize(int windowNumber, int* width, int* height); | |
IMAQ_FUNC char* IMAQ_STDCALL imaqGetWindowTitle(int windowNumber); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowZoom2(int windowNumber, float* xZoom, float* yZoom); | |
IMAQ_FUNC int IMAQ_STDCALL imaqIsWindowNonTearing(int windowNumber, int* nonTearing); | |
IMAQ_FUNC int IMAQ_STDCALL imaqIsWindowVisible(int windowNumber, int* visible); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMoveWindow(int windowNumber, Point position); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetupWindow(int windowNumber, int configuration); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowBackground(int windowNumber, WindowBackgroundFillStyle fillStyle, WindowBackgroundHatchStyle hatchStyle, const RGBValue* fillColor, const RGBValue* backgroundColor); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowDisplayMapping(int windowNumber, const DisplayMapping* mapping); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowGrid(int windowNumber, int xResolution, int yResolution); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowMaxContourCount(int windowNumber, unsigned int maxContourCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowNonTearing(int windowNumber, int nonTearing); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowPalette(int windowNumber, PaletteType type, const RGBValue* palette, int numColors); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowSize(int windowNumber, int width, int height); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowThreadPolicy(WindowThreadPolicy policy); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowTitle(int windowNumber, const char* title); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowZoomToFit(int windowNumber, int zoomToFit); | |
IMAQ_FUNC int IMAQ_STDCALL imaqShowScrollbars(int windowNumber, int visible); | |
IMAQ_FUNC int IMAQ_STDCALL imaqZoomWindow2(int windowNumber, float xZoom, float yZoom, Point center); | |
//============================================================================ | |
// Utilities functions | |
//============================================================================ | |
IMAQ_FUNC const float* IMAQ_STDCALL imaqGetKernel(KernelFamily family, int size, int number); | |
IMAQ_FUNC Annulus IMAQ_STDCALL imaqMakeAnnulus(Point center, int innerRadius, int outerRadius, double startAngle, double endAngle); | |
IMAQ_FUNC Point IMAQ_STDCALL imaqMakePoint(int xCoordinate, int yCoordinate); | |
IMAQ_FUNC PointFloat IMAQ_STDCALL imaqMakePointFloat(float xCoordinate, float yCoordinate); | |
IMAQ_FUNC Rect IMAQ_STDCALL imaqMakeRect(int top, int left, int height, int width); | |
IMAQ_FUNC Rect IMAQ_STDCALL imaqMakeRectFromRotatedRect(RotatedRect rotatedRect); | |
IMAQ_FUNC RotatedRect IMAQ_STDCALL imaqMakeRotatedRect(int top, int left, int height, int width, double angle); | |
IMAQ_FUNC RotatedRect IMAQ_STDCALL imaqMakeRotatedRectFromRect(Rect rect); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMulticoreOptions(MulticoreOperation operation, unsigned int* customNumCores); | |
//============================================================================ | |
// Tool Window functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCloseToolWindow(void); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetCurrentTool(Tool* currentTool); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetLastEvent(WindowEventType* type, int* windowNumber, Tool* tool, Rect* rect); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqGetToolWindowHandle(void); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetToolWindowPos(Point* position); | |
IMAQ_FUNC int IMAQ_STDCALL imaqIsToolWindowVisible(int* visible); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMoveToolWindow(Point position); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetCurrentTool(Tool currentTool); | |
#ifndef __GNUC__ | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetEventCallback(EventCallback callback, int synchronous); | |
#endif | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetToolColor(const RGBValue* color); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetupToolWindow(int showCoordinates, int maxIconsPerLine, const ToolWindowOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqShowToolWindow(int visible); | |
//============================================================================ | |
// Meter functions | |
//============================================================================ | |
IMAQ_FUNC MeterArc* IMAQ_STDCALL imaqGetMeterArc(int lightNeedle, MeterArcMode mode, const ROI* roi, PointFloat base, PointFloat start, PointFloat end); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReadMeter(const Image* image, const MeterArc* arcInfo, double* percentage, PointFloat* endOfNeedle); | |
//============================================================================ | |
// Calibration functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCopyCalibrationInfo2(Image* dest, Image* source, Point offset); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCorrectCalibratedImage(Image* dest, const Image* source, PixelValue fill, InterpolationMethod method, const ROI* roi); | |
IMAQ_FUNC CalibrationInfo* IMAQ_STDCALL imaqGetCalibrationInfo2(const Image* image); | |
IMAQ_FUNC CalibrationInfo* IMAQ_STDCALL imaqGetCalibrationInfo3(Image* image, unsigned int isGetErrorMap); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnCalibrationGrid(Image* image, const ROI* roi, const LearnCalibrationOptions* options, const GridDescriptor* grid, const CoordinateSystem* system, const RangeFloat* range, float* quality); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnCalibrationPoints(Image* image, const CalibrationPoints* points, const ROI* roi, const LearnCalibrationOptions* options, const GridDescriptor* grid, const CoordinateSystem* system, float* quality); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetCoordinateSystem(Image* image, const CoordinateSystem* system); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetSimpleCalibration(Image* image, ScalingMethod method, int learnTable, const GridDescriptor* grid, const CoordinateSystem* system); | |
IMAQ_FUNC TransformReport* IMAQ_STDCALL imaqTransformPixelToRealWorld(const Image* image, const PointFloat* pixelCoordinates, int numCoordinates); | |
IMAQ_FUNC TransformReport* IMAQ_STDCALL imaqTransformRealWorldToPixel(const Image* image, const PointFloat* realWorldCoordinates, int numCoordinates); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetSimpleCalibration2(Image* image, const GridDescriptor* gridDescriptor); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCalibrationSetAxisInfo(Image* image, CoordinateSystem* axisInfo); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCalibrationGetThumbnailImage(Image* templateImage, Image* image, CalibrationThumbnailType type, unsigned int index); | |
IMAQ_FUNC GetCalibrationInfoReport* IMAQ_STDCALL imaqCalibrationGetCalibrationInfo(Image* image, unsigned int isGetErrorMap); | |
IMAQ_FUNC GetCameraParametersReport* IMAQ_STDCALL imaqCalibrationGetCameraParameters(Image* templateImage); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCalibrationCompactInformation(Image* image); | |
//============================================================================ | |
// Pixel Manipulation functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqArrayToComplexPlane(Image* dest, const Image* source, const float* newPixels, ComplexPlane plane); | |
IMAQ_FUNC float* IMAQ_STDCALL imaqComplexPlaneToArray(const Image* image, ComplexPlane plane, Rect rect, int* rows, int* columns); | |
IMAQ_FUNC int IMAQ_STDCALL imaqExtractColorPlanes(const Image* image, ColorMode mode, Image* plane1, Image* plane2, Image* plane3); | |
IMAQ_FUNC int IMAQ_STDCALL imaqExtractComplexPlane(Image* dest, const Image* source, ComplexPlane plane); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFillImage(Image* image, PixelValue value, const Image* mask); | |
IMAQ_FUNC void* IMAQ_STDCALL imaqGetLine(const Image* image, Point start, Point end, int* numPoints); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetPixel(const Image* image, Point pixel, PixelValue* value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReplaceColorPlanes(Image* dest, const Image* source, ColorMode mode, const Image* plane1, const Image* plane2, const Image* plane3); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReplaceComplexPlane(Image* dest, const Image* source, const Image* newValues, ComplexPlane plane); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetLine(Image* image, const void* array, int arraySize, Point start, Point end); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetPixel(Image* image, Point coord, PixelValue value); | |
//============================================================================ | |
// Color Matching functions | |
//============================================================================ | |
IMAQ_FUNC ColorInformation* IMAQ_STDCALL imaqLearnColor(const Image* image, const ROI* roi, ColorSensitivity sensitivity, int saturation); | |
IMAQ_FUNC int* IMAQ_STDCALL imaqMatchColor(const Image* image, const ColorInformation* info, const ROI* roi, int* numScores); | |
//============================================================================ | |
// Frequency Domain Analysis functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqAttenuate(Image* dest, const Image* source, AttenuateMode highlow); | |
IMAQ_FUNC int IMAQ_STDCALL imaqConjugate(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFFT(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFlipFrequencies(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqInverseFFT(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqTruncate(Image* dest, const Image* source, TruncateMode highlow, float ratioToKeep); | |
//============================================================================ | |
// Barcode I/O functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqGradeDataMatrixBarcodeAIM(const Image* image, AIMGradeReport* report); | |
IMAQ_FUNC BarcodeInfo* IMAQ_STDCALL imaqReadBarcode(const Image* image, BarcodeType type, const ROI* roi, int validate); | |
IMAQ_FUNC DataMatrixReport* IMAQ_STDCALL imaqReadDataMatrixBarcode2(Image* image, const ROI* roi, DataMatrixGradingMode prepareForGrading, const DataMatrixDescriptionOptions* descriptionOptions, const DataMatrixSizeOptions* sizeOptions, const DataMatrixSearchOptions* searchOptions); | |
IMAQ_FUNC Barcode2DInfo* IMAQ_STDCALL imaqReadPDF417Barcode(const Image* image, const ROI* roi, Barcode2DSearchMode searchMode, unsigned int* numBarcodes); | |
IMAQ_FUNC QRCodeReport* IMAQ_STDCALL imaqReadQRCode(Image* image, const ROI* roi, QRGradingMode reserved, const QRCodeDescriptionOptions* descriptionOptions, const QRCodeSizeOptions* sizeOptions, const QRCodeSearchOptions* searchOptions); | |
//============================================================================ | |
// LCD functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqFindLCDSegments(ROI* roi, const Image* image, const LCDOptions* options); | |
IMAQ_FUNC LCDReport* IMAQ_STDCALL imaqReadLCD(const Image* image, const ROI* roi, const LCDOptions* options); | |
//============================================================================ | |
// Shape Matching functions | |
//============================================================================ | |
IMAQ_FUNC ShapeReport* IMAQ_STDCALL imaqMatchShape(Image* dest, Image* source, const Image* templateImage, int scaleInvariant, int connectivity8, double tolerance, int* numMatches); | |
//============================================================================ | |
// Contours functions | |
//============================================================================ | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddAnnulusContour(ROI* roi, Annulus annulus); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddClosedContour(ROI* roi, const Point* points, int numPoints); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddLineContour(ROI* roi, Point start, Point end); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddOpenContour(ROI* roi, const Point* points, int numPoints); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddOvalContour(ROI* roi, Rect boundingBox); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddPointContour(ROI* roi, Point point); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddRectContour(ROI* roi, Rect rect); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddRotatedRectContour2(ROI* roi, RotatedRect rect); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqCopyContour(ROI* destRoi, const ROI* sourceRoi, ContourID id); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqGetContour(const ROI* roi, unsigned int index); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetContourColor(const ROI* roi, ContourID id, RGBValue* contourColor); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetContourCount(const ROI* roi); | |
IMAQ_FUNC ContourInfo2* IMAQ_STDCALL imaqGetContourInfo2(const ROI* roi, ContourID id); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMoveContour(ROI* roi, ContourID id, int deltaX, int deltaY); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRemoveContour(ROI* roi, ContourID id); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetContourColor(ROI* roi, ContourID id, const RGBValue* color); | |
//============================================================================ | |
// Regions of Interest functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqConstructROI2(const Image* image, ROI* roi, Tool initialTool, const ToolWindowOptions* tools, const ConstructROIOptions2* options, int* okay); | |
IMAQ_FUNC ROI* IMAQ_STDCALL imaqCreateROI(void); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetROIBoundingBox(const ROI* roi, Rect* boundingBox); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetROIColor(const ROI* roi, RGBValue* roiColor); | |
IMAQ_FUNC ROI* IMAQ_STDCALL imaqGetWindowROI(int windowNumber); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetROIColor(ROI* roi, const RGBValue* color); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowROI(int windowNumber, const ROI* roi); | |
//============================================================================ | |
// Image Analysis functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCentroid(const Image* image, PointFloat* centroid, const Image* mask); | |
IMAQ_FUNC Curve* IMAQ_STDCALL imaqExtractCurves(const Image* image, const ROI* roi, const CurveOptions* curveOptions, unsigned int* numCurves); | |
IMAQ_FUNC HistogramReport* IMAQ_STDCALL imaqHistogram(const Image* image, int numClasses, float min, float max, const Image* mask); | |
IMAQ_FUNC LinearAverages* IMAQ_STDCALL imaqLinearAverages2(Image* image, LinearAveragesMode mode, Rect rect); | |
IMAQ_FUNC LineProfile* IMAQ_STDCALL imaqLineProfile(const Image* image, Point start, Point end); | |
IMAQ_FUNC QuantifyReport* IMAQ_STDCALL imaqQuantify(const Image* image, const Image* mask); | |
//============================================================================ | |
// Error Management functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqClearError(void); | |
IMAQ_FUNC char* IMAQ_STDCALL imaqGetErrorText(int errorCode); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetLastError(void); | |
IMAQ_FUNC const char* IMAQ_STDCALL imaqGetLastErrorFunc(void); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetError(int errorCode, const char* function); | |
//============================================================================ | |
// Threshold functions | |
//============================================================================ | |
IMAQ_FUNC ThresholdData* IMAQ_STDCALL imaqAutoThreshold2(Image* dest, const Image* source, int numClasses, ThresholdMethod method, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLocalThreshold(Image* dest, const Image* source, unsigned int windowWidth, unsigned int windowHeight, LocalThresholdMethod method, double deviationWeight, ObjectType type, float replaceValue); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMagicWand(Image* dest, const Image* source, Point coord, float tolerance, int connectivity8, float replaceValue); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMultithreshold(Image* dest, const Image* source, const ThresholdData* ranges, int numRanges); | |
IMAQ_FUNC int IMAQ_STDCALL imaqThreshold(Image* dest, const Image* source, float rangeMin, float rangeMax, int useNewValue, float newValue); | |
//============================================================================ | |
// Memory Management functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqDispose(void* object); | |
//============================================================================ | |
// Pattern Matching functions | |
//============================================================================ | |
IMAQ_FUNC CircleMatch* IMAQ_STDCALL imaqDetectCircles(const Image* image, const CircleDescriptor* circleDescriptor, const CurveOptions* curveOptions, const ShapeDetectionOptions* shapeDetectionOptions, const ROI* roi, int* numMatchesReturned); | |
IMAQ_FUNC EllipseMatch* IMAQ_STDCALL imaqDetectEllipses(const Image* image, const EllipseDescriptor* ellipseDescriptor, const CurveOptions* curveOptions, const ShapeDetectionOptions* shapeDetectionOptions, const ROI* roi, int* numMatchesReturned); | |
IMAQ_FUNC LineMatch* IMAQ_STDCALL imaqDetectLines(const Image* image, const LineDescriptor* lineDescriptor, const CurveOptions* curveOptions, const ShapeDetectionOptions* shapeDetectionOptions, const ROI* roi, int* numMatchesReturned); | |
IMAQ_FUNC RectangleMatch* IMAQ_STDCALL imaqDetectRectangles(const Image* image, const RectangleDescriptor* rectangleDescriptor, const CurveOptions* curveOptions, const ShapeDetectionOptions* shapeDetectionOptions, const ROI* roi, int* numMatchesReturned); | |
IMAQ_FUNC FeatureData* IMAQ_STDCALL imaqGetGeometricFeaturesFromCurves(const Curve* curves, unsigned int numCurves, const FeatureType* featureTypes, unsigned int numFeatureTypes, unsigned int* numFeatures); | |
IMAQ_FUNC FeatureData* IMAQ_STDCALL imaqGetGeometricTemplateFeatureInfo(const Image* pattern, unsigned int* numFeatures); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnColorPattern(Image* image, const LearnColorPatternOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnGeometricPattern(Image* image, PointFloat originOffset, const CurveOptions* curveOptions, const LearnGeometricPatternAdvancedOptions* advancedLearnOptions, const Image* mask); | |
IMAQ_FUNC MultipleGeometricPattern* IMAQ_STDCALL imaqLearnMultipleGeometricPatterns(const Image** patterns, unsigned int numberOfPatterns, const String255* labels); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnPattern3(Image* image, LearningMode learningMode, LearnPatternAdvancedOptions* advancedOptions, const Image* mask); | |
IMAQ_FUNC PatternMatch* IMAQ_STDCALL imaqMatchColorPattern(const Image* image, Image* pattern, const MatchColorPatternOptions* options, Rect searchRect, int* numMatches); | |
IMAQ_FUNC GeometricPatternMatch2* IMAQ_STDCALL imaqMatchGeometricPattern2(const Image* image, const Image* pattern, const CurveOptions* curveOptions, const MatchGeometricPatternOptions* matchOptions, const MatchGeometricPatternAdvancedOptions2* advancedMatchOptions, const ROI* roi, int* numMatches); | |
IMAQ_FUNC GeometricPatternMatch2* IMAQ_STDCALL imaqMatchMultipleGeometricPatterns(const Image* image, const MultipleGeometricPattern* multiplePattern, const ROI* roi, int* numMatches); | |
IMAQ_FUNC MultipleGeometricPattern* IMAQ_STDCALL imaqReadMultipleGeometricPatternFile(const char* fileName, String255 description); | |
IMAQ_FUNC PatternMatch* IMAQ_STDCALL imaqRefineMatches(const Image* image, const Image* pattern, const PatternMatch* candidatesIn, int numCandidatesIn, MatchPatternOptions* options, MatchPatternAdvancedOptions* advancedOptions, int* numCandidatesOut); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetMultipleGeometricPatternsOptions(MultipleGeometricPattern* multiplePattern, const char* label, const CurveOptions* curveOptions, const MatchGeometricPatternOptions* matchOptions, const MatchGeometricPatternAdvancedOptions2* advancedMatchOptions); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteMultipleGeometricPatternFile(const MultipleGeometricPattern* multiplePattern, const char* fileName, const char* description); | |
IMAQ_FUNC GeometricPatternMatch3* IMAQ_STDCALL imaqMatchGeometricPattern3(const Image* image, const Image* pattern, const CurveOptions* curveOptions, const MatchGeometricPatternOptions* matchOptions, const MatchGeometricPatternAdvancedOptions3* advancedMatchOptions, const ROI* roi, size_t* numMatches); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnGeometricPattern2(Image* image, PointFloat originOffset, double angleOffset, const CurveOptions* curveOptions, const LearnGeometricPatternAdvancedOptions2* advancedLearnOptions, const Image* mask); | |
IMAQ_FUNC PatternMatch* IMAQ_STDCALL imaqMatchPattern3(const Image* image, const Image* pattern, const MatchPatternOptions* options, const MatchPatternAdvancedOptions* advancedOptions, const ROI* roi, int* numMatches); | |
//============================================================================ | |
// Overlay functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqClearOverlay(Image* image, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCopyOverlay(Image* dest, const Image* source, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetOverlayProperties(const Image* image, const char* group, TransformBehaviors* transformBehaviors); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMergeOverlay(Image* dest, const Image* source, const RGBValue* palette, unsigned int numColors, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayArc(Image* image, const ArcInfo* arc, const RGBValue* color, DrawMode drawMode, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayBitmap(Image* image, Point destLoc, const RGBValue* bitmap, unsigned int numCols, unsigned int numRows, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayClosedContour(Image* image, const Point* points, int numPoints, const RGBValue* color, DrawMode drawMode, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayLine(Image* image, Point start, Point end, const RGBValue* color, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayMetafile(Image* image, const void* metafile, Rect rect, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayOpenContour(Image* image, const Point* points, int numPoints, const RGBValue* color, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayOval(Image* image, Rect boundingBox, const RGBValue* color, DrawMode drawMode, char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayPoints(Image* image, const Point* points, int numPoints, const RGBValue* colors, int numColors, PointSymbol symbol, const UserPointSymbol* userSymbol, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayRect(Image* image, Rect rect, const RGBValue* color, DrawMode drawMode, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayROI(Image* image, const ROI* roi, PointSymbol symbol, const UserPointSymbol* userSymbol, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqOverlayText(Image* image, Point origin, const char* text, const RGBValue* color, const OverlayTextOptions* options, const char* group); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetOverlayProperties(Image* image, const char* group, TransformBehaviors* transformBehaviors); | |
//============================================================================ | |
// OCR functions | |
//============================================================================ | |
IMAQ_FUNC CharSet* IMAQ_STDCALL imaqCreateCharSet(void); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDeleteChar(CharSet* set, int index); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetCharCount(const CharSet* set); | |
IMAQ_FUNC CharInfo2* IMAQ_STDCALL imaqGetCharInfo2(const CharSet* set, int index); | |
IMAQ_FUNC int IMAQ_STDCALL imaqReadOCRFile(const char* fileName, CharSet* set, String255 setDescription, ReadTextOptions* readOptions, OCRProcessingOptions* processingOptions, OCRSpacingOptions* spacingOptions); | |
IMAQ_FUNC ReadTextReport3* IMAQ_STDCALL imaqReadText3(const Image* image, const CharSet* set, const ROI* roi, const ReadTextOptions* readOptions, const OCRProcessingOptions* processingOptions, const OCRSpacingOptions* spacingOptions); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRenameChar(CharSet* set, int index, const char* newCharValue); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetReferenceChar(const CharSet* set, int index, int isReferenceChar); | |
IMAQ_FUNC int IMAQ_STDCALL imaqTrainChars(const Image* image, CharSet* set, int index, const char* charValue, const ROI* roi, const OCRProcessingOptions* processingOptions, const OCRSpacingOptions* spacingOptions); | |
IMAQ_FUNC int* IMAQ_STDCALL imaqVerifyPatterns(const Image* image, const CharSet* set, const String255* expectedPatterns, int patternCount, const ROI* roi, int* numScores); | |
IMAQ_FUNC int* IMAQ_STDCALL imaqVerifyText(const Image* image, const CharSet* set, const char* expectedString, const ROI* roi, int* numScores); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteOCRFile(const char* fileName, const CharSet* set, const char* setDescription, const ReadTextOptions* readOptions, const OCRProcessingOptions* processingOptions, const OCRSpacingOptions* spacingOptions); | |
//============================================================================ | |
// Geometric Matching functions | |
//============================================================================ | |
IMAQ_FUNC ExtractContourReport* IMAQ_STDCALL imaqExtractContour(Image* image, const ROI* roi, ExtractContourDirection direction, CurveParameters* curveParams, const ConnectionConstraint* connectionConstraintParams, unsigned int numOfConstraints, ExtractContourSelection selection, Image* contourImage); | |
IMAQ_FUNC int IMAQ_STDCALL imaqContourOverlay(Image* image, const Image* contourImage, const ContourOverlaySettings* pointsSettings, const ContourOverlaySettings* eqnSettings, const char* groupName); | |
IMAQ_FUNC ContourComputeCurvatureReport* IMAQ_STDCALL imaqContourComputeCurvature(const Image* contourImage, unsigned int kernel); | |
IMAQ_FUNC CurvatureAnalysisReport* IMAQ_STDCALL imaqContourClassifyCurvature(const Image* contourImage, unsigned int kernel, RangeLabel* curvatureClasses, unsigned int numCurvatureClasses); | |
IMAQ_FUNC ComputeDistancesReport* IMAQ_STDCALL imaqContourComputeDistances(const Image* targetImage, const Image* templateImage, const SetupMatchPatternData* matchSetupData, unsigned int smoothingKernel); | |
IMAQ_FUNC ClassifyDistancesReport* IMAQ_STDCALL imaqContourClassifyDistances(const Image* targetImage, const Image* templateImage, const SetupMatchPatternData* matchSetupData, unsigned int smoothingKernel, const RangeLabel* distanceRanges, unsigned int numDistanceRanges); | |
IMAQ_FUNC ContourInfoReport* IMAQ_STDCALL imaqContourInfo(const Image* contourImage); | |
IMAQ_FUNC SetupMatchPatternData* IMAQ_STDCALL imaqContourSetupMatchPattern(MatchMode* matchMode, unsigned int enableSubPixelAccuracy, CurveParameters* curveParams, unsigned int useLearnCurveParameters, const RangeSettingDouble* rangeSettings, unsigned int numRangeSettings); | |
IMAQ_FUNC int IMAQ_STDCALL imaqContourAdvancedSetupMatchPattern(SetupMatchPatternData* matchSetupData, GeometricAdvancedSetupDataOption* geometricOptions, unsigned int numGeometricOptions); | |
IMAQ_FUNC ContourFitLineReport* IMAQ_STDCALL imaqContourFitLine(Image* image, double pixelRadius); | |
IMAQ_FUNC PartialCircle* IMAQ_STDCALL imaqContourFitCircle(Image* image, double pixelRadius, int rejectOutliers); | |
IMAQ_FUNC PartialEllipse* IMAQ_STDCALL imaqContourFitEllipse(Image* image, double pixelRadius, int rejectOutliers); | |
IMAQ_FUNC ContourFitSplineReport* IMAQ_STDCALL imaqContourFitSpline(Image* image, int degree, int numberOfControlPoints); | |
IMAQ_FUNC ContourFitPolynomialReport* IMAQ_STDCALL imaqContourFitPolynomial(Image* image, int order); | |
//============================================================================ | |
// Edge Detection functions | |
//============================================================================ | |
IMAQ_FUNC FindCircularEdgeReport* IMAQ_STDCALL imaqFindCircularEdge2(Image* image, const ROI* roi, const CoordinateSystem* baseSystem, const CoordinateSystem* newSystem, const FindCircularEdgeOptions* edgeOptions, const CircleFitOptions* circleFitOptions); | |
IMAQ_FUNC FindConcentricEdgeReport* IMAQ_STDCALL imaqFindConcentricEdge2(Image* image, const ROI* roi, const CoordinateSystem* baseSystem, const CoordinateSystem* newSystem, const FindConcentricEdgeOptions* edgeOptions, const ConcentricEdgeFitOptions* concentricEdgeFitOptions); | |
//============================================================================ | |
// Morphology Reconstruction functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqGrayMorphologyReconstruct(Image* dstImage, Image* srcImage, const Image* markerImage, PointFloat* points, int numOfPoints, MorphologyReconstructOperation operation, const StructuringElement* structuringElement, const ROI* roi); | |
IMAQ_FUNC int IMAQ_STDCALL imaqMorphologyReconstruct(Image* dstImage, Image* srcImage, const Image* markerImage, PointFloat* points, int numOfPoints, MorphologyReconstructOperation operation, Connectivity connectivity, const ROI* roi); | |
//============================================================================ | |
// Texture functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqDetectTextureDefect(ClassifierSession* session, Image* destImage, const Image* srcImage, const ROI* roi, int initialStepSize, int finalStepSize, unsigned char defectPixelValue, double minClassificationScore); | |
IMAQ_FUNC int IMAQ_STDCALL imaqClassificationTextureDefectOptions(ClassifierSession* session, WindowSize* windowOptions, WaveletOptions* waveletOptions, void** bandsUsed, int* numBandsUsed, CooccurrenceOptions* cooccurrenceOptions, unsigned char setOperation); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCooccurrenceMatrix(const Image* srcImage, const ROI* roi, int levelPixel, const DisplacementVector* displacementVec, void* featureOptionArray, unsigned int featureOptionArraySize, void** cooccurrenceMatrixArray, int* coocurrenceMatrixRows, int* coocurrenceMatrixCols, void** featureVectorArray, int* featureVectorArraySize); | |
IMAQ_FUNC ExtractTextureFeaturesReport* IMAQ_STDCALL imaqExtractTextureFeatures(const Image* srcImage, const ROI* roi, const WindowSize* windowOptions, const WaveletOptions* waveletOptions, void* waveletBands, unsigned int numWaveletBands, const CooccurrenceOptions* cooccurrenceOptions, unsigned char useWindow); | |
IMAQ_FUNC WaveletBandsReport* IMAQ_STDCALL imaqExtractWaveletBands(const Image* srcImage, const WaveletOptions* waveletOptions, void* waveletBands, unsigned int numWaveletBands); | |
//============================================================================ | |
// Regions of Interest Manipulation functions | |
//============================================================================ | |
IMAQ_FUNC ROI* IMAQ_STDCALL imaqMaskToROI(const Image* mask, int* withinLimit); | |
IMAQ_FUNC ROIProfile* IMAQ_STDCALL imaqROIProfile(const Image* image, const ROI* roi); | |
IMAQ_FUNC int IMAQ_STDCALL imaqROIToMask(Image* mask, const ROI* roi, int fillValue, const Image* imageModel, int* inSpace); | |
IMAQ_FUNC int IMAQ_STDCALL imaqTransformROI2(ROI* roi, const CoordinateSystem* baseSystem, const CoordinateSystem* newSystem); | |
IMAQ_FUNC LabelToROIReport* IMAQ_STDCALL imaqLabelToROI(const Image* image, const unsigned int* labelsIn, unsigned int numLabelsIn, int maxNumVectors, int isExternelEdges); | |
//============================================================================ | |
// Morphology functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqGrayMorphology(Image* dest, Image* source, MorphologyMethod method, const StructuringElement* structuringElement); | |
//============================================================================ | |
// Classification functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqAddClassifierSample(Image* image, ClassifierSession* session, const ROI* roi, const char* sampleClass, double* featureVector, unsigned int vectorSize); | |
IMAQ_FUNC ClassifierReportAdvanced* IMAQ_STDCALL imaqAdvanceClassify(Image* image, const ClassifierSession* session, const ROI* roi, double* featureVector, unsigned int vectorSize); | |
IMAQ_FUNC ClassifierReport* IMAQ_STDCALL imaqClassify(Image* image, const ClassifierSession* session, const ROI* roi, double* featureVector, unsigned int vectorSize); | |
IMAQ_FUNC ClassifierSession* IMAQ_STDCALL imaqCreateClassifier(ClassifierType type); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDeleteClassifierSample(ClassifierSession* session, int index); | |
IMAQ_FUNC ClassifierAccuracyReport* IMAQ_STDCALL imaqGetClassifierAccuracy(const ClassifierSession* session); | |
IMAQ_FUNC ClassifierSampleInfo* IMAQ_STDCALL imaqGetClassifierSampleInfo(const ClassifierSession* session, int index, int* numSamples); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetColorClassifierOptions(const ClassifierSession* session, ColorOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetNearestNeighborOptions(const ClassifierSession* session, NearestNeighborOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetParticleClassifierOptions2(const ClassifierSession* session, ParticleClassifierPreprocessingOptions2* preprocessingOptions, ParticleClassifierOptions* options); | |
IMAQ_FUNC ClassifierSession* IMAQ_STDCALL imaqReadClassifierFile(ClassifierSession* session, const char* fileName, ReadClassifierFileMode mode, ClassifierType* type, ClassifierEngineType* engine, String255 description); | |
IMAQ_FUNC int IMAQ_STDCALL imaqRelabelClassifierSample(ClassifierSession* session, int index, const char* newClass); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetParticleClassifierOptions2(ClassifierSession* session, const ParticleClassifierPreprocessingOptions2* preprocessingOptions, const ParticleClassifierOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetColorClassifierOptions(ClassifierSession* session, const ColorOptions* options); | |
IMAQ_FUNC NearestNeighborTrainingReport* IMAQ_STDCALL imaqTrainNearestNeighborClassifier(ClassifierSession* session, const NearestNeighborOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWriteClassifierFile(const ClassifierSession* session, const char* fileName, WriteClassifierFileMode mode, const String255 description); | |
//============================================================================ | |
// Measure Distances functions | |
//============================================================================ | |
IMAQ_FUNC ClampMax2Report* IMAQ_STDCALL imaqClampMax2(Image* image, const ROI* roi, const CoordinateSystem* baseSystem, const CoordinateSystem* newSystem, const CurveOptions* curveSettings, const ClampSettings* clampSettings, const ClampOverlaySettings* clampOverlaySettings); | |
//============================================================================ | |
// Inspection functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqCompareGoldenTemplate(const Image* image, const Image* goldenTemplate, Image* brightDefects, Image* darkDefects, const InspectionAlignment* alignment, const InspectionOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnGoldenTemplate(Image* goldenTemplate, PointFloat originOffset, const Image* mask); | |
//============================================================================ | |
// Obsolete functions | |
//============================================================================ | |
IMAQ_FUNC int IMAQ_STDCALL imaqRotate(Image* dest, const Image* source, float angle, PixelValue fill, InterpolationMethod method); | |
IMAQ_FUNC int IMAQ_STDCALL imaqWritePNGFile(const Image* image, const char* fileName, unsigned int compressionSpeed, const RGBValue* colorTable); | |
IMAQ_FUNC ParticleReport* IMAQ_STDCALL imaqSelectParticles(const Image* image, const ParticleReport* reports, int reportCount, int rejectBorder, const SelectParticleCriteria* criteria, int criteriaCount, int* selectedCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqParticleFilter(Image* dest, Image* source, const ParticleFilterCriteria* criteria, int criteriaCount, int rejectMatches, int connectivity8); | |
IMAQ_FUNC ParticleReport* IMAQ_STDCALL imaqGetParticleInfo(Image* image, int connectivity8, ParticleInfoMode mode, int* reportCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCalcCoeff(const Image* image, const ParticleReport* report, MeasurementValue parameter, float* coefficient); | |
IMAQ_FUNC EdgeReport* IMAQ_STDCALL imaqEdgeTool(const Image* image, const Point* points, int numPoints, const EdgeOptions* options, int* numEdges); | |
IMAQ_FUNC CircleReport* IMAQ_STDCALL imaqCircles(Image* dest, const Image* source, float minRadius, float maxRadius, int* numCircles); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLabel(Image* dest, Image* source, int connectivity8, int* particleCount); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFitEllipse(const PointFloat* points, int numPoints, BestEllipse* ellipse); | |
IMAQ_FUNC int IMAQ_STDCALL imaqFitCircle(const PointFloat* points, int numPoints, BestCircle* circle); | |
IMAQ_FUNC Color IMAQ_STDCALL imaqChangeColorSpace(const Color* sourceColor, ColorMode sourceSpace, ColorMode destSpace); | |
IMAQ_FUNC PatternMatch* IMAQ_STDCALL imaqMatchPattern(const Image* image, Image* pattern, const MatchPatternOptions* options, Rect searchRect, int* numMatches); | |
IMAQ_FUNC int IMAQ_STDCALL imaqConvex(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqIsVisionInfoPresent(const Image* image, VisionInfoType type, int* present); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLineGaugeTool(const Image* image, Point start, Point end, LineGaugeMethod method, const EdgeOptions* edgeOptions, const CoordinateTransform* reference, float* distance); | |
IMAQ_FUNC int IMAQ_STDCALL imaqBestCircle(const PointFloat* points, int numPoints, PointFloat* center, double* radius); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSavePattern(const Image* pattern, const char* fileName); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLoadPattern(Image* pattern, const char* fileName); | |
IMAQ_FUNC int IMAQ_STDCALL imaqTransformROI(ROI* roi, Point originStart, float angleStart, Point originFinal, float angleFinal); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCoordinateReference(const Point* points, ReferenceMode mode, Point* origin, float* angle); | |
IMAQ_FUNC ContourInfo* IMAQ_STDCALL imaqGetContourInfo(const ROI* roi, ContourID id); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetWindowOverlay(int windowNumber, const Overlay* overlay); | |
IMAQ_FUNC Overlay* IMAQ_STDCALL imaqCreateOverlayFromROI(const ROI* roi); | |
IMAQ_FUNC Overlay* IMAQ_STDCALL imaqCreateOverlayFromMetafile(const void* metafile); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetCalibrationInfo(Image* image, CalibrationUnit unit, float xDistance, float yDistance); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetCalibrationInfo(const Image* image, CalibrationUnit* unit, float* xDistance, float* yDistance); | |
IMAQ_FUNC int IMAQ_STDCALL imaqConstructROI(const Image* image, ROI* roi, Tool initialTool, const ToolWindowOptions* tools, const ConstructROIOptions* options, int* okay); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetParticleClassifierOptions(const ClassifierSession* session, ParticleClassifierPreprocessingOptions* preprocessingOptions, ParticleClassifierOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqZoomWindow(int windowNumber, int xZoom, int yZoom, Point center); | |
IMAQ_FUNC int IMAQ_STDCALL imaqGetWindowZoom(int windowNumber, int* xZoom, int* yZoom); | |
IMAQ_FUNC int IMAQ_STDCALL imaqParticleFilter3(Image* dest, Image* source, const ParticleFilterCriteria2* criteria, int criteriaCount, const ParticleFilterOptions* options, const ROI* roi, int* numParticles); | |
IMAQ_FUNC ReadTextReport2* IMAQ_STDCALL imaqReadText2(const Image* image, const CharSet* set, const ROI* roi, const ReadTextOptions* readOptions, const OCRProcessingOptions* processingOptions, const OCRSpacingOptions* spacingOptions); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnPattern2(Image* image, LearningMode learningMode, LearnPatternAdvancedOptions* advancedOptions); | |
IMAQ_FUNC int IMAQ_STDCALL imaqConvolve(Image* dest, Image* source, const float* kernel, int matrixRows, int matrixCols, float normalize, const Image* mask); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDivideConstant(Image* dest, const Image* source, PixelValue value); | |
IMAQ_FUNC int IMAQ_STDCALL imaqDivide(Image* dest, const Image* sourceA, const Image* sourceB); | |
IMAQ_FUNC EdgeReport2* IMAQ_STDCALL imaqEdgeTool3(const Image* image, const ROI* roi, EdgeProcess processType, const EdgeOptions2* edgeOptions); | |
IMAQ_FUNC ConcentricRakeReport* IMAQ_STDCALL imaqConcentricRake(const Image* image, const ROI* roi, ConcentricRakeDirection direction, EdgeProcess process, const RakeOptions* options); | |
IMAQ_FUNC SpokeReport* IMAQ_STDCALL imaqSpoke(const Image* image, const ROI* roi, SpokeDirection direction, EdgeProcess process, const SpokeOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLearnPattern(Image* image, LearningMode learningMode); | |
IMAQ_FUNC int IMAQ_STDCALL imaqLookup(Image* dest, const Image* source, const short* table, const Image* mask); | |
IMAQ_FUNC PatternMatch* IMAQ_STDCALL imaqMatchPattern2(const Image* image, const Image* pattern, const MatchPatternOptions* options, const MatchPatternAdvancedOptions* advancedOptions, Rect searchRect, int* numMatches); | |
IMAQ_FUNC int IMAQ_STDCALL imaqSetParticleClassifierOptions(ClassifierSession* session, const ParticleClassifierPreprocessingOptions* preprocessingOptions, const ParticleClassifierOptions* options); | |
IMAQ_FUNC int IMAQ_STDCALL imaqCopyCalibrationInfo(Image* dest, const Image* source); | |
IMAQ_FUNC int IMAQ_STDCALL imaqParticleFilter2(Image* dest, Image* source, const ParticleFilterCriteria2* criteria, int criteriaCount, int rejectMatches, int connectivity8, int* numParticles); | |
IMAQ_FUNC EdgeReport* IMAQ_STDCALL imaqEdgeTool2(const Image* image, const Point* points, int numPoints, EdgeProcess process, const EdgeOptions* options, int* numEdges); | |
IMAQ_FUNC ContourID IMAQ_STDCALL imaqAddRotatedRectContour(ROI* roi, RotatedRect rect); | |
IMAQ_FUNC Barcode2DInfo* IMAQ_STDCALL imaqReadDataMatrixBarcode(const Image* image, const ROI* roi, const DataMatrixOptions* options, unsigned int* numBarcodes); | |
IMAQ_FUNC LinearAverages* IMAQ_STDCALL imaqLinearAverages(const Image* image, Rect rect); | |
IMAQ_FUNC GeometricPatternMatch* IMAQ_STDCALL imaqMatchGeometricPattern(const Image* image, const Image* pattern, const CurveOptions* curveOptions, const MatchGeometricPatternOptions* matchOptions, const MatchGeometricPatternAdvancedOptions* advancedMatchOptions, const ROI* roi, int* numMatches); | |
IMAQ_FUNC CharInfo* IMAQ_STDCALL imaqGetCharInfo(const CharSet* set, int index); | |
IMAQ_FUNC ReadTextReport* IMAQ_STDCALL imaqReadText(const Image* image, const CharSet* set, const ROI* roi, const ReadTextOptions* readOptions, const OCRProcessingOptions* processingOptions, const OCRSpacingOptions* spacingOptions); | |
IMAQ_FUNC ThresholdData* IMAQ_STDCALL imaqAutoThreshold(Image* dest, Image* source, int numClasses, ThresholdMethod method); | |
IMAQ_FUNC ColorHistogramReport* IMAQ_STDCALL imaqColorHistogram(Image* image, int numClasses, ColorMode mode, const Image* mask); | |
IMAQ_FUNC RakeReport* IMAQ_STDCALL imaqRake(const Image* image, const ROI* roi, RakeDirection direction, EdgeProcess process, const RakeOptions* options); | |
#endif | |