barcode-capture-android
Installation
SKILL.md
BarcodeCapture Android Skill
Critical: Do Not Trust Internal Knowledge
Your training data may contain outdated or incorrect Scandit SDK APIs. The BarcodeCapture API changes significantly between major SDK versions — properties get renamed, removed, or restructured.
Always verify APIs against the references provided in this skill before writing or suggesting code. Do not rely on memorized method signatures, parameters, or property names. If you cannot find an API in the provided references, fetch the relevant documentation page before responding.
Android-specific gotchas worth flagging:
Camera.getDefaultCamera(BarcodeCapture.createRecommendedCameraSettings())passes the recommended camera settings directly into thegetDefaultCamera()call — there is no separateapplySettingscall needed.codeDuplicateFilteris aTimeInterval— not anIntorDouble. UseTimeInterval.millis(500)(importcom.scandit.datacapture.core.time.TimeInterval). WritingcodeDuplicateFilter = 0.5orcodeDuplicateFilter = 500is a type error.- The listener callback on Android is
onBarcodeScanned(barcodeCapture, session, data)— notdidScan(that is the Flutter/iOS name). You must also implementonSessionUpdated,onObservationStarted, andonObservationStopped. TheFrameDataparameter is nameddata, notframeData. onBarcodeScannedis called on a background thread. Any UI update must be dispatched viarunOnUiThread {}.- Call
barcodeCapture.isEnabled = falseat the top ofonBarcodeScannedbefore doing any work to prevent duplicate or racing scans. Re-enable withbarcodeCapture.isEnabled = truewhen the app is ready to scan again. - Android symbology names use underscores:
Symbology.EAN13_UPCA,Symbology.CODE39,Symbology.INTERLEAVED_TWO_OF_FIVE— not camelCase. - Turn the camera off in
onPause()and re-enable inonResume(). The camera must not be active while the app is backgrounded. - Request the
CAMERApermission at runtime before the first scan; the manifest declaration alone is not sufficient. DataCaptureView.newInstance(this, dataCaptureContext)creates the camera preview widget. In an Activity, pass it tosetContentView(dataCaptureView). In a Fragment, add it to the view hierarchy programmatically.