This commit is contained in:
Hamza-Ayed
2023-11-06 18:25:23 +03:00
parent 942fa97a31
commit 8238323dd3
18 changed files with 5817 additions and 326 deletions

View File

@@ -3,12 +3,9 @@ import 'package:get/get.dart';
import 'package:ride/constant/box_name.dart';
import 'package:ride/main.dart';
import 'package:ride/views/auth/login_page.dart';
import 'package:ride/views/home/home_page.dart';
import '../../models/model/onboarding_model.dart';
class OnboardingController extends GetxController {}
abstract class OnBoardingController extends GetxController {
next();
onPageChanged(int index);

View File

@@ -1,7 +1,10 @@
import 'dart:convert';
import 'dart:io';
import 'dart:ui';
import 'package:flutter_tesseract_ocr/flutter_tesseract_ocr.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_tesseract_ocr/android_ios.dart';
import 'package:get/get.dart';
import 'package:google_mlkit_text_recognition/google_mlkit_text_recognition.dart';
import 'package:image_picker/image_picker.dart';
@@ -44,11 +47,11 @@ class TextExtractionController extends GetxController {
Future<void> pickAndExtractText() async {
final pickedImage = await ImagePicker().pickImage(
source: ImageSource.gallery,
// preferredCameraDevice: CameraDevice.rear,
// maxHeight: Get.height * .7,
// maxWidth: Get.width * .9,
// imageQuality: 99,
source: ImageSource.camera,
preferredCameraDevice: CameraDevice.rear,
maxHeight: Get.height * .3,
maxWidth: Get.width * .8,
imageQuality: 99,
);
if (pickedImage != null) {
isloading = true;
@@ -103,13 +106,142 @@ class TextMLGoogleRecognizerController extends GetxController {
// The scanned text
String? scannedText;
String? jsonOutput;
final List<Map<String, dynamic>> lines = [];
Map decode = {};
Future<void> scanText() async {
// Pick an image from the camera or gallery
final XFile? image =
await _imagePicker.pickImage(source: ImageSource.gallery);
// If no image was picked, return
if (image == null) {
return;
}
// Convert the XFile object to an InputImage object
final InputImage inputImage = InputImage.fromFile(File(image.path));
// Recognize the text in the image
final RecognizedText recognizedText =
await _textRecognizer.processImage(inputImage);
scannedText = recognizedText.text;
Map extractedData = {};
// Extract the scanned text line by line
for (var i = 0; i < recognizedText.blocks.length; i++) {
final block = recognizedText.blocks[i];
for (final line in block.lines) {
final lineText = line.text;
if (lineText.contains('DL')) {
final dlNumber = lineText.split('DL')[1].trim();
extractedData['dl_number'] = dlNumber;
}
if (lineText.contains('USA')) {
final usa = lineText.split('USA')[1].trim();
extractedData['USA'] = usa;
}
if (lineText.contains('DRIVER LICENSE')) {
final driverl = lineText;
extractedData['DRIVER_LICENSE'] = driverl;
}
if (lineText.contains('EXP')) {
final expiryDate = lineText.split('EXP')[1].trim();
extractedData['expiry_date'] = expiryDate;
}
if (lineText.contains('DOB')) {
final dob = lineText.split('DOB')[1].trim();
extractedData['dob'] = dob;
}
if (lineText.contains("LN")) {
if ((lineText.indexOf("LN") == 0)) {
final lastName = lineText.split('LN')[1].trim();
extractedData['lastName'] = lastName;
}
}
if (lineText.contains("FN")) {
final firstName = lineText.split('FN')[1].trim();
extractedData['firstName'] = firstName;
}
if (lineText.contains("RSTR")) {
final rstr = lineText.split('RSTR')[1].trim();
extractedData['rstr'] = rstr;
}
if (lineText.contains("CLASS")) {
final class1 = lineText.split('CLASS')[1].trim();
extractedData['class'] = class1;
}
if (lineText.contains("END")) {
final end = lineText.split('END')[1].trim();
extractedData['end'] = end;
}
if (lineText.contains("DD")) {
final dd = lineText.split('DD')[1].trim();
extractedData['dd'] = dd;
}
if (lineText.contains("EYES")) {
final eyes = lineText.split('EYES')[1].trim();
extractedData['eyes'] = eyes;
}
if (lineText.contains("SEX")) {
final parts = lineText.split("SEX ")[1];
extractedData['sex'] = parts[0];
}
if (lineText.contains("HAIR")) {
final hair = lineText.split('HAIR')[1].trim();
extractedData['hair'] = hair;
}
if (lineText.contains('STREET') || lineText.contains(',')) {
final address = lineText;
extractedData['address'] = address;
}
// Repeat this process for other relevant data fields
}
}
// Convert the list of lines to a JSON string
jsonOutput = jsonEncode(extractedData);
decode = jsonDecode(jsonOutput!);
update();
print('jsonOutput------------------------------');
print(scannedText);
}
}
class PassportRecognizerController extends GetxController {
@override
void onInit() {
scanText();
super.onInit();
}
// The ImagePicker instance
final ImagePicker _imagePicker = ImagePicker();
Map extractedData = {};
// The GoogleMlKit TextRecognizer instance
final TextRecognizer _textRecognizer = TextRecognizer();
// The scanned text
String? scannedText;
String? jsonOutput;
final List<Map<String, dynamic>> lines = [];
Map decode = {};
// Picks an image from the camera or gallery and extracts the text
Future<void> scanText() async {
// Pick an image from the camera or gallery
final XFile? image =
await _imagePicker.pickImage(source: ImageSource.camera);
await _imagePicker.pickImage(source: ImageSource.gallery);
// If no image was picked, return
if (image == null) {
@@ -127,15 +259,181 @@ class TextMLGoogleRecognizerController extends GetxController {
final List<Map<String, dynamic>> lines = [];
for (var i = 0; i < recognizedText.blocks.length; i++) {
lines.add({
'line_number': i,
'text': recognizedText.blocks[i].text,
i.toString() +
'_' +
recognizedText.blocks[i].text.toString().split('\n')[0]:
recognizedText.blocks[i].text,
});
}
// for (var i = 0; i < recognizedText.blocks.length; i++) {
// final block = recognizedText.blocks[i];
for (final line in lines) {
final key = line.keys.first;
final value = line.values.first;
if (line.values.contains('UNITED STATES OF')) {
final title = line;
extractedData['title'] = title;
}
if (line.values.contains('PASSPORT CARD')) {
final passport = line;
extractedData['passport'] = passport;
}
if (key == "7_Surname") {
final nextItem = lines[lines.indexOf(line) + 1];
extractedData['surname'] = nextItem.values.first;
}
if (key == "6_Nationality") {
var nationality = value.split('\n')[1];
extractedData['nationality'] = nationality;
}
if (key.contains('CARD')) {
var passportCard = value;
extractedData['passportCard'] = passportCard;
}
if (key.contains("9_Given")) {
var givenNames = value.split('\n')[1];
extractedData['givenNames'] = givenNames;
}
if (key.contains("13_Date of Birth")) {
final parts = value.split('\n');
if (parts.length > 1) {
var dateOfBirth = parts[1];
extractedData['dateOfBirth'] = dateOfBirth;
var sex = parts[0].split(' ')[1];
extractedData['sex'] = sex;
}
}
// }
}
// Convert the list of lines to a JSON string
final String jsonOutput = jsonEncode(lines);
jsonOutput = jsonEncode(extractedData);
decode = jsonDecode(jsonOutput!);
update();
// Print the JSON output
print(jsonOutput);
print('jsonOutput------------------------------');
print(decode);
// print(jsonEncode(lines));
}
}
class PassportDataExtractor extends GetxController {
@override
void onInit() {
extractPassportData();
super.onInit();
}
final ImagePicker _imagePicker = ImagePicker();
late final XFile? image;
final TextRecognizer _textRecognizer = TextRecognizer();
Future<Map<String, dynamic>> extractPassportData() async {
image = await _imagePicker.pickImage(source: ImageSource.gallery);
update();
if (image == null) {
throw Exception('No image picked');
}
final InputImage inputImage = InputImage.fromFile(File(image!.path));
final RecognizedText recognisedText =
await _textRecognizer.processImage(inputImage);
final Map<String, dynamic> extractedData = {};
final List<Map<String, dynamic>> extractedTextWithCoordinates = [];
for (TextBlock block in recognisedText.blocks) {
for (TextLine line in block.lines) {
final String lineText = line.text;
final Rect lineBoundingBox = line.boundingBox!;
extractedTextWithCoordinates.add({
'text': lineText,
'boundingBox': {
'left': lineBoundingBox.left,
'top': lineBoundingBox.top,
'width': lineBoundingBox.width,
'height': lineBoundingBox.height,
},
});
// if (lineText.contains('Passport Number')) {
// final String passportNumber =
// lineText.split('Passport Number')[1].trim();
// extractedData['passportNumber'] = passportNumber;
// }
// if (lineText.contains('Given Names')) {
// final String givenNames = lineText.split('Given Names')[1].trim();
// extractedData['givenNames'] = givenNames;
// }
// if (lineText.contains('Surname')) {
// final String surname = lineText.split('Surname')[1].trim();
// extractedData['surname'] = surname;
// }
// if (lineText.contains('Nationality')) {
// final String nationality = lineText.split('Nationality')[1].trim();
// extractedData['nationality'] = nationality;
// }
// if (lineText.contains('Date of Birth')) {
// final String dob = lineText.split('Date of Birth')[1].trim();
// extractedData['dateOfBirth'] = dob;
// }
// Add more field extraction conditions as needed
}
}
extractedData['extractedTextWithCoordinates'] =
extractedTextWithCoordinates;
print(jsonEncode(extractedData));
return extractedData;
}
}
class PassportDataController extends GetxController {
PassportDataExtractor passportDataExtractor = PassportDataExtractor();
List<Map<String, dynamic>> extractedTextWithCoordinates = [];
Future<void> extractDataAndDrawBoundingBoxes() async {
try {
Map<String, dynamic> extractedData =
await passportDataExtractor.extractPassportData();
extractedTextWithCoordinates =
extractedData['extractedTextWithCoordinates'];
update(); // Notify GetX that the state has changed
print(extractedTextWithCoordinates);
} catch (e) {
print('Passport data extraction failed: $e');
}
}
}
class BoundingBoxPainter extends CustomPainter {
final List<Map<String, dynamic>> boundingBoxes;
BoundingBoxPainter(this.boundingBoxes);
@override
void paint(Canvas canvas, Size size) {
final Paint paint = Paint()
..color = Colors.red
..style = PaintingStyle.stroke
..strokeWidth = 2.0;
for (Map<String, dynamic> boundingBox in boundingBoxes) {
double left = boundingBox['left'];
double top = boundingBox['top'];
double width = boundingBox['width'];
double height = boundingBox['height'];
Rect rect = Rect.fromLTWH(left, top, width, height);
canvas.drawRect(rect, paint);
}
}
@override
bool shouldRepaint(covariant CustomPainter oldDelegate) {
return false;
}
}

View File

@@ -16,6 +16,7 @@ class HomeCaptainController extends GetxController {
Timer? activeTimer;
Map data = {};
String totalMoneyToday = '0';
String totalMoneyInSEFER = '0';
String totalDurationToday = '0';
Timer? timer;
// Inject the LocationController class
@@ -89,7 +90,8 @@ class HomeCaptainController extends GetxController {
link: AppLink.getDriverpaymentToday,
payload: {'driverID': box.read(BoxName.driverID).toString()});
data = jsonDecode(res);
totalMoneyToday = data['message'][0]['total_amount'];
totalMoneyToday = data['message'][0]['todayAmount'];
totalMoneyInSEFER = data['message'][0]['total_amount'];
update();
}

View File

@@ -199,6 +199,7 @@ class MapPassengerController extends GetxController {
int seconds = remainingTimeTimerRideBegin % 60;
stringRemainingTimeRideBegin =
'$minutes:${seconds.toString().padLeft(2, '0')}';
update();
}
@@ -207,6 +208,10 @@ class MapPassengerController extends GetxController {
update();
print('rideTimerBegin: $rideTimerBegin');
print('isRideFinished: $isRideFinished');
await CRUD().post(link: AppLink.addPassengersWallet, payload: {
'passenger_id': box.read(BoxName.passengerID).toString(),
'balance': ((-1) * totalPassenger).toString()
});
Get.to(() => RateCaptainFromPassenger(), arguments: {
'driverId': driverId.toString(),
'rideId': rideId.toString(),

View File

@@ -0,0 +1,65 @@
import 'dart:async';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:ride/views/auth/login_page.dart';
import '../../constant/box_name.dart';
import '../../main.dart';
import '../../onbording_page.dart';
import '../../views/auth/captin/login_captin.dart';
import '../../views/home/Captin/home_captin.dart';
import '../../views/home/map_page.dart';
class SplashScreenController extends GetxController
with SingleGetTickerProviderMixin {
late AnimationController animationController;
late Animation<double> zoomInAnimation;
late Animation<double> zoomOutAnimation;
@override
void onInit() {
super.onInit();
animationController = AnimationController(
vsync: this,
duration: const Duration(seconds: 7),
);
zoomInAnimation = Tween<double>(begin: 1.0, end: 1.5).animate(
CurvedAnimation(
parent: animationController,
curve: Curves.easeInOut,
),
);
zoomOutAnimation = Tween<double>(begin: 1.5, end: 1.0).animate(
CurvedAnimation(
parent: animationController,
curve: Curves.easeInOut,
),
);
animationController.repeat(reverse: true);
startTimer();
}
void startTimer() {
Timer(const Duration(seconds: 7), () {
box.read(BoxName.onBoarding) == null
? Get.off(() => OnBoardingPage())
: box.read(BoxName.email) != null
? Get.off(() => const MapPage())
: box.read(BoxName.emailDriver) == null
? Get.off(() => LoginPage())
: box.read(BoxName.emailDriver) != null
? Get.off(() => const HomeCaptain())
: Get.off(() => LoginCaptin());
});
}
@override
void onClose() {
animationController.dispose();
super.onClose();
}
}