Gossip is Android TextToSpeech Helper. This is easiest way to use TextToSpeech on android where you can handle all events of TextToSpeech on UI.
Add the following line in your app level build.gradle
file and you can gossip.
implementation 'me.nikhilchaudhari.gossip:1.0.0'
Or you can just use the Gossip.kt
file in your project (dependencies: Kotlin Coroutines)
-
Initialise the
Gossip
asclass MainActivity : AppCompatActivity() { lateinit var gossip: Gossip override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) gossip = Gossip(this) } }
-
Basic gossiping
gossip.talk("She is beautiful")
The above code will initialise and start a TextToSpeech
of Android and will speak the string passed.
-
Perform UI operations on
TextToSpeech
speak events There are three methods, you can use three to handleonStart
onDone
&onError
states ofTextToSpeech
-
talkAndOnStart
gossip.talkAndOnStart("She should change her dressing", suspend { // Any UI/ MainThread changes girl_image_view.setBackgroundResource = R.drawable.red_dress })
The suspend lambda will be invoked at the time when TextToSpeech will start the talking of passed string.
-
talkAndOnDone
gossip.talkAndOnDone("She should put a lipstik as final touch", suspend { // Any UI/ MainThread changes girl_image_view.setBackgroundResource = R.drawable.lipstik })
The suspend lambda will be invoked at the time when TextToSpeech will end the talking of passed string.
-
talkAndOnError
gossip.talkAndOnStart("She messed up her makeup", suspend { // Any UI/ MainThread changes girl_image_view.setBackgroundResource = R.drawable.messed_up_girl })
The suspend lambda will be invoked at the time when there is an error in speaking the given string.
If you want to define all three events at once, you can use the following method
gossip.talk("There she goes", onStart = suspend { /*Do some UI change */ }, onDone = suspend { /*Do some UI change */ }, onError = suspend { /*Do some UI change */ } )
-
-
Stop Gossiping Stop the TTS with
stop()
methodgossip.stop()
-
Take care of all AfterParty mess Stop the TTS engine to avoid memory leaks.
override fun onDestroy() { super.onDestroy() gossip.shutdown() }
Change Language Locale
You can set the language with setLanguage()
. Default is English
gossip.setLanguage(Locale("hn"))
Change Speed of Reader
You can change speed with setSpeed()
.
gossip.setSpeed(2.0f)
Change the mode of Reader
You can change the mode Queue
and Flush
with setQueueMode
.
Queue
mode will play the text in queue. If you keep playing text/strings.
Flush
mode will flush the whole string at once and reader will play it at once.
gossip.setQueueMode(TextToSpeech.QUEUE_ADD)
gossip.setQueueMode(TextToSpeech.QUEUE_FLUSH)
Check status
gossip.isPlaying()
Copyright 2019 @ Nikhil Chaudhari
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.