Я пытаюсь реализовать простой сервис распознавания речи (сейчас отдельно, чтобы добавить его в конечном итоге в более крупное приложение).
Я получаю странную ошибку во время выполнения, которую я не мог 'получить ответ на него онлайн или в документации.
вот код ....
app.module.ts
import { SpeechRecognition } from '@ionic-native/speech-recognition/ngx';
.....
providers: [
StatusBar,
SplashScreen,
SpeechRecognition,
{provide: ErrorHandler, useClass: IonicErrorHandler}]
home.ts
import { SpeechRecognition } from '@ionic-native/speech-recognition/ngx';
import { AlertController } from 'ionic-angular';
......
constructor (private sr: SpeechRecognition, private alertCtrl: AlertController)
......
ngonInit() {
try {
this.sr.hasPermission().then((permission: boolean) => {
if(!permission) {
this.sr.requestPermission().then(
() => console.log("Granted"),
() => console.log("Denied")
);
}
});
}
catch(err) {
let alert = this.alertCtrl.create({
title: "x_x",
message: "Opps! couldn't get permission!",
buttons: [{
text: "cancel",
role: 'cancel',
handler: () => {}
}]
});
console.log(err); //ERROR LOGGED
alert.present();
}
}
start() {
try {
this.sr.startListening().subscribe((matches: Array<string>) => {
console.log(matches);
this.msg= matches[0];
});
}
catch(err) {
let alert = this.alertCtrl.create({
title: "x_x",
message: "Opps! something is wrong!",
buttons: [{
text: "cancel",
role: 'cancel',
handler: () => {}
}]
});
console.log(err); // ERROR LOGGED if ngOnInit kept empty
alert.present();
}
}
с простой кнопкой HTML, чтобы вызвать start () и распечатать все, что сопоставляется распознавателем.
На всякий случай, если этопроблема совместимости, я использую
@ ionic-native / распознавание речи ":" ^ 5.0.0 "
cordova-plugin-speechrecognition": "1.2.0 "
Ошибка, которую я получаю, всегда
TypeError: Object (...) не является функцией в SpeechRecognition.hasPermission
Само собой разумеется, если я закомментирую содержимое ngOnInit, ошибка изменится на startListening () не является функцией.
PS Это мой первый вопрос здесьStackOverFlow, надеюсь, я предоставил достаточно информации о проблеме.
Спасибо.