flutter_ocr_identity_extractor 1.2.0
flutter_ocr_identity_extractor: ^1.2.0 copied to clipboard
A Flutter package for extracting text from images and parsing Saudi ID card data using Google ML Kit Text Recognition. Supports OCR operations and comprehensive ID card data extraction.
Yousef Gamal Romieh #
Flutter Developer #
Flutter OCR Identity Extractor #
A comprehensive Flutter package for extracting text from images and parsing Saudi ID card data using Google ML Kit Text Recognition. This package provides OCR operations and comprehensive ID card data extraction with AI-powered confidence scoring.
Features #
- ✅ Extract text from images using Google ML Kit
- ✅ Support for multiple recognition scripts
- ✅ Combine results from different recognizers for better accuracy
- ✅ Comprehensive Saudi ID card data extraction
- ✅ AI-powered extraction with confidence scoring
- ✅ Support for Arabic and English text
- ✅ Arabic-Indic and Persian digits conversion
- ✅ Hijri to Gregorian date conversion
- ✅ Simple and easy-to-use API
- ✅ Support for File, file path, and image bytes
- ✅ Singleton pattern for efficient resource management
Installation #
Add this to your package's pubspec.yaml file:
dependencies:
flutter_ocr_identity_extractor: ^1.0.0
Then run:
flutter pub get
Platform Setup #
Android #
Add the following to your android/app/build.gradle:
android {
defaultConfig {
minSdkVersion 21
}
}
iOS #
Add the following to your ios/Podfile:
platform :ios, '10.0'
Then run:
cd ios && pod install
Usage #
Basic OCR Usage #
import 'package:flutter_ocr_identity_extractor/flutter_ocr_identity_extractor.dart';
import 'dart:io';
// Extract text from image file
final imageFile = File('/path/to/your/image.jpg');
final text = await OcrService.instance.recognizeTextFromImage(imageFile);
if (text != null) {
print('Extracted text: $text');
} else {
print('No text found in image');
}
Extract Saudi ID Card Data #
import 'package:flutter_ocr_identity_extractor/flutter_ocr_identity_extractor.dart';
import 'dart:io';
// Step 1: Extract text from image
final imageFile = File('/path/to/id_card.jpg');
final ocrText = await OcrService.instance.recognizeTextFromImage(imageFile);
if (ocrText != null) {
// Step 2: Parse ID card data
final idData = SaudiIdParser.instance.parseOcrText(ocrText);
print('Arabic Name: ${idData.arabicName}');
print('English Name: ${idData.englishName}');
print('Identity Number: ${idData.identityNumber}');
print('Date of Birth: ${idData.dateOfBirth}');
print('Gender: ${idData.gender}');
print('Card Type: ${idData.cardType}');
}
AI-Powered Extraction with Confidence Scoring #
import 'package:flutter_ocr_identity_extractor/flutter_ocr_identity_extractor.dart';
// Extract with AI-powered confidence scoring
final ocrText = await OcrService.instance.recognizeTextFromPath(imagePath);
if (ocrText != null) {
final idData = await AiIdExtractor.instance.extractWithAi(ocrText);
// idData contains extracted fields with high confidence
// Smart name handling ensures both Arabic and English names are available
print('Extracted ID Data: $idData');
print('Arabic Name: ${idData.arabicName}'); // Always available if any name is found
print('English Name: ${idData.englishName}'); // Always available if any name is found
}
Comprehensive Gender Detection (NEW in v1.2.0) #
import 'package:flutter_ocr_identity_extractor/flutter_ocr_identity_extractor.dart';
import 'dart:io';
// Extract with comprehensive gender detection (text + image analysis)
final imageFile = File('/path/to/id_card.jpg');
final ocrText = await OcrService.instance.recognizeTextFromImage(imageFile);
if (ocrText != null) {
// Use EnhancedIdExtractor for maximum accuracy
final idData = await EnhancedIdExtractor.instance.extractWithComprehensiveGender(
ocrText: ocrText,
imageFile: imageFile, // Optional: enables image-based gender detection
);
// Gender detection uses multiple strategies:
// 1. Name-based (بن/بنت)
// 2. Text-based (ذكر/أنثى, Male/Female, M/F)
// 3. Image-based (face analysis) - if imageFile provided
print('Gender: ${idData.gender}'); // M or F with high confidence
}
Smart Name Handling (NEW in v1.2.0) #
The package now automatically ensures both Arabic and English names are always available:
// Example 1: Only Arabic name found in OCR
// OCR Text: "محمد بن عبدالله الشمري"
final idData = await AiIdExtractor.instance.extractWithAi(ocrText);
print('Arabic: ${idData.arabicName}'); // "محمد بن عبدالله الشمري"
print('English: ${idData.englishName}'); // "Mohammed Bin Abdullah Alshammari" (auto-transliterated)
// Example 2: Only English name found in OCR
// OCR Text: "ALSHAMMARI, MOHAMMED ABDULLAH"
final idData2 = await AiIdExtractor.instance.extractWithAi(ocrText2);
print('Arabic: ${idData2.arabicName}'); // "محمد عبدالله الشمري" (auto-transliterated)
print('English: ${idData2.englishName}'); // "ALSHAMMARI, MOHAMMED ABDULLAH"
// Example 3: Both names found
// Both names are used as-is without transliteration
Complete Example #
import 'package:flutter/material.dart';
import 'package:flutter_ocr_identity_extractor/flutter_ocr_identity_extractor.dart';
import 'package:image_picker/image_picker.dart';
import 'dart:io';
class IdCardScannerExample extends StatefulWidget {
@override
_IdCardScannerExampleState createState() => _IdCardScannerExampleState();
}
class _IdCardScannerExampleState extends State<IdCardScannerExample> {
SaudiIdData? _idData;
bool _isProcessing = false;
Future<void> _scanIdCard() async {
final picker = ImagePicker();
final pickedFile = await picker.pickImage(source: ImageSource.camera);
if (pickedFile != null) {
setState(() {
_isProcessing = true;
_idData = null;
});
try {
// Step 1: Extract text from image
final ocrText = await OcrService.instance.recognizeTextFromPath(
pickedFile.path,
);
if (ocrText == null || ocrText.isEmpty) {
// Show error
return;
}
// Step 2: Extract ID data with AI
final idData = await AiIdExtractor.instance.extractWithAi(ocrText);
setState(() {
_isProcessing = false;
_idData = idData;
});
} catch (e) {
setState(() => _isProcessing = false);
// Handle error
}
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: Text('ID Card Scanner')),
body: Center(
child: Column(
children: [
ElevatedButton(
onPressed: _isProcessing ? null : _scanIdCard,
child: Text('Scan ID Card'),
),
if (_isProcessing)
CircularProgressIndicator()
else if (_idData != null)
_buildIdDataDisplay(_idData!),
],
),
),
);
}
Widget _buildIdDataDisplay(SaudiIdData data) {
return Padding(
padding: EdgeInsets.all(16),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text('Arabic Name: ${data.arabicName ?? "N/A"}'),
Text('English Name: ${data.englishName ?? "N/A"}'),
Text('Identity Number: ${data.identityNumber ?? "N/A"}'),
Text('Date of Birth: ${data.dateOfBirth ?? "N/A"}'),
Text('Gender: ${data.gender ?? "N/A"}'),
],
),
);
}
@override
void dispose() {
OcrService.instance.dispose();
super.dispose();
}
}
API Reference #
OcrService #
Singleton service for OCR operations.
Methods
recognizeTextFromImage(File imageFile)- Extract text from image filerecognizeTextFromPath(String imagePath)- Extract text from image pathrecognizeTextFromBytes(InputImage inputImage)- Extract text from image bytesdispose()- Dispose resources
SaudiIdParser #
Parser for extracting Saudi ID card data from OCR text.
Methods
parseOcrText(String ocrText)- Parse OCR text and extract ID card data
Returns: SaudiIdData
AiIdExtractor #
AI-powered extractor with confidence scoring.
Methods
extractWithAi(String ocrText)- Extract ID data with confidence scoring
Returns: Future<SaudiIdData>
SaudiIdData #
Data class containing extracted ID card information:
arabicName- Arabic nameenglishName- English nameidentityNumber- 10-digit identity numberdateOfBirth- Date of birth (DD/MM/YYYY)dateOfExpiry- Date of expiryplaceOfBirth- Place of birthgender- Gender (M or F)cardType- Type of ID card (citizen, resident, visitor)
Requirements #
- Flutter SDK: >=3.0.0
- Dart SDK: >=3.0.0
- Android: minSdkVersion 21
- iOS: iOS 10.0+
Dependencies #
google_mlkit_text_recognition: ^0.12.0logger: ^2.6.1arabic_name_transliterator: ^0.5.0
License #
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing #
Contributions are welcome! Please feel free to submit a Pull Request.
Support #
If you encounter any issues or have questions, please open an issue on the GitHub repository.