当前位置:首页 > 智能硬件 > 人工智能AI
[导读]   通过一番调研,发现国内上市公司科大讯飞的语音+SDK包口碑好,效果好,集成也方便。语音+支持离线应用,这是最主要的。集成过程走起:   1、下载DEMO程序。DEMO程序就包含了全部

  通过一番调研,发现国内上市公司科大讯飞的语音+SDK包口碑好,效果好,集成也方便。语音+支持离线应用,这是最主要的。集成过程走起:

  1、下载DEMO程序。DEMO程序就包含了全部需要的资源。

  

  2、SDK集成关键代码:

  (1)SpeechSynthesizer 是 jar包里封装的语音合成对象她是我们的女主角。

  // 语音合成对象private SpeechSynthesizer mTts;public staTIc String SPEAKER = “speaker”;

  从demo照抄实例化mTts的代码。调用方式应该是jar里封装好的方法外包调用,暂时不关注,先关注一下怎样用起来。

  private void checkVoiceServiceIsInstalled()

  {// 检测语音引擎是否可用,如果没有安装自动安装if (!checkSpeechServiceInstall())

  {String assetsApk = “SpeechService.apk”;

  if (processInstall(this, assetsApk))SpeechUTIlity.getUTIlity(this).setAppid(“53c776aa”);return;}// 引擎初始化

  SpeechUTIlity.getUtility(this).setAppid(“53c776aa”);

  mTts = new SpeechSynthesizer(this, mTtsInitListener);}

  (2)检查语音加引擎是否安装

  /** * 执行本地安装 语音+ * * @param context * @param assetsApk * @return */private boolean processInstall(Context context, String assetsApk)

  {try {Thread.sleep(30000);} catch (InterruptedException e) {e.printStackTrace();}// 本地安装方式

  if (!ApkInstaller.installFromAssets(context, assetsApk))

  {Toast.makeText(activity_main.this, “安装语音引擎失败!”, Toast.LENGTH_SHORT).show();return false;}return true;}/** * 检测科大讯飞语音+引擎是否安装 *

  * @return */private boolean checkSpeechServiceInstall() {String packageName = “com.iflytek.speechcloud”;

  List

  for (int i = 0; i 《 packages.size(); i++) {PackageInfo packageInfo = packages.get(i);

  if (packageInfo.packageName.equals(packageName)) {return true;} else {continue;}}return false;}/** * 语音合成的参数设置 *

  * @param param * @return */private void setParam() {mTts.setParameter(SpeechConstant.ENGINE_TYPE,sp.getString(“engine_preference”, “local”));

  if (sp.getString(“engine_preference”, “local”).equalsIgnoreCase(“local”))

  {mTts.setParameter(SpeechSynthesizer.VOICE_NAME,sp.getString(“role_cn_preference”, “xiaoyan”));}

  else {mTts.setParameter(SpeechSynthesizer.VOICE_NAME,sp.getString(“role_cn_preference”, “xiaoyan”));}

  mTts.setParameter(SpeechSynthesizer.SPEED,sp.getString(“speed_preference”, “50”));

  mTts.setParameter(SpeechSynthesizer.PITCH,sp.getString(“pitch_preference”, “50”));

  mTts.setParameter(SpeechSynthesizer.VOLUME,sp.getString(“volume_preference”, “50”));}

  (3)初期化监听,我在ErrorCode.SUCCESS初始化成功后显示语音引擎可用的状态,否则红叉显示不可以状态。合成回调监听,这里为了避免异步方式调用,听不清楚,使用了局部变量记录当前的语音播报状态isPlaySound。引擎支持异步调用,如果不控制会出现,一句话没说完,其他调用又在发起请求的情况,使用了队列来控制播报的顺序。

  /** * 初期化监听。 */

  private InitListener mTtsInitListener = new InitListener() {@Overridepublic void onInit(ISpeechModule arg0, int code)

  {if (code == ErrorCode.SUCCESS) {btn_voiceDemo.setBackgroundResource(R.drawable.voice_enable_style);}

  else {btn_voiceDemo.setBackgroundResource(R.drawable.voice_disable_style);}}};/** * 合成回调监听。

  */private SynthesizerListener mTtsListener = new SynthesizerListener.Stub()

  {@Overridepublic void onBufferProgress(int progress) throws RemoteException {}@Overridepublic void onCompleted(int code)

  throws RemoteException {activity_main.this.runOnUiThread(new Runnable() {@Overridepublic void run() {int pos = voiceQueueList.indexOf(getCurrentVoiceEntity());

  if (pos != -1) {currentVoiceEntity.setVoicePlayNum(currentVoiceEntity.getVoicePlayNum() + 1);

  voiceQueueList.remove(pos);

  if (currentVoiceEntity.getVoicePlayNum() 》 Integer.parseInt(sp.getString(“voice_play_timers”, “0”))) {currentVoiceEntity.setIsVoicePlayed(true);

  new ExecVoiceStatusChangeBiz().execute(String.valueOf(getCurrentVoiceEntity().getKeyId()));}

  voiceQueueList.add(currentVoiceEntity);}loadVoiceTaskList();}});isPlaySound = false;}@Overridepublic void onSpeakBegin()

  throws RemoteException {isPlaySound = true;}@Overridepublic void onSpeakPaused()

  throws RemoteException {}@Overridepublic void onSpeakProgress(int progress)

  throws RemoteException {}@Overridepublic void onSpeakResumed()

  throws RemoteException {}};/** * 窗体销毁时释放语音服务资源 */

  @Overrideprotected void onDestroy() {super.onDestroy();mTts.stopSpeaking(mTtsListener);mTts.destory();}

  3、完成。截图纪念一下:

  

  

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭