Continuous Speech Recognition Android - Without Ga

2019-03-19 07:31发布

I have an activity that implements RecognitionListener. To make it continuous, every time onEndOfSpeech() I start the listener again:

speech.startListening(recognizerIntent);

But, it takes some time (around half a second) till it starts, so there is this half a second gap, where nothing is listening. Therefore, I miss words that were spoken in that time difference.

On the other hand, when I use Google's Voice input, to dictate messages instead of the keyboard - this time gap does not exist. Meaning - there is a solution.

What is it?

Thanks

3条回答
一夜七次
2楼-- · 2019-03-19 08:01

try looking at a couple other api's....

speech demo : has source here and is discussed here and operated on CLI here

you could use the full duplex google api ( its rate capped at 50 per day )

Or if you like that general idea check ibm's watson discussed here

IMO - its more complex but not capped .

查看更多
祖国的老花朵
3楼-- · 2019-03-19 08:21

There are options like:

intent.putExtra(RecognizerIntent.EXTRA_SPEECH_INPUT_COMPLETE_SILENCE_LENGTH_MILLIS, 2000); // value to wait

or

intent.putExtra(RecognizerIntent.EXTRA_SPEECH_INPUT_POSSIBLY_COMPLETE_SILENCE_LENGTH_MILLIS, 2000);

These ceased to work on Jelly Bean and above, but work on ICS and below - not sure if intended or a bug!

查看更多
再贱就再见
4楼-- · 2019-03-19 08:26

I'll recommend using CMUSphinx to recognize speech continuously. To achieve continuous speech recognition using google speech recognition api, you might have to resort to a loop in a background service which will take too much resources and drains the device battery.

On the other hand, Pocketsphinx works really great. It's fast enough to spot a key phrase and recognize voice commands behind the lock screen without users touching their device. And it does all this offline. You can try the demo.

If you really want to use google's api, see this

查看更多
登录 后发表回答