今天用科大讯飞的SDK,它的语音识别是用的同一个SpeechRecognizer对象,但是它的语音识别、命令词识别如果同时用的话,由于SDK自带的SpeechRecognizer.createRecognizer是单例模式,所以会造成使用冲突。一旦设置了命令词识别参数之后,语音识别就不管用了。
所以今天利用反射,去破坏它的这种单例机制,让自己的语音识别和命令词识别是两个对象,方便使用。

///原代码是这样创建对象,里面含有2个参数
mIat = SpeechRecognizer.createRecognizer(context, mInitListener);

所以我们利用反射调用。

        //利用反射创建属于自身的Recognizer对象
        try {
            Class[] cArg = new Class[2];
            cArg[0] = Context.class;
            cArg[1] = InitListener.class;
            Constructor<SpeechRecognizer> con = SpeechRecognizer.class.getDeclaredConstructor(cArg);
            con.setAccessible(true);
            mIat = con.newInstance(context,mInitListener);
        } catch (Exception e) {
            e.printStackTrace();
        }

ps:这样做的好处是生成了属于自己的识别对象,但是我们应当遵循SDK的设计规则,所以二次封装需要自己实现单例模式。

Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐