zoukankan      html  css  js  c++  java
  • web端文字转语音的几种方案

    最近在开发一个微信排队取号的的系统,其中对于服务员端(管理端) 需要有呼叫功能,即点按钮 就播出"xxx号顾客请就座"的声音。

    经过在网上一番搜索研究,web端实现指定文字的语音播放 方案有这几种

    1  免费在线服务,一些网站提供文字转语音文件的功能,其中好像百度,讯飞还提供接口调用,但对我来说,需要联网这个条件就被否决了。

    2 使用微软内置activatex语音控件,最简单的但缺点也明显,只能在IE上用,考虑到系统可能在平板电脑上使用,所以这个方案也被否决。

     js代码   

       var VoiceObj = new ActiveXObject("Sapi.SpVoice");
       VoiceObj.Speak("xxx号顾客请就座", 1);

    3  重点来了。 前端使用H5的audio播放组件,后台使用SpeechSynthesizer生成wav音频文件流直接向播放器的src输出。

       大致代码如下:

    前端html

    <audio id="audioPlay">
    <source type="audio/wav" /> 
    </audio>
    
    ......
    
    function play(callText) {
    var audioPlay = document.getElementById("audioPlay");
    audioPlay.src = "../voicehandler.ashx? voice=" + callText;
    audioPlay.play();
    }

    c#后台代码

    public class VoiceHandler : IHttpHandler
        {
    
            public void ProcessRequest(HttpContext context)
            {      
    
                Thread t = null; 
                context.Response.ContentType = "application/wav";
                using (MemoryStream ms = new MemoryStream())
                {
                   
                    t = new Thread(() =>
                    {
                        SpeechSynthesizer ss = new SpeechSynthesizer();
                        try
                        {
                            ss.Rate = -5;
                            ss.Volume = 90;
                            ss.SetOutputToWaveStream(ms);
                            ss.Speak(context.Request["voice"]);
                        }
                        catch(Exception  ex)
                        {
                            ss.Dispose();
                            context.Response.Write(ex.Message);
                        }
                    });
                    t.Start();
                    t.Join();
                    ms.Position = 0;
                    if (ms.Length > 0)
                    {
                        ms.WriteTo(context.Response.OutputStream);
                    }
                    context.Response.End();
                   
                }         
    
            }
    }

    由于语音要设置人声,语速,然后合成语音等一个系列的过程,所以这里要注意的是需要通过异步线程方式调用 SpeechSynthesizer。

    iis调用SpeechSynthesizer,还涉及权限问题,如果程序报出这个异常:

    System.InvalidOperationException    Message=系统上未安装语音,或没有当前安全设置可用的语音。

    那么,试试 

    1. 权限问题;你可以尝试把应用程序池的进程标识改成LocalSystem 

    2. webconfig配置:<identity impersonate="true" userName="YourAdminUsr" password="YourAdminPwd"/>

  • 相关阅读:
    Leetcode:linked_list_cycle
    关于Go语言共享内存操作的小实例
    程序猿如同妓女
    算法——排序算法个人总结
    CentOS 6.4下安装和配置Samba 第2页_服务器应用_Linux公社-Linux系统门户网站
    解决fedora samba在windows下无权限访问的问题
    基于samba实现win7与linux之间共享文件_阳仔_新浪博客
    增加samba用户提示Failed to add entry for user
    Ubuntu+Win7+Samba实现文件共享_Linux教程_Linux公社-Linux系统门户网站
    Mycat 月分片方法
  • 原文地址:https://www.cnblogs.com/lindping/p/7641480.html
Copyright © 2011-2022 走看看