From 1d5be5746536f80407ef8f53930a498afb3e23d9 Mon Sep 17 00:00:00 2001 From: Atif Waheed Date: Mon, 25 Mar 2024 00:27:36 +0500 Subject: [PATCH 1/4] feat: sdk int less than 26 removed. --- .../main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt b/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt index 20613d86..a5c9aa16 100644 --- a/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt +++ b/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt @@ -95,9 +95,7 @@ class FlutterTtsPlugin : MethodCallHandler, FlutterPlugin { invokeMethod("speak.onStart", true) } } - if (Build.VERSION.SDK_INT < 26) { - onProgress(utteranceId, 0, utterances[utteranceId]!!.length) - } + onProgress(utteranceId, 0, utterances[utteranceId]!!.length) } override fun onDone(utteranceId: String) { From 661b3d370e2219aae5f6aad80abf6371706ada14 Mon Sep 17 00:00:00 2001 From: Atif Waheed Date: Mon, 25 Mar 2024 00:27:53 +0500 Subject: [PATCH 2/4] feat: setChannelMethodCallHandler function --- lib/flutter_tts.dart | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/lib/flutter_tts.dart b/lib/flutter_tts.dart index 5a350c02..8fafa5ca 100644 --- a/lib/flutter_tts.dart +++ b/lib/flutter_tts.dart @@ -337,6 +337,10 @@ class FlutterTts { ErrorHandler? errorHandler; FlutterTts() { + setChannelMethodCallHandler(); + } + + void setChannelMethodCallHandler() { _channel.setMethodCallHandler(platformCallHandler); } From 61a7e5b1280057b20963f0f2077326170ccf32ab Mon Sep 17 00:00:00 2001 From: Atif Waheed Date: Sat, 20 Apr 2024 23:09:23 +0500 Subject: [PATCH 3/4] Logs for Testing --- .../tundralabs/fluttertts/FlutterTtsPlugin.kt | 24 +++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt b/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt index a5c9aa16..83acbc5d 100644 --- a/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt +++ b/android/src/main/kotlin/com/tundralabs/fluttertts/FlutterTtsPlugin.kt @@ -326,18 +326,29 @@ class FlutterTtsPlugin : MethodCallHandler, FlutterPlugin { } "synthesizeToFile" -> { + Log.d(tag, "synthesizeToFile 1") val text: String? = call.argument("text") + Log.d(tag, "synthesizeToFile 2") if (synth) { + Log.d(tag, "synthesizeToFile 3") result.success(0) return } + Log.d(tag, "synthesizeToFile 4") val fileName: String? = call.argument("fileName") + Log.d(tag, "synthesizeToFile 5") synthesizeToFile(text!!, fileName!!) + Log.d(tag, "synthesizeToFile 5") if (awaitSynthCompletion) { + Log.d(tag, "synthesizeToFile 6") synth = true + Log.d(tag, "synthesizeToFile 7") synthResult = result + Log.d(tag, "synthesizeToFile 8") } else { + Log.d(tag, "synthesizeToFile 9") result.success(1) + Log.d(tag, "synthesizeToFile 10") } } @@ -649,37 +660,46 @@ class FlutterTtsPlugin : MethodCallHandler, FlutterPlugin { } private fun synthesizeToFile(text: String, fileName: String) { + Log.d(tag, "synthesizeToFile 5a") val fullPath: String val uuid: String = UUID.randomUUID().toString() + Log.d(tag, "synthesizeToFile 5b") bundle!!.putString( TextToSpeech.Engine.KEY_PARAM_UTTERANCE_ID, SYNTHESIZE_TO_FILE_PREFIX + uuid ) + Log.d(tag, "synthesizeToFile 5c") val result: Int = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) { + Log.d(tag, "synthesizeToFile 5d") val resolver = this.context?.contentResolver val contentValues = ContentValues().apply { put(MediaStore.MediaColumns.DISPLAY_NAME, fileName) put(MediaStore.MediaColumns.MIME_TYPE, "audio/wav") put(MediaStore.MediaColumns.RELATIVE_PATH, Environment.DIRECTORY_MUSIC) } + Log.d(tag, "synthesizeToFile 5e") val uri = resolver?.insert(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, contentValues) this.parcelFileDescriptor = resolver?.openFileDescriptor(uri!!, "rw") fullPath = uri?.path + File.separatorChar + fileName - + Log.d(tag, "synthesizeToFile 5f") tts!!.synthesizeToFile(text, bundle!!, parcelFileDescriptor!!, SYNTHESIZE_TO_FILE_PREFIX + uuid) } else { + Log.d(tag, "synthesizeToFile 5g") val musicDir = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_MUSIC) val file = File(musicDir, fileName) fullPath = file.path - + Log.d(tag, "synthesizeToFile 5h") tts!!.synthesizeToFile(text, bundle!!, file!!, SYNTHESIZE_TO_FILE_PREFIX + uuid) } + Log.d(tag, "synthesizeToFile 5i") if (result == TextToSpeech.SUCCESS) { + Log.d(tag, "synthesizeToFile 5j") Log.d(tag, "Successfully created file : $fullPath") } else { + Log.d(tag, "synthesizeToFile 5k") Log.d(tag, "Failed creating file : $fullPath") } } From cbc48d0468b57d4795bd585b3be9bc7ade988936 Mon Sep 17 00:00:00 2001 From: Atif Waheed Date: Sun, 21 Apr 2024 01:01:58 +0500 Subject: [PATCH 4/4] Version update --- pubspec.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pubspec.yaml b/pubspec.yaml index e146134c..a90a4e6a 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,6 +1,6 @@ name: flutter_tts description: A flutter plugin for Text to Speech. This plugin is supported on iOS, macOS, Android, Web, & Windows. -version: 4.0.2 +version: 4.0.3 homepage: https://github.com/dlutton/flutter_tts dependencies: