百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 软件资讯 > 正文

编程不难: 几句代码调用 Edge 逼真语音,一句代码同步浏览器 Cookie

ninehua 2024-12-30 06:03 43 浏览

前几天有人问通过 WebSocket 调用语音遇到的问题。我就稍微封装了一下。

几个要点注意一下:
1、这个接口在连接 WebSocket 以后,来回每个消息前面有类 HTTP 格式头。而 HTTP 头的拼接要很小心,少了一个回车符、换行符都会出错。

其实 aardio 里有个 web.joinHeaders() 做这事很方便,这个函数的参数可以传很多不同奇奇怪怪的格式进去,然后自动修正错误,规一化为正确的格式。

而我今天基于这个函数又为 aardio 新增了一个 string.http 库,专门用来生成与解析 Edge 接口的这种消息格式(其实挺好用)。

2、每次语音转文本要重新连接 WebSocket ,这是容易误解和出错的地方。套接字断开了就不要用了,重新创建一个 WebSocket 再连上去就可以了。

首先在 aardio 里画一个界面,aardio 做这些事很简单:

然后切换到代码视图,输入代码如下:

import bass.channel; 
import web.edgeTextToSpeech;
import win.ui;
/*DSG{{*/
var winform = win.form(text="Edge 大声朗读")
winform.add(
button={cls="button";text="文本转语音";left=472;top=384;right=705;bottom=445;color=14120960;db=1;dr=1;font=LOGFONT(h=-14);note="调用 Edge WebSocket 大声朗读接口";z=2};
cmbVoice={cls="combobox";left=67;top=390;right=297;bottom=416;db=1;dl=1;edge=1;items={};mode="dropdownlist";z=3};
edit={cls="edit";left=8;top=10;right=741;bottom=370;db=1;dl=1;dr=1;dt=1;edge=1;multiline=1;z=1};
static={cls="static";text="速度:";left=0;top=432;right=56;bottom=456;align="right";center=1;transparent=1;z=5};
static2={cls="static";text="语音:";left=0;top=392;right=56;bottom=416;align="right";center=1;transparent=1;z=6};
tbRate={cls="trackbar";left=56;top=424;right=344;bottom=454;max=100;min=0;z=4}
)
/*}}*/

//响应按钮点击事件
winform.button.oncommand = function(id, event) { 
     
    //禁用按钮,显示加载动画
    winform.button.disabledText = {"?";"?";"?";"?";"?";"?"}
    
    //创建文本转语音服务
    var tts = web.edgeTextToSpeech(winform.edit.text,"\tts.mp3")
    
    //设置语音
    tts.voiceOptions.name = winform.cmbVoice.selText
    
    //设置速度
    tts.voiceOptions.rate = (winform.tbRate.pos - 100) + "%"
     
    //识别完成
    tts.OnResponseEnd = function(path){ 
        
        //启用按钮,停止动画
        winform.button.disabledText = null; 
        
        //播放声音
        bass.channel.open(string.load(path)).play()
    }
    
    //连接服务器,合成语音
    tts.ConnectAsync();
}

//设置滑块范围(语音速度)
winform.tbRate.setRange(0,200);
winform.tbRate.pos = 100;

//可选语音列表
winform.cmbVoice.items = { 
 "zh-CN-XiaoxiaoNeural";
 "zh-CN-XiaoyiNeural";
 "zh-CN-YunjianNeural";
 "zh-CN-YunxiNeural";
 "zh-CN-YunxiaNeural";
 "zh-CN-YunyangNeural";
 "zh-CN-shaanxi-XiaoniNeural";
 "zh-CN-liaoning-XiaobeiNeural";
 "zh-TW-HsiaoChenNeural";
 "zh-TW-YunJheNeural";
 "zh-TW-HsiaoYuNeural"; 
 "zh-HK-HiuGaaiNeural";
 "zh-HK-HiuMaanNeural";
 "zh-HK-WanLungNeural";
}
winform.cmbVoice.selIndex = 1;

winform.show();
win.loopMessage();

按 F5 运行就可以了。有兴趣可以阅读一下扩展库的源代码,也没几句代码。

再说一个最近跟浏览器有关的的更新。

kanadeblisst 写了一篇很棒的文章:

aardio爬虫实战篇:采集自己的公众号粉丝列表。

开源地址: https://github.com/kanadeblisst00/CrawlBizUsers

我最近改进了一下文中提到的 Cookie 有关的功能。经过改进以后,现在只要一句代码就能自动把 WebView2 浏览器控件的 Cookie 提取出来用于自己创建的 HTTP 客户端。

就用 kanadeblisst 这个很棒的案例我们做一下演示:

import win.ui;
/*DSG{{*/
var winform = win.form(text="取粉丝列表") 
/*}}*/

import web.view;
var wb = web.view(winform);  
wb.go("https://mp.weixin.qq.com");
winform.show();

//等待网址,获取网址内 token 参数
var token = wb.waitUrlParam("cgi-bin/home","token");

//创建 HTTP 客户端
import web.rest.jsonLiteClient;
var http = web.rest.jsonLiteClient();

//获取 web.view 的 Cookie
http.setCookie(wb);

//声明 API 
var mp = http.api("https://mp.weixin.qq.com/cgi-bin/user_tag");

//调用 API 
var result = mp.get({
    "token": token,
    "action": "get_user_list",
    "groupid": -2,
    "limit": 20,
    "offset": 0, 
    "lang": "zh_CN",
    "f": "json",
    "backfoward": 1,
    "ajax": 1,
    "random": "0." + string.random(16, "0123456789"),
    "begin_create_time": 11111
}) 

//查看返回数据
import console;
console.dumpJson(result);

win.loopMessage();

按 F5 运行看效果,是不是方便多了?

相关推荐

单打独斗的产品设计师工作流程总结

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。我从入行开始就在一个做自己产品的小公司工作,到现在已经三年了。刚开始工作的时候什么也不懂,老板说让出效果图,就开始直接...

毕业生必备软件!6套APP构建我的产品设计工作流

工欲善其事,必先利其器。思维和方法论固然超级重要,但是掌握并制定适合自己的工作流也可以成倍提升效率。好的软件加上熟练的使用可以帮助解决遇到的所有问题,不仅可以减轻大脑和身体的负担,更可以让产品设计师在...

如何在APP原型上写需求?(app原型设计规范)

你有没有过这样的经历——辛辛苦苦写了半天的文档,结果开发一眼没看,做需求的时候又把文档里的内容问了一遍?如果你也有这样的经历,那么在APP原型上写需求,或许能帮你解决这个问题。为什么要把需求直接写在...

产品经理工具箱|原型及交互设计工具

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。世界上最实在最方便的原型设计及交互工具:国外的谷歌,facebook等大型互联网公司的交互工具就是上面最原始,最有效最...

交互设计利器汇总:实用工具大揭秘!

近年来,页面交互设计有了很好的发展,越来越受到人们的重视。如果你想成为一名页面交互设计师,除了对平面设计和产品设计有一定的了解外,更重要的是要知道哪个软件适合页面交互设计。本文将带您了解5款流行的页面...

Taro - 京东凹凸实验室出品的小程序多端开发工具,内置 UI 组件库

可以支持转换到微信/京东/百度/支付宝/字节跳动/QQ小程序以及H5端,同时也支持使用Vue语法了。关于Taro凹凸实验室(O2Lab)来自京东零售集团,创建于2015年10月,是...

开发2小时,修bug2周,我用Trae做了个小程序

在当今快速发展的科技时代,AI技术的崛起为开发者带来了前所未有的机遇与挑战。一方面,AI极大地降低了技术门槛,让更多的创意得以快速实现;另一方面,它也提升了竞争维度,促使人们在认知、方法和时间效率上不...

好用的10款免费原型设计工具(免费的原型设计软件)

对产品经理或UI/UX设计师来说,一款好的原型设计工具至关重要。好的原型设计软件能够帮助你快速构建还原度高且信息架构清晰明了的原型图,还能极大减低工作中与同事的沟通成本,更高效地推进工作。那么,一款好...

用局域网内部分享Axure原型,这里有详细的步骤

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。用axure做好原型,想分享给别人,有几个方法:生成本地文件,发送本地文件,但是文件有更新,就要重新发送用axure自...

Axure制作App原型应该怎样设置尺寸?原型尺寸对照表!

最近有几位小伙伴儿都提出同样一个疑问:想用Axure设计一个APP原型放到真实的移动设备中演示,但不知道应该使用什么尺寸?若要解释清楚像素和分辨率需要的篇幅比较长,请大家参考百度百科。这里老枪搜集...

200套数据可视化大屏模版Axure高保真原型

超炫可视化大屏模版来了,Axure高保真原型。关注微信公众号“素材帮帮站”,发送消息100051,获取素材下载地址。查看往期文章,获取更多免费素材。

Axure RP 8 Beta版正式上线(axure rp8是什么软件)

AxureSoftwareSolution公司于美国当地时间8月12日宣布其旗下产品AxureRP的v8版本的测试版正式上线。以下是其官方博客关于对AxureRP8Beta版的介绍:今天,...

PM小技术:使用SAE发布在线Axure文档

俗话说,不会写代码的产品经理不是好的射鸡湿。关于产品经理与技术之间的微妙关系,扯开了讲可是长篇大论,比如知乎上这个问题:IT行业产品经理(尤其是创业的)需要懂技术吗?懂到什么程度?,以及这个:产品经...

『原型资源』Axure自带图标库不够用,第三方经典图标库来袭

今天小编为大家带来第三方经典图标库,己确认内容可用现推荐给大家。直接上手就可不用自己画哈~获取原型文档请与班主任联系!先睹为快,合适再拿走不谢:图标太多,截取部分给大家参考o(* ̄︶ ̄*)o免费领取资...

Axure RP 8 测试版:将于今年夏天到来

我们一直在努力的开发AxureRP8。我认为这是对现有客户以及刚接触Axure的人的一个重要版本。我们希望看到你使用这些新特性,所以我们对现有客户免费升级。所有有AxureRP授权的客户包括标准...