Update: 2026-06-21 02:07:00

This commit is contained in:
Hamza-Ayed
2026-06-21 02:07:00 +03:00
parent af3dcae5b7
commit b2fae9ec66
23 changed files with 1412 additions and 210 deletions

View File

@@ -1,3 +1,4 @@
import 'dart:io';
import 'package:siro_rider/constant/box_name.dart';
import 'package:flutter/material.dart';
import 'package:flutter_tts/flutter_tts.dart';
@@ -23,29 +24,39 @@ class TextToSpeechController extends GetxController {
// Initialize TTS engine with language check
Future<void> initTts() async {
try {
String langCode = box.read(BoxName.lang) ?? 'en-US';
bool isAvailable = await flutterTts.isLanguageAvailable(langCode);
String langCode = box.read(BoxName.lang) ?? 'ar-SA';
if (langCode == 'ar') langCode = 'ar-SA';
if (langCode == 'en') langCode = 'en-US';
// If language is unavailable, default to 'en-US'
if (!isAvailable) {
langCode = 'en-US';
}
bool isAvailable = await flutterTts.isLanguageAvailable(langCode);
if (!isAvailable) langCode = 'en-US';
await flutterTts.setLanguage(langCode);
await flutterTts.setSpeechRate(0.5); // Adjust speech rate
await flutterTts.setVolume(1.0); // Set volume
await flutterTts.setSpeechRate(0.5);
await flutterTts.setVolume(1.0);
if (Platform.isIOS) {
await flutterTts.setIosAudioCategory(
IosTextToSpeechAudioCategory.playback,
[
IosTextToSpeechAudioCategoryOptions.mixWithOthers,
IosTextToSpeechAudioCategoryOptions.duckOthers,
],
);
}
} catch (error) {
Get.snackbar('Error', 'Failed to initialize TTS: $error');
print('TTS Init Error: $error');
}
}
// Function to speak the given text
// Function to speak the given text (stops current speech first)
Future<void> speakText(String text) async {
if (text.isEmpty) return;
try {
await flutterTts.awaitSpeakCompletion(true);
await flutterTts.stop();
await flutterTts.speak(text);
} catch (error) {
Get.snackbar('Error', 'Failed to speak text: $error');
print('Failed to speak text: $error');
}
}
}