• 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"/>

  • 相关阅读:
    Nginx 本地建立负载均衡(Windows环境)
    Nginx 代理本地文件夹(Windows环境)
    PostGIS 使用Mysql_fdw同步ArcGIS填坑记录
    PostGIS mysql_fdw操作日志(留观)
    PostGIS mysql_fdw使用(Linux)
    PostGIS mysql_fdw安装(Linux)
    PostGIS 安装教程(Linux)(二)
    PostGIS 安装教程(Linux)(一)
    Linux 命令记录
    PostGIS 查看表属性(字段、类型、是否为空)
  • 原文地址:https://www.cnblogs.com/lindping/p/7641480.html
Copyright © 2020-2023  润新知