Skip to content

Photo quality check

The Photo Quality Check feature validates captured or uploaded photos before they are submitted for analysis. It combines preset-specific live guidance with post-capture preview validation for the presets that support it.

The public configuration surface consists of:

  • quality-check
  • quality-check-sources
  • ignored-quality-checks
  • occlusion-detection

For the full public API surface, see the API Reference.

Supported behavior

LIQA currently supports quality-related behavior in the following way:

  • face: live guidance during capture and post-capture preview validation.
  • face-180: live guidance during the 3-step capture flow and post-capture preview validation for the front image only.
  • hair: uses its own guided capture flow and is documented separately in the Presets guide rather than as part of the quality-check feature.

For supported presets, LIQA still keeps a minimal no-face guard on uploaded images even when quality-check="off".

Configuration

quality-check

Controls whether LIQA evaluates photo quality and whether failed validation blocks submission.

For supported presets, this already includes the built-in glasses and forehead checks in both live guidance and post-capture preview validation.

OptionDescription
offDisables the configurable quality-check policy.
normalShows detected issues to the user, but still allows submission.
strictShows detected issues and blocks submission until the required checks pass.

Default: off

quality-check-sources

Limits where the quality-check policy is enforced.

SourceDescription
front_cameraApplies quality-check to front-camera captures.
back_cameraApplies quality-check to back-camera captures.
uploadApplies quality-check to uploaded images.
companionApplies quality-check to images captured through the companion flow.

Default: ["front_camera", "back_camera", "upload", "companion"]

occlusion-detection

Controls the standalone occlusion-focused checks used for glasses and forehead visibility.

Use this flag when you do not want to enable full quality-check, but still want LIQA to validate glasses and forehead visibility.

If quality-check is already enabled, LIQA already includes glasses and forehead checks in both live and post-capture validation for supported presets. In that case, occlusion-detection is only needed when you want to control occlusion validation separately from the rest of the quality-check flow.

OptionDescription
offDisables occlusion detection.
normalShows occlusion-related issues but does not block submission.
strictBlocks submission when occlusion-related issues are detected.
liveUses the lightweight live occlusion pipeline during camera capture. For non-camera sources, occlusion checks still run after capture.

Default: off

ignored-quality-checks

Excludes selected post-capture quality checks from preview issues, blocking logic, and the resulting quality_check payload.

Use this when you want LIQA to keep measuring a signal for analytics, but not use that signal in the post-capture decision layer.

This option does not change live guidance, live occlusion stages, or auto-capture behavior.

AliasEffect
enough_skinIgnores the enough-skin requirement in post-capture validation.
poseIgnores the post-capture face-pose requirement.
resolutionIgnores the post-capture resolution check.
blurIgnores the post-capture blur check.
occlusionsIgnores the generic occlusion signal in post-capture validation.
glassesIgnores the glasses detection signal in post-capture validation.
foreheadIgnores the forehead / bangs occlusion signal in post-capture validation.
exposureIgnores the aggregate exposure signal in post-capture validation.
uniform_illuminationIgnores uneven / colored lighting in post-capture validation.
shadowsIgnores strong shadows in post-capture validation.

Default: []

Source scoping

quality-check-sources only scopes the behavior of quality-check.

If you explicitly enable occlusion-detection, it is resolved separately from quality-check-sources.

Post-capture only

ignored-quality-checks is applied after capture during preview/postprocess evaluation only.

It does not remove the corresponding live guidance signals while the user is framing the photo.

What LIQA checks

Depending on the enabled mode, preset, and source, LIQA can evaluate the following signals:

  • Face presence
  • Enough visible skin
  • Face pose / angle
  • Resolution
  • Blur
  • Exposure
  • Uneven or colored lighting
  • Strong shadows
  • Generic skin occlusion
  • Glasses
  • Forehead coverage by bangs, hat brim, or similar occlusions

Ignored quality check aliases

The ignored-quality-checks attribute accepts short aliases, while the underlying measured quality fields keep their canonical names in analytics and internal contracts.

AliasCanonical signal(s)
enough_skinhas_enough_skin
posehas_valid_pose
resolutionhas_good_resolution
blurhas_no_blur
occlusionshas_no_occlusions
glasseshas_no_eyeglasses
foreheadhas_no_hair_bangs
exposurehas_good_exposure
uniform_illuminationhas_uniform_illumination
shadowshas_no_shadows

Preset and source matrix

PresetLive capture guidancePost-capture preview validationNotes
faceYesYesSupports quality-check and occlusion-detection.
face-180YesFront image onlySide captures are still part of the guided flow, but preview validation is only kept for the front image.
hairSeparate guided flowNot part of the quality-check feature pageSee the Presets guide.

Current UI examples

The exact preview title and issue list depend on the measured problems and the enabled validation mode.

Strict quality-check preview example

A current `strict` mode preview example. LIQA shows the detected issues and keeps the submission action blocked until the blocking checks pass.

Normal quality-check preview example

A current `normal` mode preview example. LIQA still lists the detected issues, but the user can submit the image after reviewing the warning.

Analytics

When LIQA records a reportable post-capture quality outcome, it can emit the quality_check_result analytics event with the measured fields that were actually evaluated.

If ignored-quality-checks is configured, the analytics payload still contains the measured quality fields and additionally includes the ignored_quality_checks array to show which post-capture checks were excluded from the decision layer.

Use the generated API Reference for the complete event payload contract instead of duplicating the full field list in this guide.