Reconnaissance vocale Uniapp (voix Xunfei) en texte

☞Common applications : la
游戏界面voix de texte, 商城导航栏zone de recherche d'entrée vocale, la 聊天界面saisie de texte voix, etc.

Cité par la voix officielle officielle unicloud :

L'interface de saisie vocale permet aux développeurs Web d'appeler rapidement le microphone de l'appareil pour la saisie vocale sans installer de plug-ins de navigateur supplémentaires. La spécification ne définit pas l'architecture technique du moteur de reconnaissance vocale sous-jacent.L'implémentation du navigateur peut être basée sur un serveur de reconnaissance vocale ou un module de reconnaissance vocale intégré local.

Configurez la voix Xunfei SDK-Recognize
(si vous ne pouvez pas utiliser la voix Xunfei, vous pouvez passer à la voix Baidu et voir le document d'accès vous-même)
entrez dans le répertoire racine du projet manifest.json-> App模块配置-> speechvérifiez la reconnaissance vocale Xunfei, comme indiqué ci-dessous:
Insérez la description de l'image ici

index.vueÉcriture de fichier

<template>
	<view class="content">
		<image class="logo" src="/static/logo.png"></image>
		<button @click="voiceBegain">讯飞语音识别</button>
		<view v-if="words1">
			这是searchValue:{
   
   {words1}}
		</view>
		<view v-if="words2">
			这是searchText:{
   
   {words2}}
		</view>
	</view>
</template>

<script>
	export default {
     
     
		data() {
     
     
			return {
     
     
				title: 'Hello',
				words1: '',
				words2: ''
			}
		},
		onLoad() {
     
     

		},
		methods: {
     
     
			send() {
     
     
				uniCloud.callFunction({
     
     
					name: 'sendcode',
					success: (e) => {
     
     
						console.log('这是发送验证码', e);
					}
				})
			},
			// 调用讯飞语音识别
			voiceBegain() {
     
     
				let _this = this;
				let options = {
     
     };
				//#ifdef APP-PLUS || APP-PLUS-NVUE
				options.engine = 'iFly';
				options.punctuation = false; // 是否需要标点符号 
				options.timeout = 10 * 1000; //语音录入持续时长
				plus.speech.startRecognize(options, function(s) {
     
     
					_this.searchText = _this.searchText + s;
					console.log(_this.searchText) //拿到语音识别的结果
					//下面是逻辑  
					_this.searchValue = s;
					_this.searchText = ""
					
					// 打印输出结果
					 _this.words1 = _this.searchValue
					 _this.words2 = _this.searchText
					 
					// 关闭语音
					plus.speech.stopRecognize();
				});
				//#endif
				// #ifdef H5
				alert("只有h5平台才有alert方法")
				// #endif
			}
		}
	}
</script>

<style>
	.content {
     
     
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}

	.logo {
     
     
		height: 200rpx;
		width: 200rpx;
		margin-top: 200rpx;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 50rpx;
	}

	.text-area {
     
     
		display: flex;
		justify-content: center;
	}

	.title {
     
     
		font-size: 36rpx;
		color: #8f8f94;
	}
</style>

Comme montré:
Insérez la description de l'image ici

exécuter
云打包 ou 自定义调试基座générer un fichier apk , apk installé sur le téléphone;
cliquez sur le buttonbouton pour déclencher la fonction de rappel personnalisé
Insérez la description de l'image ici

Sortie de page à ce moment
Insérez la description de l'image ici
Remarque:
Il n'y a pas d' plusenvironnement de navigateur ordinaire à exécuter uniquement après l'exécution et l'empaquetage de la vraie machine HBuilder plus api. Sinon, une erreur sera signalée:
Insérez la description de l'image ici

Je suppose que tu aimes

Origine blog.csdn.net/qq_44469200/article/details/108753002
conseillé
Classement