Skip to content

React Native Module for iFLYTEK Voice Cloud MSC client

Notifications You must be signed in to change notification settings

jhzzzz/react-native-xfmsc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

react-native-xfmsc

科大讯飞语音云客户端 React Native 组件。 目前只做了中文语音评测的封装,其他尚未实现,后续会逐渐加上。 此项目参考了 https://github.com/pj0579/react-native-xfei 代码。

ScreenCapture

使用说明

Android

  1. android/setting.pradle 添加:
include ':react-native-xfmsc'
project(':react-native-xfmsc').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-xfmsc/android')
  1. android/app/build.gradle 添加依赖:
dependencies {   compile project(':react-native-xfei')
  1. mainActivity onCreate 时初始化msc客户端:
SpeechUtility.createUtility(this, SpeechConstant.APPID + "=改成你的AppId");`
  1. 在语音云申请应用,并将下载的Android SDK中的msc.jar拷贝到libs目录中,相关平台.so文件拷贝到jniLibs目录中。

IOS

  1. 添加相关的 framework: TARGETS - Build Phases - Link binary With Libraries 添加 Contacts.framework ,AddressBook.framework

  2. TARGETS - Build Setting - Header Search Paths 添加 $(SRCROOT)/../../../react-native-xfmsc/ios/Xfei

  3. AppDelegate.m

#import "Xfei.h"
...
(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions<br/>
{
    …
    //Init iflytek
    [RCTXfei crateMyUtility:@"改成你的AppId"];
    …
}
  1. 项目工程 Libraries 加入 Xfei.xcodeproj
  2. TARGETS - Build Phases - Link binary With Libraries 添加 Xfei.a,Status Optional。
  3. 在语音云申请应用,并将下载的iOS SDK中 iflyMSC.Framework 拷贝到 react-native-xfmsc ios 目录中覆盖原文件。

javascript

参考示例:

import XfeiModule from 'react-native-xfmsc';
...
    onClickStart() {
        console.log('onClickStart');

        XfeiModule.startRecord("你好,吃过了吗", 'read_syllable')
    };

    onClickStop() {
        console.log('onClickStop');
        XfeiModule.stopRecord();
    };

    onISECallback =(body) => {
        var json = JSON.stringify(body);
        console.log(json);

        let state = this.state;

        state.evalResult.push(json);
        this.setState({
            evalResult:state.evalResult
        })

    };

    componentWillMount() {
        const moduleEvent = new NativeEventEmitter(XfeiModule);
        this.listener = moduleEvent.addListener('onISECallback', this.onISECallback);  //对应了原生端的名字
    };

    componentWillUnmount() {
        this.listener && this.listener.remove();  //记得remove哦
        this.listener = null;
    };
...    

接口列表

  1. 设置参数: setParameter(String key, String value)

    key:参数名,具体参数列表请参考讯飞语音云SDK。

    value:参数值,具体请参考讯飞语音云SDK。

  2. 开始录音评测: startRecord(String evalPaper, String category)

    evalPaper - 评测内容试卷,试卷格式请参考讯飞语音云SDK。

    category - 评测题型,可以是字、词、篇章,具体请参考讯飞语音云SDK。

  3. 停止录音: stopRecord()

  4. 取消: cancel()

  5. 事件回调: onISECallback(body)

    回调内容为json对象,包含以下字段:

    • type,包括:

    • file: 录音文件,评测完毕后可以回放

      • result: 评测结果 XML 格式
      • volumn: 录音音量,应用程序可据此进行音量显示
      • error: 错误消息
    • msg: 回调消息

    • data: 回调具体内容

About

React Native Module for iFLYTEK Voice Cloud MSC client

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published